stb.cpp 25.0 KB
Newer Older
S
Shengliang Guan 已提交
1 2 3
/**
 * @file stb.cpp
 * @author slguan (slguan@taosdata.com)
S
Shengliang Guan 已提交
4 5 6
 * @brief MNODE module stb tests
 * @version 1.0
 * @date 2022-01-12
S
Shengliang Guan 已提交
7
 *
S
Shengliang Guan 已提交
8
 * @copyright Copyright (c) 2022
S
Shengliang Guan 已提交
9 10 11
 *
 */

S
Shengliang Guan 已提交
12
#include "sut.h"
S
Shengliang Guan 已提交
13

S
Shengliang Guan 已提交
14
class MndTestStb : public ::testing::Test {
S
Shengliang Guan 已提交
15
 protected:
S
Shengliang Guan 已提交
16
  static void SetUpTestSuite() { test.Init("/tmp/mnode_test_stb", 9034); }
S
Shengliang Guan 已提交
17
  static void TearDownTestSuite() { test.Cleanup(); }
S
Shengliang Guan 已提交
18

S
Shengliang Guan 已提交
19
  static Testbase test;
S
Shengliang Guan 已提交
20 21 22 23

 public:
  void SetUp() override {}
  void TearDown() override {}
S
Shengliang Guan 已提交
24

S
Shengliang Guan 已提交
25 26 27 28 29 30 31 32 33 34 35
  void* BuildCreateDbReq(const char* dbname, int32_t* pContLen);
  void* BuildDropDbReq(const char* dbname, int32_t* pContLen);
  void* BuildCreateStbReq(const char* stbname, int32_t* pContLen);
  void* BuildAlterStbAddTagReq(const char* stbname, const char* tagname, int32_t* pContLen);
  void* BuildAlterStbDropTagReq(const char* stbname, const char* tagname, int32_t* pContLen);
  void* BuildAlterStbUpdateTagNameReq(const char* stbname, const char* tagname, const char* newtagname,
                                      int32_t* pContLen);
  void* BuildAlterStbUpdateTagBytesReq(const char* stbname, const char* tagname, int32_t bytes, int32_t* pContLen);
  void* BuildAlterStbAddColumnReq(const char* stbname, const char* colname, int32_t* pContLen);
  void* BuildAlterStbDropColumnReq(const char* stbname, const char* colname, int32_t* pContLen);
  void* BuildAlterStbUpdateColumnBytesReq(const char* stbname, const char* colname, int32_t bytes, int32_t* pContLen);
S
Shengliang Guan 已提交
36 37
};

S
Shengliang Guan 已提交
38
Testbase MndTestStb::test;
S
Shengliang Guan 已提交
39

S
Shengliang Guan 已提交
40
void* MndTestStb::BuildCreateDbReq(const char* dbname, int32_t* pContLen) {
S
Shengliang Guan 已提交
41 42 43 44 45
  SCreateDbReq createReq = {0};
  strcpy(createReq.db, dbname);
  createReq.numOfVgroups = 2;
  createReq.cacheBlockSize = 16;
  createReq.totalBlocks = 10;
S
Shengliang Guan 已提交
46
  createReq.daysPerFile = 1000;
S
Shengliang Guan 已提交
47 48 49 50 51 52 53 54 55 56 57
  createReq.daysToKeep0 = 3650;
  createReq.daysToKeep1 = 3650;
  createReq.daysToKeep2 = 3650;
  createReq.minRows = 100;
  createReq.maxRows = 4096;
  createReq.commitTime = 3600;
  createReq.fsyncPeriod = 3000;
  createReq.walLevel = 1;
  createReq.precision = 0;
  createReq.compression = 2;
  createReq.replications = 1;
S
Shengliang Guan 已提交
58
  createReq.strict = 1;
S
Shengliang Guan 已提交
59 60
  createReq.update = 0;
  createReq.cacheLastRow = 0;
S
Shengliang Guan 已提交
61
  createReq.ttl = 1;
S
Shengliang Guan 已提交
62
  createReq.ignoreExist = 1;
S
Shengliang Guan 已提交
63

S
Shengliang Guan 已提交
64 65 66
  int32_t contLen = tSerializeSCreateDbReq(NULL, 0, &createReq);
  void*   pReq = rpcMallocCont(contLen);
  tSerializeSCreateDbReq(pReq, contLen, &createReq);
S
Shengliang Guan 已提交
67 68 69 70 71

  *pContLen = contLen;
  return pReq;
}

S
Shengliang Guan 已提交
72
void* MndTestStb::BuildDropDbReq(const char* dbname, int32_t* pContLen) {
S
Shengliang Guan 已提交
73 74
  SDropDbReq dropdbReq = {0};
  strcpy(dropdbReq.db, dbname);
S
Shengliang Guan 已提交
75

S
Shengliang Guan 已提交
76 77 78
  int32_t contLen = tSerializeSDropDbReq(NULL, 0, &dropdbReq);
  void*   pReq = rpcMallocCont(contLen);
  tSerializeSDropDbReq(pReq, contLen, &dropdbReq);
S
Shengliang Guan 已提交
79 80 81 82 83

  *pContLen = contLen;
  return pReq;
}

