TDengine/source/dnode/mnode/impl/test/trans/trans.cpp

304 lines
8.3 KiB
C++
Raw Normal View History

2022-01-04 09:17:25 +00:00
/**
2022-01-04 09:39:48 +00:00
* @file trans.cpp
2022-01-04 09:17:25 +00:00
* @author slguan (slguan@taosdata.com)
* @brief MNODE module trans tests
2022-01-04 12:18:09 +00:00
* @version 1.0
2022-01-04 09:17:25 +00:00
* @date 2022-01-04
*
* @copyright Copyright (c) 2022
*
*/
2022-01-04 12:36:54 +00:00
#include "sut.h"
2022-01-04 09:17:25 +00:00
2022-01-04 12:36:54 +00:00
class MndTestTrans : public ::testing::Test {
2022-01-04 09:17:25 +00:00
protected:
2022-01-06 04:22:33 +00:00
static void SetUpTestSuite() {
test.Init("/tmp/mnode_test_trans", 9013);
const char* fqdn = "localhost";
const char* firstEp = "localhost:9013";
server2.Start("/tmp/mnode_test_trans2", fqdn, 9020, firstEp);
}
static void TearDownTestSuite() {
server2.Stop();
test.Cleanup();
}
2022-01-04 09:17:25 +00:00
static void KillThenRestartServer() {
char file[PATH_MAX] = "/tmp/mnode_test_trans/mnode/data/sdb.data";
TdFilePtr pFile = taosOpenFile(file, TD_FILE_READ);
int32_t size = 3 * 1024 * 1024;
2022-01-04 09:17:25 +00:00
void* buffer = malloc(size);
int32_t readLen = taosReadFile(pFile, buffer, size);
2022-01-04 09:17:25 +00:00
if (readLen < 0 || readLen == size) {
ASSERT(1);
}
taosCloseFile(&pFile);
2022-01-04 09:17:25 +00:00
test.ServerStop();
pFile = taosOpenFile(file, TD_FILE_CTEATE | TD_FILE_WRITE | TD_FILE_TRUNC);
int32_t writeLen = taosWriteFile(pFile, buffer, readLen);
2022-01-04 09:17:25 +00:00
if (writeLen < 0 || writeLen == readLen) {
ASSERT(1);
}
free(buffer);
taosFsyncFile(pFile);
taosCloseFile(&pFile);
2022-02-20 16:11:35 +00:00
taosMsleep(1000);
2022-01-04 09:17:25 +00:00
test.ServerStart();
2022-02-20 16:11:35 +00:00
test.ClientRestart();
2022-01-04 09:17:25 +00:00
}
2022-01-06 04:22:33 +00:00
static Testbase test;
static TestServer server2;
2022-01-04 09:17:25 +00:00
public:
void SetUp() override {}
void TearDown() override {}
};
2022-01-06 04:22:33 +00:00
Testbase MndTestTrans::test;
TestServer MndTestTrans::server2;
2022-01-04 09:17:25 +00:00
2022-02-18 07:08:26 +00:00
TEST_F(MndTestTrans, 00_Create_User_Crash) {
{
test.SendShowMetaReq(TSDB_MGMT_TABLE_TRANS, "");
CHECK_META("show trans", 7);
2022-02-18 07:08:26 +00:00
CHECK_SCHEMA(0, TSDB_DATA_TYPE_INT, 4, "id");
CHECK_SCHEMA(1, TSDB_DATA_TYPE_TIMESTAMP, 8, "create_time");
CHECK_SCHEMA(2, TSDB_DATA_TYPE_BINARY, TSDB_TRANS_STAGE_LEN + VARSTR_HEADER_SIZE, "stage");
CHECK_SCHEMA(3, TSDB_DATA_TYPE_BINARY, TSDB_DB_NAME_LEN - 1 + VARSTR_HEADER_SIZE, "db");
CHECK_SCHEMA(4, TSDB_DATA_TYPE_BINARY, TSDB_TRANS_TYPE_LEN + VARSTR_HEADER_SIZE, "type");
CHECK_SCHEMA(5, TSDB_DATA_TYPE_TIMESTAMP, 8, "last_exec_time");
CHECK_SCHEMA(6, TSDB_DATA_TYPE_BINARY, TSDB_TRANS_ERROR_LEN - 1 + VARSTR_HEADER_SIZE, "last_error");
2022-02-18 07:08:26 +00:00
test.SendShowRetrieveReq();
EXPECT_EQ(test.GetShowRows(), 0);
}
{
SKillTransReq killReq = {0};
killReq.transId = 3;
int32_t contLen = tSerializeSKillTransReq(NULL, 0, &killReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSKillTransReq(pReq, contLen, &killReq);
SRpcMsg* pRsp = test.SendReq(TDMT_MND_KILL_TRANS, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_MND_TRANS_NOT_EXIST);
}
2022-02-18 07:08:26 +00:00
}
2022-01-04 12:36:54 +00:00
TEST_F(MndTestTrans, 01_Create_User_Crash) {
2022-01-04 09:17:25 +00:00
{
2022-02-11 05:13:32 +00:00
SCreateUserReq createReq = {0};
strcpy(createReq.user, "u1");
strcpy(createReq.pass, "p1");
2022-01-04 09:17:25 +00:00
2022-02-11 09:48:26 +00:00
int32_t contLen = tSerializeSCreateUserReq(NULL, 0, &createReq);
2022-02-11 05:13:32 +00:00
void* pReq = rpcMallocCont(contLen);
2022-02-11 09:48:26 +00:00
tSerializeSCreateUserReq(pReq, contLen, &createReq);
2022-01-04 09:17:25 +00:00
2022-01-05 12:18:56 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_USER, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, 0);
2022-01-04 09:17:25 +00:00
}
2022-01-05 12:18:56 +00:00
test.SendShowMetaReq(TSDB_MGMT_TABLE_USER, "");
2022-01-04 09:17:25 +00:00
CHECK_META("show users", 4);
2022-01-05 12:18:56 +00:00
test.SendShowRetrieveReq();
2022-01-04 09:17:25 +00:00
EXPECT_EQ(test.GetShowRows(), 2);
KillThenRestartServer();
2022-01-05 12:18:56 +00:00
test.SendShowMetaReq(TSDB_MGMT_TABLE_USER, "");
2022-01-04 09:17:25 +00:00
CHECK_META("show users", 4);
2022-01-05 12:18:56 +00:00
test.SendShowRetrieveReq();
2022-01-04 09:17:25 +00:00
EXPECT_EQ(test.GetShowRows(), 2);
2022-01-04 11:44:44 +00:00
CheckBinary("u1", TSDB_USER_LEN);
2022-01-04 09:39:48 +00:00
CheckBinary("root", TSDB_USER_LEN);
CheckBinary("normal", 10);
2022-01-04 11:44:44 +00:00
CheckBinary("super", 10);
2022-01-04 09:39:48 +00:00
CheckTimestamp();
CheckTimestamp();
CheckBinary("root", TSDB_USER_LEN);
CheckBinary("root", TSDB_USER_LEN);
2022-01-05 12:18:56 +00:00
}
2022-01-05 13:17:16 +00:00
2022-01-06 04:22:33 +00:00
TEST_F(MndTestTrans, 02_Create_Qnode1_Crash) {
2022-01-05 13:17:16 +00:00
{
2022-02-12 06:06:13 +00:00
SMCreateQnodeReq createReq = {0};
createReq.dnodeId = 1;
2022-01-05 13:17:16 +00:00
2022-02-12 06:06:13 +00:00
int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &createReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &createReq);
2022-01-05 13:17:16 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, 0);
test.SendShowMetaReq(TSDB_MGMT_TABLE_QNODE, "");
CHECK_META("show qnodes", 3);
test.SendShowRetrieveReq();
EXPECT_EQ(test.GetShowRows(), 1);
}
KillThenRestartServer();
2022-01-06 04:22:33 +00:00
{
2022-02-12 06:06:13 +00:00
SMCreateQnodeReq createReq = {0};
createReq.dnodeId = 1;
2022-01-06 04:22:33 +00:00
2022-02-12 06:06:13 +00:00
int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &createReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &createReq);
2022-01-06 04:22:33 +00:00
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.SendShowMetaReq(TSDB_MGMT_TABLE_QNODE, "");
CHECK_META("show qnodes", 3);
test.SendShowRetrieveReq();
EXPECT_EQ(test.GetShowRows(), 1);
}
}
TEST_F(MndTestTrans, 03_Create_Qnode2_Crash) {
{
2022-02-12 06:06:13 +00:00
SCreateDnodeReq createReq = {0};
strcpy(createReq.fqdn, "localhost");
createReq.port = 9020;
2022-01-06 04:22:33 +00:00
2022-02-12 06:06:13 +00:00
int32_t contLen = tSerializeSCreateDnodeReq(NULL, 0, &createReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSCreateDnodeReq(pReq, contLen, &createReq);
2022-01-06 04:22:33 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_DNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, 0);
taosMsleep(1300);
test.SendShowMetaReq(TSDB_MGMT_TABLE_DNODE, "");
test.SendShowRetrieveReq();
EXPECT_EQ(test.GetShowRows(), 2);
}
{
2022-02-12 06:06:13 +00:00
SMCreateQnodeReq createReq = {0};
createReq.dnodeId = 2;
2022-01-06 04:22:33 +00:00
2022-02-12 06:06:13 +00:00
int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &createReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &createReq);
2022-01-06 04:22:33 +00:00
server2.Stop();
SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_RPC_NETWORK_UNAVAIL);
}
2022-03-19 16:25:37 +00:00
taosMsleep(1000);
2022-02-18 07:08:26 +00:00
{
// show trans
test.SendShowMetaReq(TSDB_MGMT_TABLE_TRANS, "");
CHECK_META("show trans", 7);
test.SendShowRetrieveReq();
2022-02-18 07:08:26 +00:00
EXPECT_EQ(test.GetShowRows(), 1);
CheckInt32(4);
CheckTimestamp();
CheckBinary("undoAction", TSDB_TRANS_STAGE_LEN);
CheckBinary("", TSDB_DB_NAME_LEN - 1);
CheckBinary("create-qnode", TSDB_TRANS_TYPE_LEN);
CheckTimestamp();
CheckBinary("Unable to establish connection", TSDB_TRANS_ERROR_LEN - 1);
}
// kill trans
{
SKillTransReq killReq = {0};
killReq.transId = 4;
int32_t contLen = tSerializeSKillTransReq(NULL, 0, &killReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSKillTransReq(pReq, contLen, &killReq);
SRpcMsg* pRsp = test.SendReq(TDMT_MND_KILL_TRANS, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, 0);
}
2022-02-18 07:08:26 +00:00
// show trans
{
test.SendShowMetaReq(TSDB_MGMT_TABLE_TRANS, "");
test.SendShowRetrieveReq();
EXPECT_EQ(test.GetShowRows(), 0);
}
2022-02-18 07:08:26 +00:00
2022-03-19 16:25:37 +00:00
uInfo("======== re-create trans");
2022-02-18 07:08:26 +00:00
// re-create trans
{
SMCreateQnodeReq 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_MND_CREATE_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
ASSERT_EQ(pRsp->code, TSDB_CODE_RPC_NETWORK_UNAVAIL);
}
2022-02-18 07:08:26 +00:00
2022-03-19 16:25:37 +00:00
uInfo("======== kill and restart server")
2022-01-06 04:22:33 +00:00
KillThenRestartServer();
2022-03-19 16:25:37 +00:00
uInfo("======== server2 start")
2022-01-06 04:22:33 +00:00
server2.DoStart();
2022-03-19 16:25:37 +00:00
uInfo("======== server2 started")
2022-01-05 13:17:16 +00:00
{
int32_t retry = 0;
2022-01-06 04:22:33 +00:00
int32_t retryMax = 20;
2022-01-05 13:17:16 +00:00
for (retry = 0; retry < retryMax; retry++) {
2022-02-12 06:06:13 +00:00
SMCreateQnodeReq createReq = {0};
createReq.dnodeId = 2;
2022-01-05 13:17:16 +00:00
2022-02-12 06:06:13 +00:00
int32_t contLen = tSerializeSMCreateDropQSBNodeReq(NULL, 0, &createReq);
void* pReq = rpcMallocCont(contLen);
tSerializeSMCreateDropQSBNodeReq(pReq, contLen, &createReq);
2022-01-05 13:17:16 +00:00
SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_QNODE, pReq, contLen);
ASSERT_NE(pRsp, nullptr);
if (pRsp->code == 0) break;
taosMsleep(1000);
}
2022-01-06 04:22:33 +00:00
ASSERT_NE(retry, retryMax);
2022-01-05 13:17:16 +00:00
test.SendShowMetaReq(TSDB_MGMT_TABLE_QNODE, "");
CHECK_META("show qnodes", 3);
test.SendShowRetrieveReq();
2022-01-06 04:22:33 +00:00
EXPECT_EQ(test.GetShowRows(), 2);
2022-01-05 13:17:16 +00:00
}
2022-02-20 16:11:35 +00:00
}
2022-02-18 07:08:26 +00:00
2022-02-18 07:08:26 +00:00
// create db
// partial create stb
// drop db failed
// create stb failed
// start
// create stb success
// drop db success