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

189 lines
5.3 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:
2022-01-10 07:15:37 +00:00
static void SetUpTestSuite() { test.Init("/tmp/dnode_test_mnode", 9114); }
2022-01-07 11:12:50 +00:00
static void TearDownTestSuite() { test.Cleanup(); }
2022-01-07 10:03:28 +00:00
static Testbase test;
2022-01-06 11:18:13 +00:00
public:
void SetUp() override {}
void TearDown() override {}
};
2022-01-07 10:03:28 +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
{
int32_t contLen = sizeof(SDCreateMnodeReq);
SDCreateMnodeReq* pReq = (SDCreateMnodeReq*)rpcMallocCont(contLen);
pReq->dnodeId = htonl(2);
pReq->replica = 1;
pReq->replicas[0].id = htonl(1);
pReq->replicas[0].port = htonl(9113);
strcpy(pReq->replicas[0].fqdn, "localhost");
SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_MNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_DND_MNODE_INVALID_OPTION);
}
2022-01-07 10:03:28 +00:00
2022-01-07 10:30:20 +00:00
{
int32_t contLen = sizeof(SDCreateMnodeReq);
2022-01-07 10:03:28 +00:00
2022-01-07 10:30:20 +00:00
SDCreateMnodeReq* pReq = (SDCreateMnodeReq*)rpcMallocCont(contLen);
pReq->dnodeId = htonl(1);
pReq->replica = 1;
pReq->replicas[0].id = htonl(2);
pReq->replicas[0].port = htonl(9113);
strcpy(pReq->replicas[0].fqdn, "localhost");
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_DND_MNODE_INVALID_OPTION);
}
2022-01-07 10:03:28 +00:00
2022-01-07 10:30:20 +00:00
{
int32_t contLen = sizeof(SDCreateMnodeReq);
SDCreateMnodeReq* pReq = (SDCreateMnodeReq*)rpcMallocCont(contLen);
pReq->dnodeId = htonl(1);
pReq->replica = 2;
pReq->replicas[0].id = htonl(1);
pReq->replicas[0].port = htonl(9113);
strcpy(pReq->replicas[0].fqdn, "localhost");
pReq->replicas[1].id = htonl(1);
pReq->replicas[1].port = htonl(9114);
strcpy(pReq->replicas[1].fqdn, "localhost");
SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_MNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_DND_MNODE_ALREADY_DEPLOYED);
}
2022-01-07 04:07:23 +00:00
}
TEST_F(DndTestMnode, 02_Alter_Mnode) {
2022-01-07 11:12:50 +00:00
{
int32_t contLen = sizeof(SDAlterMnodeReq);
2022-01-07 04:07:23 +00:00
2022-01-07 11:12:50 +00:00
SDAlterMnodeReq* pReq = (SDAlterMnodeReq*)rpcMallocCont(contLen);
2022-01-07 04:07:23 +00:00
pReq->dnodeId = htonl(2);
2022-01-07 11:12:50 +00:00
pReq->replica = 1;
pReq->replicas[0].id = htonl(1);
pReq->replicas[0].port = htonl(9113);
strcpy(pReq->replicas[0].fqdn, "localhost");
2022-01-07 04:07:23 +00:00
2022-01-07 11:12:50 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_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, TSDB_CODE_DND_MNODE_INVALID_OPTION);
2022-01-07 04:07:23 +00:00
}
{
2022-01-07 11:12:50 +00:00
int32_t contLen = sizeof(SDAlterMnodeReq);
2022-01-07 04:07:23 +00:00
2022-01-07 11:12:50 +00:00
SDAlterMnodeReq* pReq = (SDAlterMnodeReq*)rpcMallocCont(contLen);
2022-01-07 04:07:23 +00:00
pReq->dnodeId = htonl(1);
2022-01-07 11:12:50 +00:00
pReq->replica = 1;
pReq->replicas[0].id = htonl(2);
pReq->replicas[0].port = htonl(9113);
strcpy(pReq->replicas[0].fqdn, "localhost");
2022-01-07 04:07:23 +00:00
2022-01-07 11:12:50 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_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, TSDB_CODE_DND_MNODE_INVALID_OPTION);
2022-01-07 04:07:23 +00:00
}
{
2022-01-07 11:12:50 +00:00
int32_t contLen = sizeof(SDAlterMnodeReq);
2022-01-07 04:07:23 +00:00
2022-01-07 11:12:50 +00:00
SDAlterMnodeReq* pReq = (SDAlterMnodeReq*)rpcMallocCont(contLen);
2022-01-07 04:07:23 +00:00
pReq->dnodeId = htonl(1);
2022-01-07 11:12:50 +00:00
pReq->replica = 1;
pReq->replicas[0].id = htonl(1);
pReq->replicas[0].port = htonl(9113);
strcpy(pReq->replicas[0].fqdn, "localhost");
2022-01-07 04:07:23 +00:00
2022-01-07 11:12:50 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_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) {
{
int32_t contLen = sizeof(SDDropMnodeReq);
SDDropMnodeReq* pReq = (SDDropMnodeReq*)rpcMallocCont(contLen);
pReq->dnodeId = htonl(2);
SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_MNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
2022-01-07 11:12:50 +00:00
ASSERT_EQ(pRsp->code, TSDB_CODE_DND_MNODE_INVALID_OPTION);
2022-01-07 04:07:23 +00:00
}
{
int32_t contLen = sizeof(SDDropMnodeReq);
SDDropMnodeReq* pReq = (SDDropMnodeReq*)rpcMallocCont(contLen);
pReq->dnodeId = htonl(1);
SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_MNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, 0);
}
{
int32_t contLen = sizeof(SDDropMnodeReq);
SDDropMnodeReq* pReq = (SDDropMnodeReq*)rpcMallocCont(contLen);
pReq->dnodeId = htonl(1);
SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_MNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_DND_MNODE_NOT_DEPLOYED);
}
{
2022-01-07 11:12:50 +00:00
int32_t contLen = sizeof(SDAlterMnodeReq);
2022-01-07 04:07:23 +00:00
2022-01-07 11:12:50 +00:00
SDAlterMnodeReq* pReq = (SDAlterMnodeReq*)rpcMallocCont(contLen);
2022-01-07 04:07:23 +00:00
pReq->dnodeId = htonl(1);
2022-01-07 11:12:50 +00:00
pReq->replica = 1;
pReq->replicas[0].id = htonl(1);
pReq->replicas[0].port = htonl(9113);
strcpy(pReq->replicas[0].fqdn, "localhost");
2022-01-07 04:07:23 +00:00
2022-01-07 11:12:50 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_ALTER_MNODE, pReq, contLen);
2022-01-07 04:07:23 +00:00
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_DND_MNODE_NOT_DEPLOYED);
}
2022-01-07 11:12:50 +00:00
2022-01-07 04:07:23 +00:00
{
int32_t contLen = sizeof(SDCreateMnodeReq);
SDCreateMnodeReq* pReq = (SDCreateMnodeReq*)rpcMallocCont(contLen);
pReq->dnodeId = htonl(1);
2022-01-07 11:12:50 +00:00
pReq->replica = 2;
pReq->replicas[0].id = htonl(1);
pReq->replicas[0].port = htonl(9113);
strcpy(pReq->replicas[0].fqdn, "localhost");
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
}