S
Shengliang Guan 已提交
84 85 86 87 88 89 90 91
void* MndTestStb::BuildCreateStbReq(const char* stbname, int32_t* pContLen) {
  SMCreateStbReq createReq = {0};
  createReq.numOfColumns = 2;
  createReq.numOfTags = 3;
  createReq.igExists = 0;
  createReq.pColumns = taosArrayInit(createReq.numOfColumns, sizeof(SField));
  createReq.pTags = taosArrayInit(createReq.numOfTags, sizeof(SField));
  strcpy(createReq.name, stbname);
S
Shengliang Guan 已提交
92

S
Shengliang Guan 已提交
93
  {
S
Shengliang Guan 已提交
94 95 96 97 98
    SField field = {0};
    field.bytes = 8;
    field.type = TSDB_DATA_TYPE_TIMESTAMP;
    strcpy(field.name, "ts");
    taosArrayPush(createReq.pColumns, &field);
S
Shengliang Guan 已提交
99 100 101
  }

  {
S
Shengliang Guan 已提交
102 103 104 105 106
    SField field = {0};
    field.bytes = 12;
    field.type = TSDB_DATA_TYPE_BINARY;
    strcpy(field.name, "col1");
    taosArrayPush(createReq.pColumns, &field);
S
Shengliang Guan 已提交
107 108
  }

S
Shengliang Guan 已提交
109
  {
S
Shengliang Guan 已提交
110 111 112 113 114
    SField field = {0};
    field.bytes = 2;
    field.type = TSDB_DATA_TYPE_TINYINT;
    strcpy(field.name, "tag1");
    taosArrayPush(createReq.pTags, &field);
S
Shengliang Guan 已提交
115
  }
S
Shengliang Guan 已提交
116

S
Shengliang Guan 已提交
117
  {
S
Shengliang Guan 已提交
118 119 120 121 122
    SField field = {0};
    field.bytes = 8;
    field.type = TSDB_DATA_TYPE_BIGINT;
    strcpy(field.name, "tag2");
    taosArrayPush(createReq.pTags, &field);
S
Shengliang Guan 已提交
123
  }
S
Shengliang Guan 已提交
124 125

  {
S
Shengliang Guan 已提交
126 127 128 129 130
    SField field = {0};
    field.bytes = 16;
    field.type = TSDB_DATA_TYPE_BINARY;
    strcpy(field.name, "tag3");
    taosArrayPush(createReq.pTags, &field);
S
Shengliang Guan 已提交
131
  }
S
Shengliang Guan 已提交
132

S
Shengliang Guan 已提交
133
  int32_t tlen = tSerializeSMCreateStbReq(NULL, 0, &createReq);
S
Shengliang Guan 已提交
134
  void*   pHead = rpcMallocCont(tlen);
S
Shengliang Guan 已提交
135 136
  tSerializeSMCreateStbReq(pHead, tlen, &createReq);
  tFreeSMCreateStbReq(&createReq);
S
Shengliang Guan 已提交
137 138
  *pContLen = tlen;
  return pHead;
S
Shengliang Guan 已提交
139
}
S
Shengliang Guan 已提交
140

S
Shengliang Guan 已提交
141 142 143 144 145 146
void* MndTestStb::BuildAlterStbAddTagReq(const char* stbname, const char* tagname, int32_t* pContLen) {
  SMAltertbReq req = {0};
  strcpy(req.name, stbname);
  req.numOfFields = 1;
  req.pFields = taosArrayInit(1, sizeof(SField));
  req.alterType = TSDB_ALTER_TABLE_ADD_TAG;
S
Shengliang Guan 已提交
147

S
Shengliang Guan 已提交
148 149 150 151 152 153
  SField field = {0};
  field.bytes = 12;
  field.type = TSDB_DATA_TYPE_BINARY;
  strcpy(field.name, tagname);
  taosArrayPush(req.pFields, &field);

S
Shengliang Guan 已提交
154
  int32_t contLen = tSerializeSMAlterStbReq(NULL, 0, &req);
S
Shengliang Guan 已提交
155
  void*   pHead = rpcMallocCont(contLen);
S
Shengliang Guan 已提交
156
  tSerializeSMAlterStbReq(pHead, contLen, &req);
S
Shengliang Guan 已提交
157 158

  *pContLen = contLen;
S
Shengliang Guan 已提交
159
  return pHead;
S
Shengliang Guan 已提交
160 161
}

S
Shengliang Guan 已提交
162 163 164 165 166 167
void* MndTestStb::BuildAlterStbDropTagReq(const char* stbname, const char* tagname, int32_t* pContLen) {
  SMAltertbReq req = {0};
  strcpy(req.name, stbname);
  req.numOfFields = 1;
  req.pFields = taosArrayInit(1, sizeof(SField));
  req.alterType = TSDB_ALTER_TABLE_DROP_TAG;
S
Shengliang Guan 已提交
168

S
Shengliang Guan 已提交
169 170 171 172 173 174
  SField field = {0};
  field.bytes = 12;
  field.type = TSDB_DATA_TYPE_BINARY;
  strcpy(field.name, tagname);
  taosArrayPush(req.pFields, &field);

S
Shengliang Guan 已提交
175
  int32_t contLen = tSerializeSMAlterStbReq(NULL, 0, &req);
S
Shengliang Guan 已提交
176
  void*   pHead = rpcMallocCont(contLen);
S
Shengliang Guan 已提交
177
  tSerializeSMAlterStbReq(pHead, contLen, &req);
S
Shengliang Guan 已提交
178 179

  *pContLen = contLen;
S
Shengliang Guan 已提交
180
  return pHead;
S
Shengliang Guan 已提交
181 182
}

