TDengine/source/dnode/mgmt/test/mnode/dmnode.cpp

210 lines
6.2 KiB
C++
Raw Normal View History

2022-01-06 11:18:13 +00:00
/**
* @file dmnode.cpp
* @author slguan (slguan@taosdata.com)
* @brief DNODE module mnode tests
* @version 1.0
* @date 2022-01-07
*
* @copyright Copyright (c) 2022
*
*/
#include "sut.h"
class DndTestMnode : public ::testing::Test {
protected:
static void SetUpTestSuite() { test.Init(TD_TMP_DIR_PATH "dmnodeTest", 9114); }
2022-01-07 11:12:50 +00:00
static void TearDownTestSuite() { test.Cleanup(); }
2022-01-07 10:03:28 +00:00
2022-02-16 08:36:05 +00:00
static Testbase test;
2022-01-06 11:18:13 +00:00
public:
void SetUp() override {}
void TearDown() override {}
};
2022-02-16 08:36:05 +00:00
Testbase DndTestMnode::test;
2022-01-07 04:07:23 +00:00
2022-01-07 10:03:28 +00:00
TEST_F(DndTestMnode, 01_Create_Mnode) {
2022-01-07 10:30:20 +00:00
{
2022-02-16 08:36:05 +00:00
SDCreateMnodeReq createReq = {0};
createReq.dnodeId = 2;
createReq.replica = 1;
createReq.replicas[0].id = 1;
createReq.replicas[0].port = 9113;
strcpy(createReq.replicas[0].fqdn, "localhost");
2022-01-07 10:30:20 +00:00
2022-02-16 08:36:05 +00:00
int32_t contLen = tSerializeSDCreateMnodeReq(NULL, 0, &createReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSDCreateMnodeReq(pReq, contLen, &createReq);
2022-01-07 10:30:20 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_MNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_MNODE_ALREADY_DEPLOYED);
2022-01-07 10:30:20 +00:00
}
2022-01-07 10:03:28 +00:00
2022-01-07 10:30:20 +00:00
{
2022-02-16 08:36:05 +00:00
SDCreateMnodeReq createReq = {0};
createReq.dnodeId = 1;
createReq.replica = 1;
createReq.replicas[0].id = 2;
createReq.replicas[0].port = 9113;
strcpy(createReq.replicas[0].fqdn, "localhost");
2022-01-07 10:03:28 +00:00
2022-02-16 08:36:05 +00:00
int32_t contLen = tSerializeSDCreateMnodeReq(NULL, 0, &createReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSDCreateMnodeReq(pReq, contLen, &createReq);
2022-01-07 10:03:28 +00:00
2022-01-07 10:30:20 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_MNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_MNODE_ALREADY_DEPLOYED);
2022-01-07 10:30:20 +00:00
}
2022-01-07 10:03:28 +00:00
2022-01-07 10:30:20 +00:00
{
2022-02-16 08:36:05 +00:00
SDCreateMnodeReq createReq = {0};
createReq.dnodeId = 1;
createReq.replica = 2;
createReq.replicas[0].id = 1;
createReq.replicas[0].port = 9113;
strcpy(createReq.replicas[0].fqdn, "localhost");
createReq.replicas[1].id = 1;
createReq.replicas[1].port = 9114;
strcpy(createReq.replicas[1].fqdn, "localhost");
int32_t contLen = tSerializeSDCreateMnodeReq(NULL, 0, &createReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSDCreateMnodeReq(pReq, contLen, &createReq);
2022-01-07 10:30:20 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_MNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_MNODE_ALREADY_DEPLOYED);
2022-01-07 10:30:20 +00:00
}
2022-01-07 04:07:23 +00:00
}
TEST_F(DndTestMnode, 02_Alter_Mnode) {
2022-02-16 08:36:05 +00:00
{
SDAlterMnodeReq alterReq = {0};
alterReq.dnodeId = 2;
alterReq.replica = 1;
alterReq.replicas[0].id = 1;
alterReq.replicas[0].port = 9113;
strcpy(alterReq.replicas[0].fqdn, "localhost");
2022-01-07 04:07:23 +00:00
2022-02-16 08:36:05 +00:00
int32_t contLen = tSerializeSDCreateMnodeReq(NULL, 0, &alterReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSDCreateMnodeReq(pReq, contLen, &alterReq);
2022-01-07 04:07:23 +00:00
2022-06-02 11:00:14 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_MNODE, pReq, contLen);
2022-01-07 04:07:23 +00:00
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_INVALID_OPTION);
2022-01-07 04:07:23 +00:00
}
{
2022-02-16 08:36:05 +00:00
SDAlterMnodeReq alterReq = {0};
alterReq.dnodeId = 1;
alterReq.replica = 1;
alterReq.replicas[0].id = 2;
alterReq.replicas[0].port = 9113;
strcpy(alterReq.replicas[0].fqdn, "localhost");
2022-01-07 04:07:23 +00:00
2022-02-16 08:36:05 +00:00
int32_t contLen = tSerializeSDCreateMnodeReq(NULL, 0, &alterReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSDCreateMnodeReq(pReq, contLen, &alterReq);
2022-01-07 04:07:23 +00:00
2022-06-02 11:00:14 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_MNODE, pReq, contLen);
2022-01-07 04:07:23 +00:00
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_INVALID_OPTION);
2022-01-07 04:07:23 +00:00
}
{
2022-02-16 08:36:05 +00:00
SDAlterMnodeReq alterReq = {0};
alterReq.dnodeId = 1;
alterReq.replica = 1;
alterReq.replicas[0].id = 1;
alterReq.replicas[0].port = 9113;
strcpy(alterReq.replicas[0].fqdn, "localhost");
2022-01-07 04:07:23 +00:00
2022-02-16 08:36:05 +00:00
int32_t contLen = tSerializeSDCreateMnodeReq(NULL, 0, &alterReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSDCreateMnodeReq(pReq, contLen, &alterReq);
2022-01-07 04:07:23 +00:00
2022-06-02 11:00:14 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_MNODE, pReq, contLen);
2022-01-07 04:07:23 +00:00
ASSERT_NE(pRsp, nullptr);
2022-01-07 11:12:50 +00:00
ASSERT_EQ(pRsp->code, 0);
2022-01-07 04:07:23 +00:00
}
}
TEST_F(DndTestMnode, 03_Drop_Mnode) {
{
2022-02-16 08:36:05 +00:00
SDDropMnodeReq dropReq = {0};
dropReq.dnodeId = 2;
2022-01-07 04:07:23 +00:00
2022-10-18 09:34:58 +00:00
int32_t contLen = tSerializeSCreateDropMQSNodeReq(NULL, 0, &dropReq);
2022-02-16 08:36:05 +00:00
void* pReq = rpcMallocCont(contLen);
2022-10-18 09:34:58 +00:00
tSerializeSCreateDropMQSNodeReq(pReq, contLen, &dropReq);
2022-01-07 04:07:23 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_MNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_INVALID_OPTION);
2022-01-07 04:07:23 +00:00
}
{
2022-02-16 08:36:05 +00:00
SDDropMnodeReq dropReq = {0};
dropReq.dnodeId = 1;
2022-01-07 04:07:23 +00:00
2022-10-18 09:34:58 +00:00
int32_t contLen = tSerializeSCreateDropMQSNodeReq(NULL, 0, &dropReq);
2022-02-16 08:36:05 +00:00
void* pReq = rpcMallocCont(contLen);
2022-10-18 09:34:58 +00:00
tSerializeSCreateDropMQSNodeReq(pReq, contLen, &dropReq);
2022-01-07 04:07:23 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_MNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, 0);
}
{
2022-02-16 08:36:05 +00:00
SDDropMnodeReq dropReq = {0};
dropReq.dnodeId = 1;
2022-01-07 04:07:23 +00:00
2022-10-18 09:34:58 +00:00
int32_t contLen = tSerializeSCreateDropMQSNodeReq(NULL, 0, &dropReq);
2022-02-16 08:36:05 +00:00
void* pReq = rpcMallocCont(contLen);
2022-10-18 09:34:58 +00:00
tSerializeSCreateDropMQSNodeReq(pReq, contLen, &dropReq);
2022-01-07 04:07:23 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_MNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_MNODE_NOT_DEPLOYED);
2022-01-07 04:07:23 +00:00
}
{
2022-02-16 08:36:05 +00:00
SDAlterMnodeReq alterReq = {0};
alterReq.dnodeId = 1;
alterReq.replica = 1;
alterReq.replicas[0].id = 1;
alterReq.replicas[0].port = 9113;
strcpy(alterReq.replicas[0].fqdn, "localhost");
2022-01-07 04:07:23 +00:00
2022-02-16 08:36:05 +00:00
int32_t contLen = tSerializeSDCreateMnodeReq(NULL, 0, &alterReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSDCreateMnodeReq(pReq, contLen, &alterReq);
2022-01-07 04:07:23 +00:00
2022-06-02 11:00:14 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_MNODE, pReq, contLen);
2022-01-07 04:07:23 +00:00
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_MNODE_NOT_DEPLOYED);
2022-01-07 04:07:23 +00:00
}
{
2022-02-16 08:36:05 +00:00
SDCreateMnodeReq createReq = {0};
createReq.dnodeId = 1;
createReq.replica = 2;
createReq.replicas[0].id = 1;
createReq.replicas[0].port = 9113;
strcpy(createReq.replicas[0].fqdn, "localhost");
int32_t contLen = tSerializeSDCreateMnodeReq(NULL, 0, &createReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSDCreateMnodeReq(pReq, contLen, &createReq);
2022-01-07 04:07:23 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_MNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, 0);
}
2022-01-07 11:12:50 +00:00
}