TDengine/source/dnode/mgmt/test/qnode/dqnode.cpp

162 lines
4.4 KiB
C++
Raw Permalink Normal View History

2022-01-04 12:36:54 +00:00
/**
* @file dqnode.cpp
* @author slguan (slguan@taosdata.com)
* @brief DNODE module qnode tests
* @version 1.0
* @date 2022-01-05
*
* @copyright Copyright (c) 2022
*
*/
#include "sut.h"
class DndTestQnode : public ::testing::Test {
protected:
static void SetUpTestSuite() { test.Init(TD_TMP_DIR_PATH "dqnodeTest", 9111); }
2022-01-04 12:36:54 +00:00
static void TearDownTestSuite() { test.Cleanup(); }
static Testbase test;
public:
void SetUp() override {}
void TearDown() override {}
};
Testbase DndTestQnode::test;
2022-01-04 12:42:03 +00:00
2022-01-05 01:58:02 +00:00
TEST_F(DndTestQnode, 01_Create_Qnode) {
2022-01-04 12:42:03 +00:00
{
2022-02-16 09:33:07 +00:00
SDCreateQnodeReq createReq = {0};
createReq.dnodeId = 2;
2022-01-04 12:42:03 +00:00
2022-10-18 09:34:58 +00:00
int32_t contLen = tSerializeSCreateDropMQSNodeReq(NULL, 0, &createReq);
2022-02-16 09:33:07 +00:00
void* pReq = rpcMallocCont(contLen);
2022-10-18 09:34:58 +00:00
tSerializeSCreateDropMQSNodeReq(pReq, contLen, &createReq);
2022-01-04 12:42:03 +00:00
2022-01-05 12:18:56 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_INVALID_OPTION);
2023-10-26 13:06:08 +00:00
rpcFreeCont(pRsp->pCont);
2022-01-04 12:42:03 +00:00
}
2022-01-04 13:31:49 +00:00
{
2022-02-16 09:33:07 +00:00
SDCreateQnodeReq createReq = {0};
createReq.dnodeId = 1;
2022-01-04 12:42:03 +00:00
2022-10-18 09:34:58 +00:00
int32_t contLen = tSerializeSCreateDropMQSNodeReq(NULL, 0, &createReq);
2022-02-16 09:33:07 +00:00
void* pReq = rpcMallocCont(contLen);
2022-10-18 09:34:58 +00:00
tSerializeSCreateDropMQSNodeReq(pReq, contLen, &createReq);
2022-01-04 12:42:03 +00:00
2022-01-05 12:18:56 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, 0);
2023-10-26 13:06:08 +00:00
rpcFreeCont(pRsp->pCont);
2022-01-04 13:31:49 +00:00
}
2022-01-04 12:42:03 +00:00
2022-01-04 13:31:49 +00:00
{
2022-02-16 09:33:07 +00:00
SDCreateQnodeReq createReq = {0};
createReq.dnodeId = 1;
2022-01-04 12:42:03 +00:00
2022-10-18 09:34:58 +00:00
int32_t contLen = tSerializeSCreateDropMQSNodeReq(NULL, 0, &createReq);
2022-02-16 09:33:07 +00:00
void* pReq = rpcMallocCont(contLen);
2022-10-18 09:34:58 +00:00
tSerializeSCreateDropMQSNodeReq(pReq, contLen, &createReq);
2022-01-04 12:42:03 +00:00
2022-01-05 12:18:56 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_QNODE_ALREADY_DEPLOYED);
2023-10-26 13:06:08 +00:00
rpcFreeCont(pRsp->pCont);
2022-01-04 13:31:49 +00:00
}
2022-01-04 12:42:03 +00:00
2022-01-04 13:31:49 +00:00
test.Restart();
2022-01-04 12:42:03 +00:00
2022-01-04 13:31:49 +00:00
{
2022-02-16 09:33:07 +00:00
SDCreateQnodeReq createReq = {0};
createReq.dnodeId = 1;
2022-01-04 13:31:49 +00:00
2022-10-18 09:34:58 +00:00
int32_t contLen = tSerializeSCreateDropMQSNodeReq(NULL, 0, &createReq);
2022-02-16 09:33:07 +00:00
void* pReq = rpcMallocCont(contLen);
2022-10-18 09:34:58 +00:00
tSerializeSCreateDropMQSNodeReq(pReq, contLen, &createReq);
2022-01-04 13:31:49 +00:00
2022-01-05 12:18:56 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_QNODE_ALREADY_DEPLOYED);
2023-10-26 13:06:08 +00:00
rpcFreeCont(pRsp->pCont);
2022-01-04 13:31:49 +00:00
}
2022-01-05 01:58:02 +00:00
}
2022-01-05 13:17:16 +00:00
TEST_F(DndTestQnode, 02_Drop_Qnode) {
2022-05-12 15:30:01 +00:00
#if 0
2022-01-05 01:58:02 +00:00
{
2022-02-16 09:33:07 +00:00
SDDropQnodeReq dropReq = {0};
dropReq.dnodeId = 2;
2022-01-05 01:58:02 +00:00
2022-10-18 09:34:58 +00:00
int32_t contLen = tSerializeSCreateDropMQSNodeReq(NULL, 0, &dropReq);
2022-02-16 09:33:07 +00:00
void* pReq = rpcMallocCont(contLen);
2022-10-18 09:34:58 +00:00
tSerializeSCreateDropMQSNodeReq(pReq, contLen, &dropReq);
2022-01-05 01:58:02 +00:00
2022-01-05 12:18:56 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_INVALID_OPTION);
2023-10-26 13:06:08 +00:00
rpcFreeCont(pRsp->pCont);
2022-01-05 01:58:02 +00:00
}
2022-05-12 15:30:01 +00:00
#endif
2022-01-05 01:58:02 +00:00
{
2022-02-16 09:33:07 +00:00
SDDropQnodeReq dropReq = {0};
dropReq.dnodeId = 1;
2022-01-05 01:58:02 +00:00
2022-10-18 09:34:58 +00:00
int32_t contLen = tSerializeSCreateDropMQSNodeReq(NULL, 0, &dropReq);
2022-02-16 09:33:07 +00:00
void* pReq = rpcMallocCont(contLen);
2022-10-18 09:34:58 +00:00
tSerializeSCreateDropMQSNodeReq(pReq, contLen, &dropReq);
2022-01-05 01:58:02 +00:00
2022-01-05 12:18:56 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, 0);
2023-10-26 13:06:08 +00:00
rpcFreeCont(pRsp->pCont);
2022-01-05 01:58:02 +00:00
}
{
2022-02-16 09:33:07 +00:00
SDDropQnodeReq dropReq = {0};
dropReq.dnodeId = 1;
2022-01-05 01:58:02 +00:00
2022-10-18 09:34:58 +00:00
int32_t contLen = tSerializeSCreateDropMQSNodeReq(NULL, 0, &dropReq);
2022-02-16 09:33:07 +00:00
void* pReq = rpcMallocCont(contLen);
2022-10-18 09:34:58 +00:00
tSerializeSCreateDropMQSNodeReq(pReq, contLen, &dropReq);
2022-01-05 01:58:02 +00:00
2022-01-05 12:18:56 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_QNODE_NOT_DEPLOYED);
2023-10-26 13:06:08 +00:00
rpcFreeCont(pRsp->pCont);
2022-01-05 01:58:02 +00:00
}
test.Restart();
{
2022-02-16 09:33:07 +00:00
SDDropQnodeReq dropReq = {0};
dropReq.dnodeId = 1;
2022-01-05 01:58:02 +00:00
2022-10-18 09:34:58 +00:00
int32_t contLen = tSerializeSCreateDropMQSNodeReq(NULL, 0, &dropReq);
2022-02-16 09:33:07 +00:00
void* pReq = rpcMallocCont(contLen);
2022-10-18 09:34:58 +00:00
tSerializeSCreateDropMQSNodeReq(pReq, contLen, &dropReq);
2022-01-05 01:58:02 +00:00
2022-01-05 12:18:56 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_DROP_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_QNODE_NOT_DEPLOYED);
2023-10-26 13:06:08 +00:00
rpcFreeCont(pRsp->pCont);
2022-01-05 01:58:02 +00:00
}
{
2022-02-16 09:33:07 +00:00
SDCreateQnodeReq createReq = {0};
createReq.dnodeId = 1;
2022-01-05 01:58:02 +00:00
2022-10-18 09:34:58 +00:00
int32_t contLen = tSerializeSCreateDropMQSNodeReq(NULL, 0, &createReq);
2022-02-16 09:33:07 +00:00
void* pReq = rpcMallocCont(contLen);
2022-10-18 09:34:58 +00:00
tSerializeSCreateDropMQSNodeReq(pReq, contLen, &createReq);
2022-01-05 01:58:02 +00:00
2022-01-05 12:18:56 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_DND_CREATE_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, 0);
2023-10-26 13:06:08 +00:00
rpcFreeCont(pRsp->pCont);
2022-01-05 01:58:02 +00:00
}
2022-01-04 12:42:03 +00:00
}