S
Shengliang Guan 已提交
183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202
void* MndTestStb::BuildAlterStbUpdateTagNameReq(const char* stbname, const char* tagname, const char* newtagname,
                                                int32_t* pContLen) {
  SMAltertbReq req = {0};
  strcpy(req.name, stbname);
  req.numOfFields = 2;
  req.pFields = taosArrayInit(2, sizeof(SField));
  req.alterType = TSDB_ALTER_TABLE_UPDATE_TAG_NAME;

  SField field = {0};
  field.bytes = 12;
  field.type = TSDB_DATA_TYPE_BINARY;
  strcpy(field.name, tagname);
  taosArrayPush(req.pFields, &field);

  SField field2 = {0};
  field2.bytes = 12;
  field2.type = TSDB_DATA_TYPE_BINARY;
  strcpy(field2.name, newtagname);
  taosArrayPush(req.pFields, &field2);

S
Shengliang Guan 已提交
203
  int32_t contLen = tSerializeSMAlterStbReq(NULL, 0, &req);
S
Shengliang Guan 已提交
204
  void*   pHead = rpcMallocCont(contLen);
S
Shengliang Guan 已提交
205
  tSerializeSMAlterStbReq(pHead, contLen, &req);
S
Shengliang Guan 已提交
206 207

  *pContLen = contLen;
S
Shengliang Guan 已提交
208
  return pHead;
S
Shengliang Guan 已提交
209 210
}

S
Shengliang Guan 已提交
211 212 213 214 215 216 217 218 219 220 221 222 223 224
void* MndTestStb::BuildAlterStbUpdateTagBytesReq(const char* stbname, const char* tagname, int32_t bytes,
                                                 int32_t* pContLen) {
  SMAltertbReq req = {0};
  strcpy(req.name, stbname);
  req.numOfFields = 1;
  req.pFields = taosArrayInit(1, sizeof(SField));
  req.alterType = TSDB_ALTER_TABLE_UPDATE_TAG_BYTES;

  SField field = {0};
  field.bytes = bytes;
  field.type = TSDB_DATA_TYPE_BINARY;
  strcpy(field.name, tagname);
  taosArrayPush(req.pFields, &field);

S
Shengliang Guan 已提交
225
  int32_t contLen = tSerializeSMAlterStbReq(NULL, 0, &req);
S
Shengliang Guan 已提交
226
  void*   pHead = rpcMallocCont(contLen);
S
Shengliang Guan 已提交
227
  tSerializeSMAlterStbReq(pHead, contLen, &req);
S
Shengliang Guan 已提交
228 229

  *pContLen = contLen;
S
Shengliang Guan 已提交
230
  return pHead;
S
Shengliang Guan 已提交
231 232
}

S
Shengliang Guan 已提交
233 234 235 236 237 238 239 240 241 242 243 244
void* MndTestStb::BuildAlterStbAddColumnReq(const char* stbname, const char* colname, int32_t* pContLen) {
  SMAltertbReq req = {0};
  strcpy(req.name, stbname);
  req.numOfFields = 1;
  req.pFields = taosArrayInit(1, sizeof(SField));
  req.alterType = TSDB_ALTER_TABLE_ADD_COLUMN;

  SField field = {0};
  field.bytes = 12;
  field.type = TSDB_DATA_TYPE_BINARY;
  strcpy(field.name, colname);
  taosArrayPush(req.pFields, &field);
S
Shengliang Guan 已提交
245

S
Shengliang Guan 已提交
246
  int32_t contLen = tSerializeSMAlterStbReq(NULL, 0, &req);
S
Shengliang Guan 已提交
247
  void*   pHead = rpcMallocCont(contLen);
S
Shengliang Guan 已提交
248
  tSerializeSMAlterStbReq(pHead, contLen, &req);
S
Shengliang Guan 已提交
249 250

  *pContLen = contLen;
S
Shengliang Guan 已提交
251
  return pHead;
S
Shengliang Guan 已提交
252 253
}

S
Shengliang Guan 已提交
254 255 256 257 258 259 260 261 262 263 264 265
void* MndTestStb::BuildAlterStbDropColumnReq(const char* stbname, const char* colname, int32_t* pContLen) {
  SMAltertbReq req = {0};
  strcpy(req.name, stbname);
  req.numOfFields = 1;
  req.pFields = taosArrayInit(1, sizeof(SField));
  req.alterType = TSDB_ALTER_TABLE_DROP_COLUMN;

  SField field = {0};
  field.bytes = 12;
  field.type = TSDB_DATA_TYPE_BINARY;
  strcpy(field.name, colname);
  taosArrayPush(req.pFields, &field);
S
Shengliang Guan 已提交
266

S
Shengliang Guan 已提交
267
  int32_t contLen = tSerializeSMAlterStbReq(NULL, 0, &req);
S
Shengliang Guan 已提交
268
  void*   pHead = rpcMallocCont(contLen);
S
Shengliang Guan 已提交
269
  tSerializeSMAlterStbReq(pHead, contLen, &req);
S
Shengliang Guan 已提交
270 271

  *pContLen = contLen;
S
Shengliang Guan 已提交
272
  return pHead;
S
Shengliang Guan 已提交
273 274
}

