295 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			295 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			C++
		
	
	
	
/**
 | 
						|
 * @file qnode.cpp
 | 
						|
 * @author slguan (slguan@taosdata.com)
 | 
						|
 * @brief MNODE module qnode tests
 | 
						|
 * @version 1.0
 | 
						|
 * @date 2022-01-05
 | 
						|
 *
 | 
						|
 * @copyright Copyright (c) 2022
 | 
						|
 *
 | 
						|
 */
 | 
						|
 | 
						|
#include "sut.h"
 | 
						|
 | 
						|
class MndTestQnode : public ::testing::Test {
 | 
						|
 public:
 | 
						|
  void SetUp() override {}
 | 
						|
  void TearDown() override {}
 | 
						|
 | 
						|
 public:
 | 
						|
  static void SetUpTestSuite() {
 | 
						|
    test.Init(TD_TMP_DIR_PATH "mnode_test_qnode1", 9014);
 | 
						|
    const char* fqdn = "localhost";
 | 
						|
    const char* firstEp = "localhost:9014";
 | 
						|
 | 
						|
    // server2.Start(TD_TMP_DIR_PATH "mnode_test_qnode2", fqdn, 9015, firstEp);
 | 
						|
    taosMsleep(300);
 | 
						|
  }
 | 
						|
 | 
						|
  static void TearDownTestSuite() {
 | 
						|
    server2.Stop();
 | 
						|
    test.Cleanup();
 | 
						|
  }
 | 
						|
 | 
						|
  static Testbase   test;
 | 
						|
  static TestServer server2;
 | 
						|
};
 | 
						|
 | 
						|
Testbase   MndTestQnode::test;
 | 
						|
TestServer MndTestQnode::server2;
 | 
						|
 | 
						|
TEST_F(MndTestQnode, 01_Show_Qnode) {
 | 
						|
  test.SendShowReq(TSDB_MGMT_TABLE_QNODE, "qnodes", "");
 | 
						|
  EXPECT_EQ(test.GetShowRows(), 0);
 | 
						|
}
 | 
						|
 | 
						|
TEST_F(MndTestQnode, 02_Create_Qnode) {
 | 
						|
  {
 | 
						|
    SMCreateQnodeReq createReq = {0};
 | 
						|
    createReq.dnodeId = 2;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &createReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &createReq);
 | 
						|
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_QNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_DNODE_NOT_EXIST);
 | 
						|
  }
 | 
						|
 | 
						|
  {
 | 
						|
    SMCreateQnodeReq createReq = {0};
 | 
						|
    createReq.dnodeId = 1;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &createReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &createReq);
 | 
						|
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_QNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, 0);
 | 
						|
 | 
						|
    test.SendShowReq(TSDB_MGMT_TABLE_QNODE, "qnodes", "");
 | 
						|
    EXPECT_EQ(test.GetShowRows(), 1);
 | 
						|
  }
 | 
						|
 | 
						|
  {
 | 
						|
    SMCreateQnodeReq createReq = {0};
 | 
						|
    createReq.dnodeId = 1;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &createReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &createReq);
 | 
						|
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_QNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_QNODE_ALREADY_EXIST);
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
TEST_F(MndTestQnode, 03_Drop_Qnode) {
 | 
						|
  {
 | 
						|
    SCreateDnodeReq createReq = {0};
 | 
						|
    strcpy(createReq.fqdn, "localhost");
 | 
						|
    createReq.port = 9015;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDnodeReq(NULL, 0, &createReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDnodeReq(pReq, contLen, &createReq);
 | 
						|
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_DNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, 0);
 | 
						|
 | 
						|
    taosMsleep(1300);
 | 
						|
    test.SendShowReq(TSDB_MGMT_TABLE_DNODE, "dnodes", "");
 | 
						|
    EXPECT_EQ(test.GetShowRows(), 2);
 | 
						|
  }
 | 
						|
 | 
						|
  {
 | 
						|
    SMCreateQnodeReq createReq = {0};
 | 
						|
    createReq.dnodeId = 2;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &createReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &createReq);
 | 
						|
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_QNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, 0);
 | 
						|
 | 
						|
    test.SendShowReq(TSDB_MGMT_TABLE_QNODE, "qnodes", "");
 | 
						|
    EXPECT_EQ(test.GetShowRows(), 2);
 | 
						|
  }
 | 
						|
 | 
						|
  {
 | 
						|
    SMDropQnodeReq dropReq = {0};
 | 
						|
    dropReq.dnodeId = 2;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &dropReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &dropReq);
 | 
						|
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_QNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, 0);
 | 
						|
 | 
						|
    test.SendShowReq(TSDB_MGMT_TABLE_QNODE, "qnodes", "");
 | 
						|
    EXPECT_EQ(test.GetShowRows(), 1);
 | 
						|
  }
 | 
						|
 | 
						|
  {
 | 
						|
    SMDropQnodeReq dropReq = {0};
 | 
						|
    dropReq.dnodeId = 2;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &dropReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &dropReq);
 | 
						|
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_QNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_QNODE_NOT_EXIST);
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
TEST_F(MndTestQnode, 03_Create_Qnode_Rollback) {
 | 
						|
  {
 | 
						|
    // send message first, then dnode2 crash, result is returned, and rollback is started
 | 
						|
    SMCreateQnodeReq createReq = {0};
 | 
						|
    createReq.dnodeId = 2;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &createReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &createReq);
 | 
						|
 | 
						|
    server2.Stop();
 | 
						|
    taosMsleep(1000);
 | 
						|
    // test.ClientRestart();
 | 
						|
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_QNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, TSDB_CODE_RPC_NETWORK_UNAVAIL);
 | 
						|
  }
 | 
						|
 | 
						|
  {
 | 
						|
    // continue send message, qnode is creating
 | 
						|
    SMCreateQnodeReq createReq = {0};
 | 
						|
    createReq.dnodeId = 2;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &createReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &createReq);
 | 
						|
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_QNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, TSDB_CODE_SDB_OBJ_CREATING);
 | 
						|
  }
 | 
						|
 | 
						|
  {
 | 
						|
    // continue send message, qnode is creating
 | 
						|
    SMDropQnodeReq dropReq = {0};
 | 
						|
    dropReq.dnodeId = 2;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &dropReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &dropReq);
 | 
						|
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_QNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, TSDB_CODE_SDB_OBJ_CREATING);
 | 
						|
  }
 | 
						|
 | 
						|
  {
 | 
						|
    // server start, wait until the rollback finished
 | 
						|
    server2.Start();
 | 
						|
    test.ClientRestart();
 | 
						|
    taosMsleep(1000);
 | 
						|
 | 
						|
    int32_t retry = 0;
 | 
						|
    int32_t retryMax = 20;
 | 
						|
 | 
						|
    for (retry = 0; retry < retryMax; retry++) {
 | 
						|
      SMCreateQnodeReq createReq = {0};
 | 
						|
      createReq.dnodeId = 2;
 | 
						|
 | 
						|
      int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &createReq);
 | 
						|
      void*   pReq = rpcMallocCont(contLen);
 | 
						|
      tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &createReq);
 | 
						|
 | 
						|
      SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_QNODE, pReq, contLen);
 | 
						|
      ASSERT_NE(pRsp, nullptr);
 | 
						|
      if (pRsp->code == 0) break;
 | 
						|
      taosMsleep(1000);
 | 
						|
    }
 | 
						|
 | 
						|
    ASSERT_NE(retry, retryMax);
 | 
						|
  }
 | 
						|
}
 | 
						|
