/** * @file dsnode.cpp * @author slguan (slguan@taosdata.com) * @brief DNODE module snode tests * @version 1.0 * @date 2022-01-05 * * @copyright Copyright (c) 2022 * */ #include "sut.h" class DndTestSnode : public ::testing::Test { protected: static void SetUpTestSuite() { test.Init("/tmp/dnode_test_snode", 9113); } static void TearDownTestSuite() { test.Cleanup(); } static Testbase test; public: void SetUp() override {} void TearDown() override {} }; Testbase DndTestSnode::test; TEST_F(DndTestSnode, 01_Create_Snode) { { SDCreateSnodeReq createReq = {0}; createReq.dnodeId = 2; int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &createReq); void* pReq = rpcMallocCont(contLen); tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &createReq); SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_SNODE, pReq, contLen); ASSERT_NE(pRsp, nullptr); ASSERT_EQ(pRsp->code, TSDB_CODE_DND_SNODE_INVALID_OPTION); } { SDCreateSnodeReq createReq = {0}; createReq.dnodeId = 1; int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &createReq); void* pReq = rpcMallocCont(contLen); tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &createReq); SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_SNODE, pReq, contLen); ASSERT_NE(pRsp, nullptr); ASSERT_EQ(pRsp->code, 0); } { SDCreateSnodeReq createReq = {0}; createReq.dnodeId = 1; int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &createReq); void* pReq = rpcMallocCont(contLen); tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &createReq); SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_SNODE, pReq, contLen); ASSERT_NE(pRsp, nullptr); ASSERT_EQ(pRsp->code, TSDB_CODE_DND_SNODE_ALREADY_DEPLOYED); } test.Restart(); { SDCreateSnodeReq createReq = {0}; createReq.dnodeId = 1; int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &createReq); void* pReq = rpcMallocCont(contLen); tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &createReq); SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_SNODE, pReq, contLen); ASSERT_NE(pRsp, nullptr); ASSERT_EQ(pRsp->code, TSDB_CODE_DND_SNODE_ALREADY_DEPLOYED); } } TEST_F(DndTestSnode, 01_Drop_Snode) { { SDDropSnodeReq dropReq = {0}; dropReq.dnodeId = 2; int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &dropReq); void* pReq = rpcMallocCont(contLen); tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &dropReq); SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_SNODE, pReq, contLen); ASSERT_NE(pRsp, nullptr); ASSERT_EQ(pRsp->code, TSDB_CODE_DND_SNODE_INVALID_OPTION); } { SDDropSnodeReq dropReq = {0}; dropReq.dnodeId = 1; int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &dropReq); void* pReq = rpcMallocCont(contLen); tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &dropReq); SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_SNODE, pReq, contLen); ASSERT_NE(pRsp, nullptr); ASSERT_EQ(pRsp->code, 0); } { SDDropSnodeReq dropReq = {0}; dropReq.dnodeId = 1; int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &dropReq); void* pReq = rpcMallocCont(contLen); tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &dropReq); SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_SNODE, pReq, contLen); ASSERT_NE(pRsp, nullptr); ASSERT_EQ(pRsp->code, TSDB_CODE_DND_SNODE_NOT_DEPLOYED); } test.Restart(); { SDDropSnodeReq dropReq = {0}; dropReq.dnodeId = 1; int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &dropReq); void* pReq = rpcMallocCont(contLen); tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &dropReq); SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_SNODE, pReq, contLen); ASSERT_NE(pRsp, nullptr); ASSERT_EQ(pRsp->code, TSDB_CODE_DND_SNODE_NOT_DEPLOYED); } { SDCreateSnodeReq createReq = {0}; createReq.dnodeId = 1; int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &createReq); void* pReq = rpcMallocCont(contLen); tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &createReq); SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_SNODE, pReq, contLen); ASSERT_NE(pRsp, nullptr); ASSERT_EQ(pRsp->code, 0); } }