S
Shengliang Guan 已提交
275 276 277 278 279 280 281 282 283 284 285 286 287 288
void* MndTestStb::BuildAlterStbUpdateColumnBytesReq(const char* stbname, const char* colname, int32_t bytes,
                                                    int32_t* pContLen) {
  SMAltertbReq req = {0};
  strcpy(req.name, stbname);
  req.numOfFields = 1;
  req.pFields = taosArrayInit(1, sizeof(SField));
  req.alterType = TSDB_ALTER_TABLE_UPDATE_COLUMN_BYTES;

  SField field = {0};
  field.bytes = bytes;
  field.type = TSDB_DATA_TYPE_BINARY;
  strcpy(field.name, colname);
  taosArrayPush(req.pFields, &field);

S
Shengliang Guan 已提交
289
  int32_t contLen = tSerializeSMAlterStbReq(NULL, 0, &req);
S
Shengliang Guan 已提交
290
  void*   pHead = rpcMallocCont(contLen);
S
Shengliang Guan 已提交
291
  tSerializeSMAlterStbReq(pHead, contLen, &req);
S
Shengliang Guan 已提交
292 293

  *pContLen = contLen;
S
Shengliang Guan 已提交
294
  return pHead;
S
Shengliang Guan 已提交
295 296
}

S
Shengliang Guan 已提交
297 298 299 300 301
TEST_F(MndTestStb, 01_Create_Show_Meta_Drop_Restart_Stb) {
  const char* dbname = "1.d1";
  const char* stbname = "1.d1.stb";

  {
S
Shengliang Guan 已提交
302 303 304
    int32_t  contLen = 0;
    void*    pReq = BuildCreateDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_DB, pReq, contLen);
S
Shengliang Guan 已提交
305 306
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
307
    taosMsleep(2000); // Wait for the vnode to become the leader
S
Shengliang Guan 已提交
308 309 310
  }

  {
S
Shengliang Guan 已提交
311 312 313
    int32_t  contLen = 0;
    void*    pReq = BuildCreateStbReq(stbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_STB, pReq, contLen);
S
Shengliang Guan 已提交
314 315 316 317 318
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
  }

  {
S
Shengliang Guan 已提交
319
    test.SendShowReq(TSDB_MGMT_TABLE_STB, "user_stables", dbname);
S
Shengliang Guan 已提交
320 321 322 323 324
    EXPECT_EQ(test.GetShowRows(), 1);
  }

  // ----- meta ------
  {
S
Shengliang Guan 已提交
325 326 327 328 329 330 331
    STableInfoReq infoReq = {0};
    strcpy(infoReq.dbFName, dbname);
    strcpy(infoReq.tbName, "stb");

    int32_t contLen = tSerializeSTableInfoReq(NULL, 0, &infoReq);
    void*   pReq = rpcMallocCont(contLen);
    tSerializeSTableInfoReq(pReq, contLen, &infoReq);
S
Shengliang Guan 已提交
332

D
dapan1121 已提交
333
    SRpcMsg* pMsg = test.SendReq(TDMT_MND_TABLE_META, pReq, contLen);
S
Shengliang Guan 已提交
334 335 336
    ASSERT_NE(pMsg, nullptr);
    ASSERT_EQ(pMsg->code, 0);

S
Shengliang Guan 已提交
337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352
    STableMetaRsp metaRsp = {0};
    tDeserializeSTableMetaRsp(pMsg->pCont, pMsg->contLen, &metaRsp);

    EXPECT_STREQ(metaRsp.dbFName, dbname);
    EXPECT_STREQ(metaRsp.tbName, "stb");
    EXPECT_STREQ(metaRsp.stbName, "stb");
    EXPECT_EQ(metaRsp.numOfColumns, 2);
    EXPECT_EQ(metaRsp.numOfTags, 3);
    EXPECT_EQ(metaRsp.precision, TSDB_TIME_PRECISION_MILLI);
    EXPECT_EQ(metaRsp.tableType, TSDB_SUPER_TABLE);
    EXPECT_EQ(metaRsp.update, 0);
    EXPECT_EQ(metaRsp.sversion, 1);
    EXPECT_EQ(metaRsp.tversion, 0);
    EXPECT_GT(metaRsp.suid, 0);
    EXPECT_GT(metaRsp.tuid, 0);
    EXPECT_EQ(metaRsp.vgId, 0);
S
Shengliang Guan 已提交
353 354

    {
S
Shengliang Guan 已提交
355
      SSchema* pSchema = &metaRsp.pSchemas[0];
S
Shengliang Guan 已提交
356 357 358 359 360 361 362
      EXPECT_EQ(pSchema->type, TSDB_DATA_TYPE_TIMESTAMP);
      EXPECT_EQ(pSchema->colId, 1);
      EXPECT_EQ(pSchema->bytes, 8);
      EXPECT_STREQ(pSchema->name, "ts");
    }

    {
S
Shengliang Guan 已提交
363
      SSchema* pSchema = &metaRsp.pSchemas[1];
S
Shengliang Guan 已提交
364
      EXPECT_EQ(pSchema->type, TSDB_DATA_TYPE_BINARY);
S
Shengliang Guan 已提交
365
      EXPECT_EQ(pSchema->colId, 2);
S
Shengliang Guan 已提交
366
      EXPECT_EQ(pSchema->bytes, 12);
S
Shengliang Guan 已提交
367 368 369 370
      EXPECT_STREQ(pSchema->name, "col1");
    }

    {
S
Shengliang Guan 已提交
371
      SSchema* pSchema = &metaRsp.pSchemas[2];
S
Shengliang Guan 已提交
372 373 374 375 376 377 378
      EXPECT_EQ(pSchema->type, TSDB_DATA_TYPE_TINYINT);
      EXPECT_EQ(pSchema->colId, 3);
      EXPECT_EQ(pSchema->bytes, 2);
      EXPECT_STREQ(pSchema->name, "tag1");
    }

    {
S
Shengliang Guan 已提交
379
      SSchema* pSchema = &metaRsp.pSchemas[3];
S
Shengliang Guan 已提交
380 381 382 383 384 385 386
      EXPECT_EQ(pSchema->type, TSDB_DATA_TYPE_BIGINT);
      EXPECT_EQ(pSchema->colId, 4);
      EXPECT_EQ(pSchema->bytes, 8);
      EXPECT_STREQ(pSchema->name, "tag2");
    }

    {
S
Shengliang Guan 已提交
387
      SSchema* pSchema = &metaRsp.pSchemas[4];
S
Shengliang Guan 已提交
388 389 390 391 392
      EXPECT_EQ(pSchema->type, TSDB_DATA_TYPE_BINARY);
      EXPECT_EQ(pSchema->colId, 5);
      EXPECT_EQ(pSchema->bytes, 16);
      EXPECT_STREQ(pSchema->name, "tag3");
    }
S
Shengliang Guan 已提交
393 394

    tFreeSTableMetaRsp(&metaRsp);
S
Shengliang Guan 已提交
395 396 397 398 399 400
  }

  // restart
  test.Restart();

  {
S
Shengliang Guan 已提交
401
    test.SendShowReq(TSDB_MGMT_TABLE_STB, "user_stables", dbname);
S
Shengliang Guan 已提交
402 403 404 405
    EXPECT_EQ(test.GetShowRows(), 1);
  }

  {
S
Shengliang Guan 已提交
406 407
    SMDropStbReq dropReq = {0};
    strcpy(dropReq.name, stbname);
S
Shengliang Guan 已提交
408

S
Shengliang Guan 已提交
409
    int32_t contLen = tSerializeSMDropStbReq(NULL, 0, &dropReq);
S
Shengliang Guan 已提交
410
    void*   pHead = rpcMallocCont(contLen);
S
Shengliang Guan 已提交
411
    tSerializeSMDropStbReq(pHead, contLen, &dropReq);
S
Shengliang Guan 已提交
412

S
Shengliang Guan 已提交
413
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_STB, pHead, contLen);
S
Shengliang Guan 已提交
414 415 416 417
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
  }