TEST_F(MndTestQnode, 04_Drop_Qnode_Rollback) {
 | 
						|
  {
 | 
						|
    // send message first, then dnode2 crash, result is returned, and rollback is started
 | 
						|
    SMDropQnodeReq dropReq = {0};
 | 
						|
    dropReq.dnodeId = 2;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &dropReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &dropReq);
 | 
						|
 | 
						|
    server2.Stop();
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_QNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, TSDB_CODE_RPC_NETWORK_UNAVAIL);
 | 
						|
  }
 | 
						|
 | 
						|
  {
 | 
						|
    // continue send message, qnode is dropping
 | 
						|
    SMCreateQnodeReq createReq = {0};
 | 
						|
    createReq.dnodeId = 2;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &createReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &createReq);
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_QNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, TSDB_CODE_SDB_OBJ_DROPPING);
 | 
						|
  }
 | 
						|
 | 
						|
  {
 | 
						|
    // continue send message, qnode is dropping
 | 
						|
    SMDropQnodeReq dropReq = {0};
 | 
						|
    dropReq.dnodeId = 2;
 | 
						|
 | 
						|
    int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &dropReq);
 | 
						|
    void*   pReq = rpcMallocCont(contLen);
 | 
						|
    tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &dropReq);
 | 
						|
 | 
						|
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_QNODE, pReq, contLen);
 | 
						|
    ASSERT_NE(pRsp, nullptr);
 | 
						|
    ASSERT_EQ(pRsp->code, TSDB_CODE_SDB_OBJ_DROPPING);
 | 
						|
  }
 | 
						|
 | 
						|
  {
 | 
						|
    // server start, wait until the rollback finished
 | 
						|
    server2.Start();
 | 
						|
    taosMsleep(1000);
 | 
						|
 | 
						|
    int32_t retry = 0;
 | 
						|
    int32_t retryMax = 20;
 | 
						|
 | 
						|
    for (retry = 0; retry < retryMax; retry++) {
 | 
						|
      SMCreateQnodeReq createReq = {0};
 | 
						|
      createReq.dnodeId = 2;
 | 
						|
 | 
						|
      int32_t contLen = tSerializeSCreateDropMQSBNodeReq(NULL, 0, &createReq);
 | 
						|
      void*   pReq = rpcMallocCont(contLen);
 | 
						|
      tSerializeSCreateDropMQSBNodeReq(pReq, contLen, &createReq);
 | 
						|
      SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_QNODE, pReq, contLen);
 | 
						|
      ASSERT_NE(pRsp, nullptr);
 | 
						|
      if (pRsp->code == 0) break;
 | 
						|
      taosMsleep(1000);
 | 
						|
    }
 | 
						|
 | 
						|
    ASSERT_NE(retry, retryMax);
 | 
						|
  }
 | 
						|
}
 |