S
Shengliang Guan 已提交
418
  {
S
Shengliang Guan 已提交
419
    test.SendShowReq(TSDB_MGMT_TABLE_STB, "user_stables", dbname);
S
Shengliang Guan 已提交
420 421
    EXPECT_EQ(test.GetShowRows(), 0);
  }
S
Shengliang Guan 已提交
422

S
Shengliang Guan 已提交
423
  {
S
Shengliang Guan 已提交
424 425 426
    int32_t  contLen = 0;
    void*    pReq = BuildDropDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_DB, pReq, contLen);
S
Shengliang Guan 已提交
427 428 429
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
  }
S
Shengliang Guan 已提交
430
}
S
Shengliang Guan 已提交
431

S
Shengliang Guan 已提交
432 433 434
TEST_F(MndTestStb, 02_Alter_Stb_AddTag) {
  const char* dbname = "1.d2";
  const char* stbname = "1.d2.stb";
S
Shengliang Guan 已提交
435
  int32_t     contLen = 0;
S
Shengliang Guan 已提交
436 437

  {
S
Shengliang Guan 已提交
438 439
    void*    pReq = BuildCreateDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_DB, pReq, contLen);
S
Shengliang Guan 已提交
440 441
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
442
    taosMsleep(2000); // Wait for the vnode to become the leader
S
Shengliang Guan 已提交
443
  }
S
Shengliang Guan 已提交
444

S
Shengliang Guan 已提交
445
  {
S
Shengliang Guan 已提交
446 447
    void*    pReq = BuildCreateStbReq(stbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_STB, pReq, contLen);
S
Shengliang Guan 已提交
448 449
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
S
Shengliang Guan 已提交
450 451
  }

S
Shengliang Guan 已提交
452
  {
S
Shengliang Guan 已提交
453 454
    void*    pReq = BuildAlterStbAddTagReq("1.d3.stb", "tag4", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
455 456 457 458
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_INVALID_DB);
  }

  {
S
Shengliang Guan 已提交
459 460
    void*    pReq = BuildAlterStbAddTagReq("1.d2.stb3", "tag4", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
461 462 463 464
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_STB_NOT_EXIST);
  }

  {
S
Shengliang Guan 已提交
465 466
    void*    pReq = BuildAlterStbAddTagReq(stbname, "tag3", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
467 468 469 470
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_TAG_ALREADY_EXIST);
  }

  {
S
Shengliang Guan 已提交
471 472
    void*    pReq = BuildAlterStbAddTagReq(stbname, "col1", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
473 474 475 476
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_COLUMN_ALREADY_EXIST);
  }

  {
S
Shengliang Guan 已提交
477 478
    void*    pReq = BuildAlterStbAddTagReq(stbname, "tag4", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
479 480 481
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);

S
Shengliang Guan 已提交
482
    test.SendShowReq(TSDB_MGMT_TABLE_STB, "user_stables", dbname);
S
Shengliang Guan 已提交
483
  }
S
Shengliang Guan 已提交
484 485

  {
S
Shengliang Guan 已提交
486 487
    void*    pReq = BuildDropDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_DB, pReq, contLen);
S
Shengliang Guan 已提交
488 489 490
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
  }
S
Shengliang Guan 已提交
491
}
S
Shengliang Guan 已提交
492 493 494 495 496 497 498

TEST_F(MndTestStb, 03_Alter_Stb_DropTag) {
  const char* dbname = "1.d3";
  const char* stbname = "1.d3.stb";
  int32_t     contLen = 0;

  {
S
Shengliang Guan 已提交
499 500
    void*    pReq = BuildCreateDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_DB, pReq, contLen);
S
Shengliang Guan 已提交
501
    ASSERT_EQ(pRsp->code, 0);
502
    taosMsleep(2000); // Wait for the vnode to become the leader
S
Shengliang Guan 已提交
503 504 505
  }

  {
S
Shengliang Guan 已提交
506 507
    void*    pReq = BuildCreateStbReq(stbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_STB, pReq, contLen);
S
Shengliang Guan 已提交
508 509 510 511
    ASSERT_EQ(pRsp->code, 0);
  }

  {
S
Shengliang Guan 已提交
512 513
    void*    pReq = BuildAlterStbDropTagReq(stbname, "tag5", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
514 515 516 517
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_TAG_NOT_EXIST);
  }

  {
S
Shengliang Guan 已提交
518 519
    void*    pReq = BuildAlterStbDropTagReq(stbname, "tag3", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
520 521 522
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);

S
Shengliang Guan 已提交
523
    test.SendShowReq(TSDB_MGMT_TABLE_STB, "user_stables", dbname);
S
Shengliang Guan 已提交
524 525
    EXPECT_EQ(test.GetShowRows(), 1);
  }
S
Shengliang Guan 已提交
526 527

  {
S
Shengliang Guan 已提交
528 529
    void*    pReq = BuildDropDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_DB, pReq, contLen);
S
Shengliang Guan 已提交
530 531 532
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
  }
S
Shengliang Guan 已提交
533 534
}

S
Shengliang Guan 已提交
535
TEST_F(MndTestStb, 04_Alter_Stb_AlterTagName) {
S
Shengliang Guan 已提交
536 537 538 539 540
  const char* dbname = "1.d4";
  const char* stbname = "1.d4.stb";
  int32_t     contLen = 0;

  {
S
Shengliang Guan 已提交
541 542
    void*    pReq = BuildCreateDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_DB, pReq, contLen);
S
Shengliang Guan 已提交
543
    ASSERT_EQ(pRsp->code, 0);
544
    taosMsleep(2000); // Wait for the vnode to become the leader
S
Shengliang Guan 已提交
545 546 547
  }

  {
S
Shengliang Guan 已提交
548 549
    void*    pReq = BuildCreateStbReq(stbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_STB, pReq, contLen);
S
Shengliang Guan 已提交
550 551 552 553
    ASSERT_EQ(pRsp->code, 0);
  }

  {
S
Shengliang Guan 已提交
554 555
    void*    pReq = BuildAlterStbUpdateTagNameReq(stbname, "tag5", "tag6", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
556 557 558 559
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_TAG_NOT_EXIST);
  }

  {
S
Shengliang Guan 已提交
560 561
    void*    pReq = BuildAlterStbUpdateTagNameReq(stbname, "col1", "tag6", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
562 563 564 565
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_TAG_NOT_EXIST);
  }

  {
S
Shengliang Guan 已提交
566 567
    void*    pReq = BuildAlterStbUpdateTagNameReq(stbname, "tag3", "col1", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
568 569 570 571
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_COLUMN_ALREADY_EXIST);
  }

  {
S
Shengliang Guan 已提交
572 573
    void*    pReq = BuildAlterStbUpdateTagNameReq(stbname, "tag3", "tag2", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
574 575 576
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_TAG_ALREADY_EXIST);
  }
  {
S
Shengliang Guan 已提交
577 578
    void*    pReq = BuildAlterStbUpdateTagNameReq(stbname, "tag3", "tag2", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
579 580 581 582
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_TAG_ALREADY_EXIST);
  }

  {
S
Shengliang Guan 已提交
583 584
    void*    pReq = BuildAlterStbUpdateTagNameReq(stbname, "tag3", "tag4", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
585 586 587
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);

S
Shengliang Guan 已提交
588
    test.SendShowReq(TSDB_MGMT_TABLE_STB, "user_stables", dbname);
S
Shengliang Guan 已提交
589 590 591
    EXPECT_EQ(test.GetShowRows(), 1);
  }

S
Shengliang Guan 已提交
592
  {
S
Shengliang Guan 已提交
593 594
    void*    pReq = BuildDropDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_DB, pReq, contLen);
S
Shengliang Guan 已提交
595 596 597 598
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
  }
}
S
Shengliang Guan 已提交
599

S
Shengliang Guan 已提交
600
TEST_F(MndTestStb, 05_Alter_Stb_AlterTagBytes) {
S
Shengliang Guan 已提交
601 602 603 604 605
  const char* dbname = "1.d5";
  const char* stbname = "1.d5.stb";
  int32_t     contLen = 0;

  {
S
Shengliang Guan 已提交
606 607
    void*    pReq = BuildCreateDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_DB, pReq, contLen);
S
Shengliang Guan 已提交
608
    ASSERT_EQ(pRsp->code, 0);
609
    taosMsleep(2000); // Wait for the vnode to become the leader
S
Shengliang Guan 已提交
610 611 612
  }

  {
S
Shengliang Guan 已提交
613 614
    void*    pReq = BuildCreateStbReq(stbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_STB, pReq, contLen);
S
Shengliang Guan 已提交
615 616 617 618
    ASSERT_EQ(pRsp->code, 0);
  }

  {
S
Shengliang Guan 已提交
619 620
    void*    pReq = BuildAlterStbUpdateTagBytesReq(stbname, "tag5", 12, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
621 622 623 624
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_TAG_NOT_EXIST);
  }

  {
S
Shengliang Guan 已提交
625 626
    void*    pReq = BuildAlterStbUpdateTagBytesReq(stbname, "tag1", 13, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
627 628 629 630
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_INVALID_STB_OPTION);
  }

  {
S
Shengliang Guan 已提交
631 632
    void*    pReq = BuildAlterStbUpdateTagBytesReq(stbname, "tag3", 8, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
633 634 635 636
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_INVALID_ROW_BYTES);
  }

  {
S
Shengliang Guan 已提交
637 638
    void*    pReq = BuildAlterStbUpdateTagBytesReq(stbname, "tag3", 20, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
639
    ASSERT_EQ(pRsp->code, 0);
S
Shengliang Guan 已提交
640

S
Shengliang Guan 已提交
641
    test.SendShowReq(TSDB_MGMT_TABLE_STB, "user_stables", dbname);
S
Shengliang Guan 已提交
642 643
    EXPECT_EQ(test.GetShowRows(), 1);
  }
S
Shengliang Guan 已提交
644 645

  {
S
Shengliang Guan 已提交
646 647
    void*    pReq = BuildDropDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_DB, pReq, contLen);
S
Shengliang Guan 已提交
648 649 650 651 652 653 654 655 656 657 658
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
  }
}

TEST_F(MndTestStb, 06_Alter_Stb_AddColumn) {
  const char* dbname = "1.d6";
  const char* stbname = "1.d6.stb";
  int32_t     contLen = 0;

  {
S
Shengliang Guan 已提交
659 660
    void*    pReq = BuildCreateDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_DB, pReq, contLen);
S
Shengliang Guan 已提交
661 662
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
663
    taosMsleep(2000); // Wait for the vnode to become the leader
S
Shengliang Guan 已提交
664 665 666
  }

  {
S
Shengliang Guan 已提交
667 668
    void*    pReq = BuildCreateStbReq(stbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_STB, pReq, contLen);
S
Shengliang Guan 已提交
669 670 671 672 673
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
  }

  {
S
Shengliang Guan 已提交
674 675
    void*    pReq = BuildAlterStbAddColumnReq("1.d7.stb", "tag4", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
676 677 678 679
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_INVALID_DB);
  }

  {
S
Shengliang Guan 已提交
680 681
    void*    pReq = BuildAlterStbAddColumnReq("1.d6.stb3", "tag4", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
682 683 684 685
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_STB_NOT_EXIST);
  }

  {
S
Shengliang Guan 已提交
686 687
    void*    pReq = BuildAlterStbAddColumnReq(stbname, "tag3", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
688 689 690 691
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_TAG_ALREADY_EXIST);
  }

  {
S
Shengliang Guan 已提交
692 693
    void*    pReq = BuildAlterStbAddColumnReq(stbname, "col1", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
694 695 696 697
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_COLUMN_ALREADY_EXIST);
  }

  {
S
Shengliang Guan 已提交
698 699
    void*    pReq = BuildAlterStbAddColumnReq(stbname, "col2", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
700 701 702
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);

S
Shengliang Guan 已提交
703
    test.SendShowReq(TSDB_MGMT_TABLE_STB, "user_stables", dbname);
S
Shengliang Guan 已提交
704 705 706 707
    EXPECT_EQ(test.GetShowRows(), 1);
  }

  {
S
Shengliang Guan 已提交
708 709
    void*    pReq = BuildDropDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_DB, pReq, contLen);
S
Shengliang Guan 已提交
710 711 712 713 714 715 716 717 718 719 720
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
  }
}

TEST_F(MndTestStb, 07_Alter_Stb_DropColumn) {
  const char* dbname = "1.d7";
  const char* stbname = "1.d7.stb";
  int32_t     contLen = 0;

  {
S
Shengliang Guan 已提交
721 722
    void*    pReq = BuildCreateDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_DB, pReq, contLen);
S
Shengliang Guan 已提交
723
    ASSERT_EQ(pRsp->code, 0);
724
    taosMsleep(2000); // Wait for the vnode to become the leader
S
Shengliang Guan 已提交
725 726 727
  }

  {
S
Shengliang Guan 已提交
728 729
    void*    pReq = BuildCreateStbReq(stbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_STB, pReq, contLen);
S
Shengliang Guan 已提交
730 731 732 733
    ASSERT_EQ(pRsp->code, 0);
  }

  {
S
Shengliang Guan 已提交
734 735
    void*    pReq = BuildAlterStbDropColumnReq(stbname, "col4", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
736 737 738 739
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_COLUMN_NOT_EXIST);
  }

  {
S
Shengliang Guan 已提交
740 741
    void*    pReq = BuildAlterStbDropColumnReq(stbname, "col1", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
742 743 744 745
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_INVALID_STB_ALTER_OPTION);
  }

  {
S
Shengliang Guan 已提交
746 747
    void*    pReq = BuildAlterStbDropColumnReq(stbname, "ts", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
748 749 750 751
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_INVALID_STB_ALTER_OPTION);
  }

  {
S
Shengliang Guan 已提交
752 753
    void*    pReq = BuildAlterStbAddColumnReq(stbname, "col2", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
754 755 756 757 758
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
  }

  {
S
Shengliang Guan 已提交
759 760
    void*    pReq = BuildAlterStbDropColumnReq(stbname, "col1", &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
761 762 763
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);

S
Shengliang Guan 已提交
764
    test.SendShowReq(TSDB_MGMT_TABLE_STB, "user_stables", dbname);
S
Shengliang Guan 已提交
765 766 767 768
    EXPECT_EQ(test.GetShowRows(), 1);
  }

  {
S
Shengliang Guan 已提交
769 770
    void*    pReq = BuildDropDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_DB, pReq, contLen);
S
Shengliang Guan 已提交
771 772 773 774 775 776 777 778 779 780 781
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
  }
}

TEST_F(MndTestStb, 08_Alter_Stb_AlterTagBytes) {
  const char* dbname = "1.d8";
  const char* stbname = "1.d8.stb";
  int32_t     contLen = 0;

  {
S
Shengliang Guan 已提交
782 783
    void*    pReq = BuildCreateDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_DB, pReq, contLen);
S
Shengliang Guan 已提交
784
    ASSERT_EQ(pRsp->code, 0);
785
    taosMsleep(2000); // Wait for the vnode to become the leader
S
Shengliang Guan 已提交
786 787 788
  }

  {
S
Shengliang Guan 已提交
789 790
    void*    pReq = BuildCreateStbReq(stbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_CREATE_STB, pReq, contLen);
S
Shengliang Guan 已提交
791 792 793 794
    ASSERT_EQ(pRsp->code, 0);
  }

  {
S
Shengliang Guan 已提交
795 796
    void*    pReq = BuildAlterStbUpdateColumnBytesReq(stbname, "col5", 12, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
797 798 799 800
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_COLUMN_NOT_EXIST);
  }

  {
S
Shengliang Guan 已提交
801 802
    void*    pReq = BuildAlterStbUpdateColumnBytesReq(stbname, "ts", 8, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
803 804 805 806
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_INVALID_STB_OPTION);
  }

  {
S
Shengliang Guan 已提交
807 808
    void*    pReq = BuildAlterStbUpdateColumnBytesReq(stbname, "col1", 8, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
809 810 811 812
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_INVALID_ROW_BYTES);
  }

  {
S
Shengliang Guan 已提交
813 814
    void*    pReq = BuildAlterStbUpdateColumnBytesReq(stbname, "col1", TSDB_MAX_BYTES_PER_ROW, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
815 816 817 818
    ASSERT_EQ(pRsp->code, TSDB_CODE_MND_INVALID_ROW_BYTES);
  }

  {
S
Shengliang Guan 已提交
819 820
    void*    pReq = BuildAlterStbUpdateColumnBytesReq(stbname, "col1", 20, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_ALTER_STB, pReq, contLen);
S
Shengliang Guan 已提交
821 822
    ASSERT_EQ(pRsp->code, 0);

S
Shengliang Guan 已提交
823
    test.SendShowReq(TSDB_MGMT_TABLE_STB, "user_stables", dbname);
S
Shengliang Guan 已提交
824 825 826 827
    EXPECT_EQ(test.GetShowRows(), 1);
  }

  {
S
Shengliang Guan 已提交
828 829
    void*    pReq = BuildDropDbReq(dbname, &contLen);
    SRpcMsg* pRsp = test.SendReq(TDMT_MND_DROP_DB, pReq, contLen);
S
Shengliang Guan 已提交
830 831 832 833
    ASSERT_NE(pRsp, nullptr);
    ASSERT_EQ(pRsp->code, 0);
  }
}