• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

taosdata / TDengine / #4866

26 Nov 2025 05:46AM UTC coverage: 64.504% (+0.009%) from 64.495%
#4866

push

travis-ci

guanshengliang
Merge branch '3.0' into cover/3.0

768 of 945 new or added lines in 33 files covered. (81.27%)

3056 existing lines in 105 files now uncovered.

158119 of 245129 relevant lines covered (64.5%)

113247450.85 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

78.15
/source/client/src/clientMsgHandler.c
1
/*
2
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
3
 *
4
 * This program is free software: you can use, redistribute, and/or modify
5
 * it under the terms of the GNU Affero General Public License, version 3
6
 * or later ("AGPL"), as published by the Free Software Foundation.
7
 *
8
 * This program is distributed in the hope that it will be useful, but WITHOUT
9
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
10
 * FITNESS FOR A PARTICULAR PURPOSE.
11
 *
12
 * You should have received a copy of the GNU Affero General Public License
13
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
14
 */
15

16
#include "catalog.h"
17
#include "clientInt.h"
18
#include "clientLog.h"
19
#include "clientMonitor.h"
20
#include "cmdnodes.h"
21
#include "command.h"
22
#include "os.h"
23
#include "query.h"
24
#include "systable.h"
25
#include "tdatablock.h"
26
#include "tdef.h"
27
#include "tglobal.h"
28
#include "tname.h"
29
#include "tversion.h"
30

31
extern SClientHbMgr clientHbMgr;
32

33
static void setErrno(SRequestObj* pRequest, int32_t code) {
5,900,656✔
34
  pRequest->code = code;
5,900,656✔
35
  terrno = code;
5,900,656✔
36
}
5,900,656✔
37

38
int32_t genericRspCallback(void* param, SDataBuf* pMsg, int32_t code) {
4,721,306✔
39
  SRequestObj* pRequest = param;
4,721,306✔
40
  setErrno(pRequest, code);
4,721,306✔
41

42
  if (NEED_CLIENT_RM_TBLMETA_REQ(pRequest->type)) {
4,721,306✔
43
    if (removeMeta(pRequest->pTscObj, pRequest->targetTableList, IS_VIEW_REQUEST(pRequest->type)) != 0) {
1,267,221✔
44
      tscError("failed to remove meta data for table");
×
45
    }
46
  }
47

48
  taosMemoryFree(pMsg->pEpSet);
4,721,306✔
49
  taosMemoryFree(pMsg->pData);
4,721,306✔
50
  if (pRequest->body.queryFp != NULL) {
4,721,306✔
51
    doRequestCallback(pRequest, code);
4,721,008✔
52
  } else {
53
    if (tsem_post(&pRequest->body.rspSem) != 0) {
298✔
54
      tscError("failed to post semaphore");
×
55
    }
56
  }
57
  return code;
4,721,306✔
58
}
59

60
int32_t processConnectRsp(void* param, SDataBuf* pMsg, int32_t code) {
3,688,330✔
61
  SRequestObj* pRequest = acquireRequest(*(int64_t*)param);
3,688,330✔
62
  if (NULL == pRequest) {
3,688,645✔
63
    goto EXIT;
×
64
  }
65

66
  if (code != TSDB_CODE_SUCCESS) {
3,688,645✔
67
    goto End;
11,730✔
68
  }
69

70
  STscObj* pTscObj = pRequest->pTscObj;
3,676,915✔
71

72
  if (NULL == pTscObj->pAppInfo) {
3,676,915✔
73
    code = TSDB_CODE_TSC_DISCONNECTED;
×
74
    goto End;
×
75
  }
76

77
  SConnectRsp connectRsp = {0};
3,676,915✔
78
  if (tDeserializeSConnectRsp(pMsg->pData, pMsg->len, &connectRsp) != 0) {
3,676,915✔
79
    code = TSDB_CODE_TSC_INVALID_VERSION;
×
80
    goto End;
×
81
  }
82

83
  if ((code = taosCheckVersionCompatibleFromStr(td_version, connectRsp.sVer, 3)) != 0) {
3,676,915✔
84
    tscError("version not compatible. client version:%s, server version:%s", td_version, connectRsp.sVer);
×
85
    goto End;
×
86
  }
87

88
  int32_t now = taosGetTimestampSec();
3,676,915✔
89
  int32_t delta = abs(now - connectRsp.svrTimestamp);
3,676,001✔
90
  if (delta > timestampDeltaLimit) {
3,676,001✔
UNCOV
91
    code = TSDB_CODE_TIME_UNSYNCED;
×
UNCOV
92
    tscError("time diff:%ds is too big", delta);
×
93
    goto End;
×
94
  }
95

96
  if (connectRsp.epSet.numOfEps == 0) {
3,676,450✔
97
    code = TSDB_CODE_APP_ERROR;
×
98
    goto End;
×
99
  }
100

101
  int    updateEpSet = 1;
3,676,450✔
102
  SEpSet srcEpSet = getEpSet_s(&pTscObj->pAppInfo->mgmtEp);
3,676,450✔
103
  if (connectRsp.dnodeNum == 1) {
3,676,343✔
104
    SEpSet dstEpSet = connectRsp.epSet;
3,536,781✔
105
    if (srcEpSet.numOfEps == 1) {
3,537,038✔
106
      if (rpcSetDefaultAddr(pTscObj->pAppInfo->pTransporter, srcEpSet.eps[srcEpSet.inUse].fqdn,
2,183,039✔
107
                            dstEpSet.eps[dstEpSet.inUse].fqdn) != 0) {
2,183,200✔
108
        tscError("failed to set default addr for rpc");
×
109
      }
110
      updateEpSet = 0;
2,181,932✔
111
    }
112
  }
113
  if (updateEpSet == 1 && !isEpsetEqual(&srcEpSet, &connectRsp.epSet)) {
3,674,667✔
114
    SEpSet corEpSet = getEpSet_s(&pTscObj->pAppInfo->mgmtEp);
1,380,485✔
115

116
    SEpSet* pOrig = &corEpSet;
1,380,502✔
117
    SEp*    pOrigEp = &pOrig->eps[pOrig->inUse];
1,380,502✔
118
    SEp*    pNewEp = &connectRsp.epSet.eps[connectRsp.epSet.inUse];
1,380,502✔
119
    tscDebug("mnode epset updated from %d/%d=>%s:%d to %d/%d=>%s:%d in connRsp", pOrig->inUse, pOrig->numOfEps,
1,380,502✔
120
             pOrigEp->fqdn, pOrigEp->port, connectRsp.epSet.inUse, connectRsp.epSet.numOfEps, pNewEp->fqdn,
121
             pNewEp->port);
122
    updateEpSet_s(&pTscObj->pAppInfo->mgmtEp, &connectRsp.epSet);
1,380,502✔
123
  }
124

125
  for (int32_t i = 0; i < connectRsp.epSet.numOfEps; ++i) {
7,456,402✔
126
    tscDebug("QID:0x%" PRIx64 ", epSet.fqdn[%d]:%s port:%d, conn:0x%" PRIx64, pRequest->requestId, i,
3,783,435✔
127
             connectRsp.epSet.eps[i].fqdn, connectRsp.epSet.eps[i].port, pTscObj->id);
128
  }
129

130
  pTscObj->sysInfo = connectRsp.sysInfo;
3,672,967✔
131
  pTscObj->connId = connectRsp.connId;
3,674,304✔
132
  pTscObj->acctId = connectRsp.acctId;
3,673,748✔
133
  tstrncpy(pTscObj->sVer, connectRsp.sVer, tListLen(pTscObj->sVer));
3,675,697✔
134
  tstrncpy(pTscObj->sDetailVer, connectRsp.sDetailVer, tListLen(pTscObj->sDetailVer));
3,675,012✔
135

136
  // update the appInstInfo
137
  pTscObj->pAppInfo->clusterId = connectRsp.clusterId;
3,674,481✔
138
  pTscObj->pAppInfo->serverCfg.monitorParas = connectRsp.monitorParas;
3,675,012✔
139
  pTscObj->pAppInfo->serverCfg.enableAuditDelete = connectRsp.enableAuditDelete;
3,673,091✔
140
  tscDebug("monitor paras from connect rsp, clusterId:0x%" PRIx64 ", threshold:%d scope:%d",
3,674,645✔
141
           connectRsp.clusterId, connectRsp.monitorParas.tsSlowLogThreshold, connectRsp.monitorParas.tsSlowLogScope);
142
  lastClusterId = connectRsp.clusterId;
3,674,645✔
143

144
  pTscObj->connType = connectRsp.connType;
3,674,645✔
145
  pTscObj->passInfo.ver = connectRsp.passVer;
3,672,107✔
146
  pTscObj->authVer = connectRsp.authVer;
3,672,757✔
147
  pTscObj->whiteListInfo.ver = connectRsp.whiteListVer;
3,673,733✔
148

149
  if (taosHashGet(appInfo.pInstMapByClusterId, &connectRsp.clusterId, LONG_BYTES) == NULL) {
3,671,927✔
150
    if (taosHashPut(appInfo.pInstMapByClusterId, &connectRsp.clusterId, LONG_BYTES, &pTscObj->pAppInfo,
1,740,687✔
151
                    POINTER_BYTES) != 0) {
152
      tscError("failed to put appInfo into appInfo.pInstMapByClusterId");
×
153
    } else {
154
#ifdef USE_MONITOR
155
      MonitorSlowLogData data = {0};
1,740,687✔
156
      data.clusterId = pTscObj->pAppInfo->clusterId;
1,740,687✔
157
      data.type = SLOW_LOG_READ_BEGINNIG;
1,740,687✔
158
      (void)monitorPutData2MonitorQueue(data);  // ignore
1,740,687✔
159
      monitorClientSlowQueryInit(connectRsp.clusterId);
1,740,687✔
160
      monitorClientSQLReqInit(connectRsp.clusterId);
1,740,687✔
161
#endif
162
    }
163
  }
164

165
  (void)taosThreadMutexLock(&clientHbMgr.lock);
3,675,910✔
166
  SAppHbMgr* pAppHbMgr = taosArrayGetP(clientHbMgr.appHbMgrs, pTscObj->appHbMgrIdx);
3,676,915✔
167
  if (pAppHbMgr) {
3,676,915✔
168
    if (hbRegisterConn(pAppHbMgr, pTscObj->id, connectRsp.clusterId, connectRsp.connType) != 0) {
3,676,915✔
169
      tscError("QID:0x%" PRIx64 ", failed to register conn to hbMgr", pRequest->requestId);
×
170
    }
171
  } else {
172
    (void)taosThreadMutexUnlock(&clientHbMgr.lock);
×
173
    code = TSDB_CODE_TSC_DISCONNECTED;
×
174
    goto End;
×
175
  }
176
  (void)taosThreadMutexUnlock(&clientHbMgr.lock);
3,676,915✔
177

178
  tscDebug("QID:0x%" PRIx64 ", clusterId:0x%" PRIx64 ", totalConn:%" PRId64, pRequest->requestId, connectRsp.clusterId,
3,676,915✔
179
           pTscObj->pAppInfo->numOfConns);
180

181
End:
3,552,447✔
182
  if (code != 0) {
3,688,645✔
183
    setErrno(pRequest, code);
11,730✔
184
  }
185
  if (tsem_post(&pRequest->body.rspSem) != 0) {
3,688,645✔
186
    tscError("failed to post semaphore");
×
187
  }
188

189
  if (pRequest) {
3,688,645✔
190
    (void)releaseRequest(pRequest->self);
3,688,645✔
191
  }
192

193
EXIT:
3,194,085✔
194
  taosMemoryFree(param);
3,688,645✔
195
  taosMemoryFree(pMsg->pEpSet);
3,688,645✔
196
  taosMemoryFree(pMsg->pData);
3,688,645✔
197
  return code;
3,688,645✔
198
}
199

200
SMsgSendInfo* buildMsgInfoImpl(SRequestObj* pRequest) {
18,894,386✔
201
  SMsgSendInfo* pMsgSendInfo = taosMemoryCalloc(1, sizeof(SMsgSendInfo));
18,894,386✔
202
  if (pMsgSendInfo == NULL) return pMsgSendInfo;
18,894,583✔
203
  pMsgSendInfo->requestObjRefId = pRequest->self;
18,894,583✔
204
  pMsgSendInfo->requestId = pRequest->requestId;
18,894,583✔
205
  pMsgSendInfo->param = pRequest;
18,894,730✔
206
  pMsgSendInfo->msgType = pRequest->type;
18,894,730✔
207
  pMsgSendInfo->target.type = TARGET_TYPE_MNODE;
18,895,198✔
208

209
  pMsgSendInfo->msgInfo = pRequest->body.requestMsg;
18,895,198✔
210
  pMsgSendInfo->fp = getMsgRspHandle(pRequest->type);
18,894,238✔
211
  return pMsgSendInfo;
18,895,048✔
212
}
213

214
int32_t processCreateDbRsp(void* param, SDataBuf* pMsg, int32_t code) {
1,478,756✔
215
  // todo rsp with the vnode id list
216
  SRequestObj* pRequest = param;
1,478,756✔
217
  taosMemoryFree(pMsg->pData);
1,478,756✔
218
  taosMemoryFree(pMsg->pEpSet);
1,478,756✔
219
  if (code != TSDB_CODE_SUCCESS) {
1,478,756✔
220
    setErrno(pRequest, code);
37,370✔
221
  } else {
222
    struct SCatalog* pCatalog = NULL;
1,441,386✔
223
    code = catalogGetHandle(pRequest->pTscObj->pAppInfo->clusterId, &pCatalog);
1,441,386✔
224
    if (TSDB_CODE_SUCCESS == code) {
1,441,386✔
225
      STscObj* pTscObj = pRequest->pTscObj;
1,441,386✔
226

227
      SRequestConnInfo conn = {.pTrans = pTscObj->pAppInfo->pTransporter,
1,441,386✔
228
                               .requestId = pRequest->requestId,
1,441,386✔
229
                               .requestObjRefId = pRequest->self,
1,441,386✔
230
                               .mgmtEps = getEpSet_s(&pTscObj->pAppInfo->mgmtEp)};
1,441,386✔
231
      char             dbFName[TSDB_DB_FNAME_LEN];
1,312,720✔
232
      (void)snprintf(dbFName, sizeof(dbFName) - 1, "%d.%s", pTscObj->acctId, TSDB_INFORMATION_SCHEMA_DB);
1,441,386✔
233
      if (catalogRefreshDBVgInfo(pCatalog, &conn, dbFName) != 0) {
1,441,386✔
234
        tscError("QID:0x%" PRIx64 ", failed to refresh db vg info", pRequest->requestId);
×
235
      }
236
      (void)snprintf(dbFName, sizeof(dbFName) - 1, "%d.%s", pTscObj->acctId, TSDB_PERFORMANCE_SCHEMA_DB);
1,441,386✔
237
      if (catalogRefreshDBVgInfo(pCatalog, &conn, dbFName) != 0) {
1,441,386✔
238
        tscError("QID:0x%" PRIx64 ", failed to refresh db vg info", pRequest->requestId);
×
239
      }
240
    }
241
  }
242

243
  if (pRequest->body.queryFp) {
1,478,756✔
244
    doRequestCallback(pRequest, code);
1,478,756✔
245
  } else {
246
    if (tsem_post(&pRequest->body.rspSem) != 0) {
×
247
      tscError("failed to post semaphore");
×
248
    }
249
  }
250
  return code;
1,478,756✔
251
}
252

253
int32_t processUseDbRsp(void* param, SDataBuf* pMsg, int32_t code) {
3,019,196✔
254
  SRequestObj* pRequest = param;
3,019,196✔
255
  if (TSDB_CODE_MND_DB_NOT_EXIST == code || TSDB_CODE_MND_DB_IN_CREATING == code ||
3,019,196✔
256
      TSDB_CODE_MND_DB_IN_DROPPING == code) {
257
    SUseDbRsp usedbRsp = {0};
1,875✔
258
    if (tDeserializeSUseDbRsp(pMsg->pData, pMsg->len, &usedbRsp) != 0) {
1,875✔
259
      tscError("QID:0x%" PRIx64 ", deserialize SUseDbRsp failed", pRequest->requestId);
1,875✔
260
    }
261
    struct SCatalog* pCatalog = NULL;
1,875✔
262

263
    if (usedbRsp.vgVersion >= 0) {  // cached in local
1,875✔
264
      int64_t clusterId = pRequest->pTscObj->pAppInfo->clusterId;
1,875✔
265
      int32_t code1 = catalogGetHandle(clusterId, &pCatalog);
1,875✔
266
      if (code1 != TSDB_CODE_SUCCESS) {
1,875✔
267
        tscWarn("QID:0x%" PRIx64 ", catalogGetHandle failed, clusterId:0x%" PRIx64 ", error:%s", pRequest->requestId, clusterId,
×
268
                tstrerror(code1));
269
      } else {
270
        if (catalogRemoveDB(pCatalog, usedbRsp.db, usedbRsp.uid) != 0) {
1,875✔
271
          tscError("QID:0x%" PRIx64 ", catalogRemoveDB failed, db:%s, uid:%" PRId64, pRequest->requestId, usedbRsp.db,
×
272
                   usedbRsp.uid);
273
        }
274
      }
275
    }
276
    tFreeSUsedbRsp(&usedbRsp);
1,875✔
277
  }
278

279
  if (code != TSDB_CODE_SUCCESS) {
3,019,196✔
280
    taosMemoryFree(pMsg->pData);
4,378✔
281
    taosMemoryFree(pMsg->pEpSet);
4,378✔
282
    setErrno(pRequest, code);
4,378✔
283

284
    if (pRequest->body.queryFp != NULL) {
4,378✔
285
      doRequestCallback(pRequest, pRequest->code);
4,378✔
286

287
    } else {
288
      if (tsem_post(&pRequest->body.rspSem) != 0) {
×
289
        tscError("failed to post semaphore");
×
290
      }
291
    }
292

293
    return code;
4,378✔
294
  }
295

296
  SUseDbRsp usedbRsp = {0};
3,014,818✔
297
  if (tDeserializeSUseDbRsp(pMsg->pData, pMsg->len, &usedbRsp) != 0) {
3,014,818✔
298
    tscError("QID:0x%" PRIx64 ", deserialize SUseDbRsp failed", pRequest->requestId);
×
299
  }
300

301
  if (strlen(usedbRsp.db) == 0) {
3,014,723✔
302
    taosMemoryFree(pMsg->pData);
×
303
    taosMemoryFree(pMsg->pEpSet);
×
304

305
    if (usedbRsp.errCode != 0) {
×
306
      return usedbRsp.errCode;
×
307
    } else {
308
      return TSDB_CODE_APP_ERROR;
×
309
    }
310
  }
311

312
  tscTrace("db:%s, usedbRsp received, numOfVgroups:%d", usedbRsp.db, usedbRsp.vgNum);
3,014,723✔
313
  for (int32_t i = 0; i < usedbRsp.vgNum; ++i) {
5,552,792✔
314
    SVgroupInfo* pInfo = taosArrayGet(usedbRsp.pVgroupInfos, i);
2,537,974✔
315
    if (pInfo == NULL) {
2,537,974✔
316
      continue;
×
317
    }
318
    tscTrace("vgId:%d, numOfEps:%d inUse:%d ", pInfo->vgId, pInfo->epSet.numOfEps, pInfo->epSet.inUse);
2,537,974✔
319
    for (int32_t j = 0; j < pInfo->epSet.numOfEps; ++j) {
5,285,722✔
320
      tscTrace("vgId:%d, index:%d epset:%s:%u", pInfo->vgId, j, pInfo->epSet.eps[j].fqdn, pInfo->epSet.eps[j].port);
2,747,748✔
321
    }
322
  }
323

324
  SName name = {0};
3,014,818✔
325
  if (tNameFromString(&name, usedbRsp.db, T_NAME_ACCT | T_NAME_DB) != TSDB_CODE_SUCCESS) {
3,014,818✔
326
    tscError("QID:0x%" PRIx64 ", failed to parse db name:%s", pRequest->requestId, usedbRsp.db);
×
327
  }
328

329
  SUseDbOutput output = {0};
3,014,818✔
330
  code = queryBuildUseDbOutput(&output, &usedbRsp);
3,014,818✔
331
  if (code != 0) {
3,014,255✔
332
    terrno = code;
×
333
    if (output.dbVgroup) taosHashCleanup(output.dbVgroup->vgHash);
×
334

335
    tscError("QID:0x%" PRIx64 ", failed to build use db output since %s", pRequest->requestId, terrstr());
×
336
  } else if (output.dbVgroup && output.dbVgroup->vgHash) {
3,014,255✔
337
    struct SCatalog* pCatalog = NULL;
1,193,583✔
338

339
    int32_t code1 = catalogGetHandle(pRequest->pTscObj->pAppInfo->clusterId, &pCatalog);
1,193,583✔
340
    if (code1 != TSDB_CODE_SUCCESS) {
1,193,583✔
341
      tscWarn("catalogGetHandle failed, clusterId:0x%" PRIx64 ", error:%s", pRequest->pTscObj->pAppInfo->clusterId,
×
342
              tstrerror(code1));
343
    } else {
344
      if (catalogUpdateDBVgInfo(pCatalog, output.db, output.dbId, output.dbVgroup) != 0) {
1,193,583✔
345
        tscError("QID:0x%" PRIx64 ", failed to update db vg info, db:%s, dbId:%" PRId64, pRequest->requestId, output.db,
×
346
                 output.dbId);
347
      }
348
      output.dbVgroup = NULL;
1,193,583✔
349
    }
350
  }
351

352
  taosMemoryFreeClear(output.dbVgroup);
3,014,818✔
353
  tFreeSUsedbRsp(&usedbRsp);
3,014,629✔
354

355
  char db[TSDB_DB_NAME_LEN] = {0};
3,014,256✔
356
  if (tNameGetDbName(&name, db) != TSDB_CODE_SUCCESS) {
3,014,256✔
357
    tscError("QID:0x%" PRIx64 ", failed to get db name since %s", pRequest->requestId, tstrerror(code));
×
358
  }
359

360
  setConnectionDB(pRequest->pTscObj, db);
3,014,818✔
361

362
  taosMemoryFree(pMsg->pData);
3,014,818✔
363
  taosMemoryFree(pMsg->pEpSet);
3,014,561✔
364

365
  if (pRequest->body.queryFp != NULL) {
3,014,582✔
366
    doRequestCallback(pRequest, pRequest->code);
3,014,114✔
367
  } else {
368
    if (tsem_post(&pRequest->body.rspSem) != 0) {
×
369
      tscError("failed to post semaphore");
×
370
    }
371
  }
372
  return 0;
3,014,818✔
373
}
374

375
int32_t processCreateSTableRsp(void* param, SDataBuf* pMsg, int32_t code) {
2,229,374✔
376
  if (pMsg == NULL) {
2,229,374✔
377
    tscError("processCreateSTableRsp: invalid input param, pMsg is NULL");
×
378
    return TSDB_CODE_TSC_INVALID_INPUT;
×
379
  }
380
  if (param == NULL) {
2,229,374✔
381
    taosMemoryFree(pMsg->pEpSet);
×
382
    taosMemoryFree(pMsg->pData);
×
383
    tscError("processCreateSTableRsp: invalid input param, param is NULL");
×
384
    return TSDB_CODE_TSC_INVALID_INPUT;
×
385
  }
386

387
  SRequestObj* pRequest = param;
2,229,374✔
388

389
  if (code != TSDB_CODE_SUCCESS) {
2,229,374✔
390
    setErrno(pRequest, code);
30,773✔
391
  } else {
392
    SMCreateStbRsp createRsp = {0};
2,198,601✔
393
    SDecoder       coder = {0};
2,198,601✔
394
    tDecoderInit(&coder, pMsg->pData, pMsg->len);
2,198,601✔
395
    if (pMsg->len > 0) {
2,198,601✔
396
      code = tDecodeSMCreateStbRsp(&coder, &createRsp);  // pMsg->len == 0
2,183,203✔
397
      if (code != TSDB_CODE_SUCCESS) {
2,182,914✔
398
        setErrno(pRequest, code);
×
399
      }
400
    }
401
    tDecoderClear(&coder);
2,198,312✔
402

403
    pRequest->body.resInfo.execRes.msgType = TDMT_MND_CREATE_STB;
2,198,601✔
404
    pRequest->body.resInfo.execRes.res = createRsp.pMeta;
2,198,601✔
405
  }
406

407
  taosMemoryFree(pMsg->pEpSet);
2,229,374✔
408
  taosMemoryFree(pMsg->pData);
2,229,374✔
409

410
  if (pRequest->body.queryFp != NULL) {
2,229,374✔
411
    SExecResult* pRes = &pRequest->body.resInfo.execRes;
1,839,372✔
412

413
    if (code == TSDB_CODE_SUCCESS) {
1,839,661✔
414
      SCatalog* pCatalog = NULL;
1,836,633✔
415
      int32_t   ret = catalogGetHandle(pRequest->pTscObj->pAppInfo->clusterId, &pCatalog);
1,836,633✔
416
      if (pRes->res != NULL) {
1,836,344✔
417
        ret = handleCreateTbExecRes(pRes->res, pCatalog);
1,828,544✔
418
      }
419

420
      if (ret != TSDB_CODE_SUCCESS) {
1,836,633✔
421
        code = ret;
×
422
      }
423
    }
424

425
    doRequestCallback(pRequest, code);
1,839,661✔
426
  } else {
427
    if (tsem_post(&pRequest->body.rspSem) != 0) {
389,713✔
428
      tscError("failed to post semaphore");
×
429
    }
430
  }
431
  return code;
2,229,374✔
432
}
433

434
int32_t processDropDbRsp(void* param, SDataBuf* pMsg, int32_t code) {
1,311,056✔
435
  SRequestObj* pRequest = param;
1,311,056✔
436
  if (code != TSDB_CODE_SUCCESS) {
1,311,056✔
437
    setErrno(pRequest, code);
11,237✔
438
  } else {
439
    SDropDbRsp dropdbRsp = {0};
1,299,819✔
440
    if (tDeserializeSDropDbRsp(pMsg->pData, pMsg->len, &dropdbRsp) != 0) {
1,299,819✔
441
      tscError("QID:0x%" PRIx64 ", deserialize SDropDbRsp failed", pRequest->requestId);
×
442
    }
443
    struct SCatalog* pCatalog = NULL;
1,299,819✔
444
    code = catalogGetHandle(pRequest->pTscObj->pAppInfo->clusterId, &pCatalog);
1,299,819✔
445
    if (TSDB_CODE_SUCCESS == code) {
1,299,819✔
446
      if (catalogRemoveDB(pCatalog, dropdbRsp.db, dropdbRsp.uid) != 0) {
1,299,819✔
447
        tscError("QID:0x%" PRIx64 ", failed to remove db:%s", pRequest->requestId, dropdbRsp.db);
×
448
      }
449
      STscObj* pTscObj = pRequest->pTscObj;
1,299,819✔
450

451
      SRequestConnInfo conn = {.pTrans = pTscObj->pAppInfo->pTransporter,
1,299,819✔
452
                               .requestId = pRequest->requestId,
1,299,819✔
453
                               .requestObjRefId = pRequest->self,
1,299,819✔
454
                               .mgmtEps = getEpSet_s(&pTscObj->pAppInfo->mgmtEp)};
1,299,819✔
455
      char             dbFName[TSDB_DB_FNAME_LEN] = {0};
1,299,819✔
456
      (void)snprintf(dbFName, sizeof(dbFName) - 1, "%d.%s", pTscObj->acctId, TSDB_INFORMATION_SCHEMA_DB);
1,299,819✔
457
      if (catalogRefreshDBVgInfo(pCatalog, &conn, dbFName) != TSDB_CODE_SUCCESS) {
1,299,819✔
458
        tscError("QID:0x%" PRIx64 ", failed to refresh db vg info, db:%s", pRequest->requestId, dbFName);
×
459
      }
460
      (void)snprintf(dbFName, sizeof(dbFName) - 1, "%d.%s", pTscObj->acctId, TSDB_PERFORMANCE_SCHEMA_DB);
1,299,819✔
461
      if (catalogRefreshDBVgInfo(pCatalog, &conn, dbFName) != 0) {
1,299,819✔
462
        tscError("QID:0x%" PRIx64 ", failed to refresh db vg info, db:%s", pRequest->requestId, dbFName);
×
463
      }
464
    }
465
  }
466

467
  taosMemoryFree(pMsg->pData);
1,311,056✔
468
  taosMemoryFree(pMsg->pEpSet);
1,311,056✔
469

470
  if (pRequest->body.queryFp != NULL) {
1,311,056✔
471
    doRequestCallback(pRequest, code);
1,311,056✔
472
  } else {
473
    if (tsem_post(&pRequest->body.rspSem) != 0) {
×
474
      tscError("failed to post semaphore");
×
475
    }
476
  }
477
  return code;
1,311,056✔
478
}
479

480
int32_t processAlterStbRsp(void* param, SDataBuf* pMsg, int32_t code) {
6,013,592✔
481
  SRequestObj* pRequest = param;
6,013,592✔
482
  if (code != TSDB_CODE_SUCCESS) {
6,013,592✔
483
    setErrno(pRequest, code);
1,066,936✔
484
  } else {
485
    SMAlterStbRsp alterRsp = {0};
4,946,656✔
486
    SDecoder      coder = {0};
4,946,656✔
487
    tDecoderInit(&coder, pMsg->pData, pMsg->len);
4,946,656✔
488
    if (pMsg->len > 0) {
4,946,656✔
489
      code = tDecodeSMAlterStbRsp(&coder, &alterRsp);  // pMsg->len == 0
4,923,965✔
490
      if (code != TSDB_CODE_SUCCESS) {
4,923,965✔
491
        setErrno(pRequest, code);
×
492
      }
493
    }
494
    tDecoderClear(&coder);
4,946,656✔
495

496
    pRequest->body.resInfo.execRes.msgType = TDMT_MND_ALTER_STB;
4,946,656✔
497
    pRequest->body.resInfo.execRes.res = alterRsp.pMeta;
4,946,656✔
498
  }
499

500
  taosMemoryFree(pMsg->pData);
6,013,592✔
501
  taosMemoryFree(pMsg->pEpSet);
6,013,592✔
502

503
  if (pRequest->body.queryFp != NULL) {
6,013,592✔
504
    SExecResult* pRes = &pRequest->body.resInfo.execRes;
6,013,592✔
505

506
    if (code == TSDB_CODE_SUCCESS) {
6,013,592✔
507
      SCatalog* pCatalog = NULL;
4,946,656✔
508
      int32_t   ret = catalogGetHandle(pRequest->pTscObj->pAppInfo->clusterId, &pCatalog);
4,946,656✔
509
      if (pRes->res != NULL) {
4,946,656✔
510
        ret = handleAlterTbExecRes(pRes->res, pCatalog);
4,923,965✔
511
      }
512

513
      if (ret != TSDB_CODE_SUCCESS) {
4,946,656✔
514
        code = ret;
×
515
      }
516
    }
517

518
    doRequestCallback(pRequest, code);
6,013,592✔
519
  } else {
520
    if (tsem_post(&pRequest->body.rspSem) != 0) {
×
521
      tscError("failed to post semaphore");
×
522
    }
523
  }
524
  return code;
6,013,592✔
525
}
526

527
static int32_t buildShowVariablesBlock(SArray* pVars, SSDataBlock** block) {
44,881✔
528
  int32_t      code = 0;
44,881✔
529
  int32_t      line = 0;
44,881✔
530
  SSDataBlock* pBlock = taosMemoryCalloc(1, sizeof(SSDataBlock));
44,881✔
531
  TSDB_CHECK_NULL(pBlock, code, line, END, terrno);
44,881✔
532
  pBlock->info.hasVarCol = true;
44,881✔
533

534
  pBlock->pDataBlock = taosArrayInit(SHOW_VARIABLES_RESULT_COLS, sizeof(SColumnInfoData));
44,881✔
535
  TSDB_CHECK_NULL(pBlock->pDataBlock, code, line, END, terrno);
44,881✔
536
  SColumnInfoData infoData = {0};
44,881✔
537
  infoData.info.type = TSDB_DATA_TYPE_VARCHAR;
44,881✔
538
  infoData.info.bytes = SHOW_VARIABLES_RESULT_FIELD1_LEN;
44,881✔
539
  TSDB_CHECK_NULL(taosArrayPush(pBlock->pDataBlock, &infoData), code, line, END, terrno);
89,762✔
540

541
  infoData.info.type = TSDB_DATA_TYPE_VARCHAR;
44,881✔
542
  infoData.info.bytes = SHOW_VARIABLES_RESULT_FIELD2_LEN;
44,881✔
543
  TSDB_CHECK_NULL(taosArrayPush(pBlock->pDataBlock, &infoData), code, line, END, terrno);
89,762✔
544

545
  infoData.info.type = TSDB_DATA_TYPE_VARCHAR;
44,881✔
546
  infoData.info.bytes = SHOW_VARIABLES_RESULT_FIELD3_LEN;
44,881✔
547
  TSDB_CHECK_NULL(taosArrayPush(pBlock->pDataBlock, &infoData), code, line, END, terrno);
89,762✔
548

549
  infoData.info.type = TSDB_DATA_TYPE_VARCHAR;
44,881✔
550
  infoData.info.bytes = SHOW_VARIABLES_RESULT_FIELD4_LEN;
44,881✔
551
  TSDB_CHECK_NULL(taosArrayPush(pBlock->pDataBlock, &infoData), code, line, END, terrno);
89,762✔
552

553
  infoData.info.type = TSDB_DATA_TYPE_VARCHAR;
44,881✔
554
  infoData.info.bytes = SHOW_VARIABLES_RESULT_FIELD5_LEN;
44,881✔
555
  TSDB_CHECK_NULL(taosArrayPush(pBlock->pDataBlock, &infoData), code, line, END, terrno);
89,762✔
556

557
  int32_t numOfCfg = taosArrayGetSize(pVars);
44,881✔
558
  code = blockDataEnsureCapacity(pBlock, numOfCfg);
44,881✔
559
  TSDB_CHECK_CODE(code, line, END);
44,881✔
560

561
  for (int32_t i = 0, c = 0; i < numOfCfg; ++i, c = 0) {
4,562,335✔
562
    SVariablesInfo* pInfo = taosArrayGet(pVars, i);
4,517,454✔
563
    TSDB_CHECK_NULL(pInfo, code, line, END, terrno);
4,517,454✔
564

565
    char name[TSDB_CONFIG_OPTION_LEN + VARSTR_HEADER_SIZE] = {0};
4,517,454✔
566
    STR_WITH_MAXSIZE_TO_VARSTR(name, pInfo->name, TSDB_CONFIG_OPTION_LEN + VARSTR_HEADER_SIZE);
4,517,454✔
567
    SColumnInfoData* pColInfo = taosArrayGet(pBlock->pDataBlock, c++);
4,517,454✔
568
    TSDB_CHECK_NULL(pColInfo, code, line, END, terrno);
4,517,454✔
569
    code = colDataSetVal(pColInfo, i, name, false);
4,517,454✔
570
    TSDB_CHECK_CODE(code, line, END);
4,517,454✔
571

572
    char value[TSDB_CONFIG_VALUE_LEN + VARSTR_HEADER_SIZE] = {0};
4,517,454✔
573
    STR_WITH_MAXSIZE_TO_VARSTR(value, pInfo->value, TSDB_CONFIG_VALUE_LEN + VARSTR_HEADER_SIZE);
4,517,454✔
574
    pColInfo = taosArrayGet(pBlock->pDataBlock, c++);
4,517,454✔
575
    TSDB_CHECK_NULL(pColInfo, code, line, END, terrno);
4,517,454✔
576
    code = colDataSetVal(pColInfo, i, value, false);
4,517,454✔
577
    TSDB_CHECK_CODE(code, line, END);
4,517,454✔
578

579
    char scope[TSDB_CONFIG_SCOPE_LEN + VARSTR_HEADER_SIZE] = {0};
4,517,454✔
580
    STR_WITH_MAXSIZE_TO_VARSTR(scope, pInfo->scope, TSDB_CONFIG_SCOPE_LEN + VARSTR_HEADER_SIZE);
4,517,454✔
581
    pColInfo = taosArrayGet(pBlock->pDataBlock, c++);
4,517,454✔
582
    TSDB_CHECK_NULL(pColInfo, code, line, END, terrno);
4,517,454✔
583
    code = colDataSetVal(pColInfo, i, scope, false);
4,517,454✔
584
    TSDB_CHECK_CODE(code, line, END);
4,517,454✔
585

586
    char category[TSDB_CONFIG_CATEGORY_LEN + VARSTR_HEADER_SIZE] = {0};
4,517,454✔
587
    STR_WITH_MAXSIZE_TO_VARSTR(category, pInfo->category, TSDB_CONFIG_CATEGORY_LEN + VARSTR_HEADER_SIZE);
4,517,454✔
588
    pColInfo = taosArrayGet(pBlock->pDataBlock, c++);
4,517,454✔
589
    TSDB_CHECK_NULL(pColInfo, code, line, END, terrno);
4,517,454✔
590
    code = colDataSetVal(pColInfo, i, category, false);
4,517,454✔
591
    TSDB_CHECK_CODE(code, line, END);
4,517,454✔
592

593
    char info[TSDB_CONFIG_INFO_LEN + VARSTR_HEADER_SIZE] = {0};
4,517,454✔
594
    STR_WITH_MAXSIZE_TO_VARSTR(info, pInfo->info, TSDB_CONFIG_INFO_LEN + VARSTR_HEADER_SIZE);
4,517,454✔
595
    pColInfo = taosArrayGet(pBlock->pDataBlock, c++);
4,517,454✔
596
    TSDB_CHECK_NULL(pColInfo, code, line, END, terrno);
4,517,454✔
597
    code = colDataSetVal(pColInfo, i, info, false);
4,517,454✔
598
    TSDB_CHECK_CODE(code, line, END);
4,517,454✔
599
  }
600

601
  pBlock->info.rows = numOfCfg;
44,881✔
602

603
  *block = pBlock;
44,881✔
604
  return code;
44,881✔
605

606
END:
×
607
  taosArrayDestroy(pBlock->pDataBlock);
×
608
  taosMemoryFree(pBlock);
×
609
  return code;
×
610
}
611

612
static int32_t buildShowVariablesRsp(SArray* pVars, SRetrieveTableRsp** pRsp) {
44,881✔
613
  SSDataBlock* pBlock = NULL;
44,881✔
614
  int32_t      code = buildShowVariablesBlock(pVars, &pBlock);
44,881✔
615
  if (code) {
44,881✔
616
    return code;
×
617
  }
618

619
  size_t dataEncodeBufSize = blockGetEncodeSize(pBlock);
44,881✔
620
  size_t rspSize = sizeof(SRetrieveTableRsp) + dataEncodeBufSize + PAYLOAD_PREFIX_LEN;
44,881✔
621
  *pRsp = taosMemoryCalloc(1, rspSize);
44,881✔
622
  if (NULL == *pRsp) {
44,881✔
623
    code = terrno;
×
624
    goto _exit;
×
625
  }
626

627
  (*pRsp)->useconds = 0;
44,881✔
628
  (*pRsp)->completed = 1;
44,881✔
629
  (*pRsp)->precision = 0;
44,881✔
630
  (*pRsp)->compressed = 0;
44,881✔
631

632
  (*pRsp)->numOfRows = htobe64((int64_t)pBlock->info.rows);
44,881✔
633
  (*pRsp)->numOfCols = htonl(SHOW_VARIABLES_RESULT_COLS);
44,881✔
634

635
  int32_t len = 0;
44,881✔
636
  if ((*pRsp)->numOfRows > 0) {
44,881✔
637
    len = blockEncode(pBlock, (*pRsp)->data + PAYLOAD_PREFIX_LEN, dataEncodeBufSize, SHOW_VARIABLES_RESULT_COLS);
44,069✔
638
    if (len < 0) {
44,069✔
639
      uError("buildShowVariablesRsp error, len:%d", len);
×
640
      code = terrno;
×
641
      goto _exit;
×
642
    }
643
    SET_PAYLOAD_LEN((*pRsp)->data, len, len);
44,069✔
644

645
    int32_t payloadLen = len + PAYLOAD_PREFIX_LEN;
44,069✔
646
    (*pRsp)->payloadLen = htonl(payloadLen);
44,069✔
647
    (*pRsp)->compLen = htonl(payloadLen);
44,069✔
648

649
    if (payloadLen != rspSize - sizeof(SRetrieveTableRsp)) {
44,069✔
650
      uError("buildShowVariablesRsp error, len:%d != rspSize - sizeof(SRetrieveTableRsp):%" PRIu64, len,
×
651
             (uint64_t)(rspSize - sizeof(SRetrieveTableRsp)));
652
      code = TSDB_CODE_TSC_INVALID_INPUT;
×
653
      goto _exit;
×
654
    }
655
  }
656

657
  blockDataDestroy(pBlock);
44,881✔
658
  pBlock = NULL;
44,881✔
659

660
  return TSDB_CODE_SUCCESS;
44,881✔
661
_exit:
×
662
  if (*pRsp) {
×
663
    taosMemoryFree(*pRsp);
×
664
    *pRsp = NULL;
×
665
  }
666
  if (pBlock) {
×
667
    blockDataDestroy(pBlock);
×
668
    pBlock = NULL;
×
669
  }
670
  return code;
×
671
}
672

673
int32_t processShowVariablesRsp(void* param, SDataBuf* pMsg, int32_t code) {
44,881✔
674
  SRequestObj* pRequest = param;
44,881✔
675
  if (code != TSDB_CODE_SUCCESS) {
44,881✔
676
    setErrno(pRequest, code);
×
677
  } else {
678
    SShowVariablesRsp  rsp = {0};
44,881✔
679
    SRetrieveTableRsp* pRes = NULL;
44,881✔
680
    code = tDeserializeSShowVariablesRsp(pMsg->pData, pMsg->len, &rsp);
44,881✔
681
    if (TSDB_CODE_SUCCESS == code) {
44,881✔
682
      code = buildShowVariablesRsp(rsp.variables, &pRes);
44,881✔
683
    }
684
    if (TSDB_CODE_SUCCESS == code) {
44,881✔
685
      code = setQueryResultFromRsp(&pRequest->body.resInfo, pRes, false, pRequest->stmtBindVersion > 0);
44,881✔
686
    }
687

688
    if (code != 0) {
44,881✔
689
      pRequest->body.resInfo.pRspMsg = NULL;
×
690
      taosMemoryFree(pRes);
×
691
    }
692
    tFreeSShowVariablesRsp(&rsp);
44,881✔
693
  }
694

695
  taosMemoryFree(pMsg->pData);
44,881✔
696
  taosMemoryFree(pMsg->pEpSet);
44,881✔
697

698
  if (pRequest->body.queryFp != NULL) {
44,881✔
699
    doRequestCallback(pRequest, code);
44,881✔
700
  } else {
701
    if (tsem_post(&pRequest->body.rspSem) != 0) {
×
702
      tscError("failed to post semaphore");
×
703
    }
704
  }
705
  return code;
44,881✔
706
}
707

708
static int32_t buildCompactDbBlock(SCompactDbRsp* pRsp, SSDataBlock** block) {
59,881✔
709
  int32_t      code = 0;
59,881✔
710
  int32_t      line = 0;
59,881✔
711
  SSDataBlock* pBlock = taosMemoryCalloc(1, sizeof(SSDataBlock));
59,881✔
712
  TSDB_CHECK_NULL(pBlock, code, line, END, terrno);
59,881✔
713
  pBlock->info.hasVarCol = true;
59,881✔
714

715
  pBlock->pDataBlock = taosArrayInit(COMPACT_DB_RESULT_COLS, sizeof(SColumnInfoData));
59,881✔
716
  TSDB_CHECK_NULL(pBlock->pDataBlock, code, line, END, terrno);
59,881✔
717
  SColumnInfoData infoData = {0};
59,881✔
718
  infoData.info.type = TSDB_DATA_TYPE_VARCHAR;
59,881✔
719
  infoData.info.bytes = COMPACT_DB_RESULT_FIELD1_LEN;
59,881✔
720
  TSDB_CHECK_NULL(taosArrayPush(pBlock->pDataBlock, &infoData), code, line, END, terrno);
119,762✔
721

722
  infoData.info.type = TSDB_DATA_TYPE_INT;
59,881✔
723
  infoData.info.bytes = tDataTypes[TSDB_DATA_TYPE_INT].bytes;
59,881✔
724
  TSDB_CHECK_NULL(taosArrayPush(pBlock->pDataBlock, &infoData), code, line, END, terrno);
119,762✔
725

726
  infoData.info.type = TSDB_DATA_TYPE_VARCHAR;
59,881✔
727
  infoData.info.bytes = COMPACT_DB_RESULT_FIELD3_LEN;
59,881✔
728
  TSDB_CHECK_NULL(taosArrayPush(pBlock->pDataBlock, &infoData), code, line, END, terrno);
119,762✔
729

730
  code = blockDataEnsureCapacity(pBlock, 1);
59,881✔
731
  TSDB_CHECK_CODE(code, line, END);
59,881✔
732

733
  SColumnInfoData* pResultCol = taosArrayGet(pBlock->pDataBlock, 0);
59,881✔
734
  TSDB_CHECK_NULL(pResultCol, code, line, END, terrno);
59,881✔
735
  SColumnInfoData* pIdCol = taosArrayGet(pBlock->pDataBlock, 1);
59,881✔
736
  TSDB_CHECK_NULL(pIdCol, code, line, END, terrno);
59,881✔
737
  SColumnInfoData* pReasonCol = taosArrayGet(pBlock->pDataBlock, 2);
59,881✔
738
  TSDB_CHECK_NULL(pReasonCol, code, line, END, terrno);
59,881✔
739

740
  char result[COMPACT_DB_RESULT_FIELD1_LEN] = {0};
59,881✔
741
  char reason[COMPACT_DB_RESULT_FIELD3_LEN] = {0};
59,881✔
742
  if (pRsp->bAccepted) {
59,881✔
743
    STR_TO_VARSTR(result, "accepted");
59,881✔
744
    code = colDataSetVal(pResultCol, 0, result, false);
59,881✔
745
    TSDB_CHECK_CODE(code, line, END);
59,881✔
746
    code = colDataSetVal(pIdCol, 0, (void*)&pRsp->compactId, false);
59,881✔
747
    TSDB_CHECK_CODE(code, line, END);
59,881✔
748
    STR_TO_VARSTR(reason, "success");
59,881✔
749
    code = colDataSetVal(pReasonCol, 0, reason, false);
59,881✔
750
    TSDB_CHECK_CODE(code, line, END);
59,881✔
751
  } else {
752
    STR_TO_VARSTR(result, "rejected");
×
753
    code = colDataSetVal(pResultCol, 0, result, false);
×
754
    TSDB_CHECK_CODE(code, line, END);
×
755
    colDataSetNULL(pIdCol, 0);
756
    STR_TO_VARSTR(reason, "compaction is ongoing");
×
757
    code = colDataSetVal(pReasonCol, 0, reason, false);
×
758
    TSDB_CHECK_CODE(code, line, END);
×
759
  }
760
  pBlock->info.rows = 1;
59,881✔
761

762
  *block = pBlock;
59,881✔
763

764
  return TSDB_CODE_SUCCESS;
59,881✔
765
END:
×
766
  taosMemoryFree(pBlock);
×
767
  taosArrayDestroy(pBlock->pDataBlock);
×
768
  return code;
×
769
}
770

771
static int32_t buildRetriveTableRspForCompactDb(SCompactDbRsp* pCompactDb, SRetrieveTableRsp** pRsp) {
59,881✔
772
  SSDataBlock* pBlock = NULL;
59,881✔
773
  int32_t      code = buildCompactDbBlock(pCompactDb, &pBlock);
59,881✔
774
  if (code) {
59,881✔
775
    return code;
×
776
  }
777

778
  size_t dataEncodeBufSize = blockGetEncodeSize(pBlock);
59,881✔
779
  size_t rspSize = sizeof(SRetrieveTableRsp) + dataEncodeBufSize + PAYLOAD_PREFIX_LEN;
59,881✔
780
  *pRsp = taosMemoryCalloc(1, rspSize);
59,881✔
781
  if (NULL == *pRsp) {
59,881✔
782
    code = terrno;
×
783
    goto _exit;
×
784
  }
785

786
  (*pRsp)->useconds = 0;
59,881✔
787
  (*pRsp)->completed = 1;
59,881✔
788
  (*pRsp)->precision = 0;
59,881✔
789
  (*pRsp)->compressed = 0;
59,881✔
790
  (*pRsp)->compLen = 0;
59,881✔
791
  (*pRsp)->payloadLen = 0;
59,881✔
792
  (*pRsp)->numOfRows = htobe64((int64_t)pBlock->info.rows);
59,881✔
793
  (*pRsp)->numOfCols = htonl(COMPACT_DB_RESULT_COLS);
59,881✔
794

795
  int32_t len = blockEncode(pBlock, (*pRsp)->data + PAYLOAD_PREFIX_LEN, dataEncodeBufSize, COMPACT_DB_RESULT_COLS);
59,881✔
796
  if (len < 0) {
59,881✔
797
    uError("buildRetriveTableRspForCompactDb error, len:%d", len);
×
798
    code = terrno;
×
799
    goto _exit;
×
800
  }
801
  blockDataDestroy(pBlock);
59,881✔
802

803
  SET_PAYLOAD_LEN((*pRsp)->data, len, len);
59,881✔
804

805
  int32_t payloadLen = len + PAYLOAD_PREFIX_LEN;
59,881✔
806
  (*pRsp)->payloadLen = htonl(payloadLen);
59,881✔
807
  (*pRsp)->compLen = htonl(payloadLen);
59,881✔
808

809
  if (payloadLen != rspSize - sizeof(SRetrieveTableRsp)) {
59,881✔
810
    uError("buildRetriveTableRspForCompactDb error, len:%d != rspSize - sizeof(SRetrieveTableRsp):%" PRIu64, len,
×
811
           (uint64_t)(rspSize - sizeof(SRetrieveTableRsp)));
812
    code = TSDB_CODE_TSC_INVALID_INPUT;
×
813
    goto _exit;
×
814
  }
815

816
  return TSDB_CODE_SUCCESS;
59,881✔
817
_exit:
×
818
  if (*pRsp) {
×
819
    taosMemoryFree(*pRsp);
×
820
    *pRsp = NULL;
×
821
  }
822
  if (pBlock) {
×
823
    blockDataDestroy(pBlock);
×
824
    pBlock = NULL;
×
825
  }
826
  return code;
×
827
}
828

829
int32_t processCompactDbRsp(void* param, SDataBuf* pMsg, int32_t code) {
33,567✔
830
  SRequestObj* pRequest = param;
33,567✔
831
  if (code != TSDB_CODE_SUCCESS) {
33,567✔
832
    setErrno(pRequest, code);
2,650✔
833
  } else {
834
    SCompactDbRsp      rsp = {0};
30,917✔
835
    SRetrieveTableRsp* pRes = NULL;
30,917✔
836
    code = tDeserializeSCompactDbRsp(pMsg->pData, pMsg->len, &rsp);
30,917✔
837
    if (TSDB_CODE_SUCCESS == code) {
30,917✔
838
      code = buildRetriveTableRspForCompactDb(&rsp, &pRes);
30,917✔
839
    }
840
    if (TSDB_CODE_SUCCESS == code) {
30,917✔
841
      code = setQueryResultFromRsp(&pRequest->body.resInfo, pRes, false, pRequest->stmtBindVersion > 0);
30,917✔
842
    }
843

844
    if (code != 0) {
30,917✔
845
      pRequest->body.resInfo.pRspMsg = NULL;
×
846
      taosMemoryFree(pRes);
×
847
    }
848
  }
849

850
  taosMemoryFree(pMsg->pData);
33,567✔
851
  taosMemoryFree(pMsg->pEpSet);
33,567✔
852

853
  if (pRequest->body.queryFp != NULL) {
33,567✔
854
    pRequest->body.queryFp(((SSyncQueryParam*)pRequest->body.interParam)->userParam, pRequest, code);
33,567✔
855
  } else {
856
    if (tsem_post(&pRequest->body.rspSem) != 0) {
×
857
      tscError("failed to post semaphore");
×
858
    }
859
  }
860
  return code;
33,567✔
861
}
862

863
static int32_t buildScanDbBlock(SScanDbRsp* pRsp, SSDataBlock** block) {
508✔
864
  int32_t      code = 0;
508✔
865
  int32_t      line = 0;
508✔
866
  SSDataBlock* pBlock = taosMemoryCalloc(1, sizeof(SSDataBlock));
508✔
867
  TSDB_CHECK_NULL(pBlock, code, line, END, terrno);
508✔
868
  pBlock->info.hasVarCol = true;
508✔
869

870
  pBlock->pDataBlock = taosArrayInit(SCAN_DB_RESULT_COLS, sizeof(SColumnInfoData));
508✔
871
  TSDB_CHECK_NULL(pBlock->pDataBlock, code, line, END, terrno);
508✔
872
  SColumnInfoData infoData = {0};
508✔
873
  infoData.info.type = TSDB_DATA_TYPE_VARCHAR;
508✔
874
  infoData.info.bytes = SCAN_DB_RESULT_FIELD1_LEN;
508✔
875
  TSDB_CHECK_NULL(taosArrayPush(pBlock->pDataBlock, &infoData), code, line, END, terrno);
1,016✔
876

877
  infoData.info.type = TSDB_DATA_TYPE_INT;
508✔
878
  infoData.info.bytes = tDataTypes[TSDB_DATA_TYPE_INT].bytes;
508✔
879
  TSDB_CHECK_NULL(taosArrayPush(pBlock->pDataBlock, &infoData), code, line, END, terrno);
1,016✔
880

881
  infoData.info.type = TSDB_DATA_TYPE_VARCHAR;
508✔
882
  infoData.info.bytes = SCAN_DB_RESULT_FIELD3_LEN;
508✔
883
  TSDB_CHECK_NULL(taosArrayPush(pBlock->pDataBlock, &infoData), code, line, END, terrno);
1,016✔
884

885
  code = blockDataEnsureCapacity(pBlock, 1);
508✔
886
  TSDB_CHECK_CODE(code, line, END);
508✔
887

888
  SColumnInfoData* pResultCol = taosArrayGet(pBlock->pDataBlock, 0);
508✔
889
  TSDB_CHECK_NULL(pResultCol, code, line, END, terrno);
508✔
890
  SColumnInfoData* pIdCol = taosArrayGet(pBlock->pDataBlock, 1);
508✔
891
  TSDB_CHECK_NULL(pIdCol, code, line, END, terrno);
508✔
892
  SColumnInfoData* pReasonCol = taosArrayGet(pBlock->pDataBlock, 2);
508✔
893
  TSDB_CHECK_NULL(pReasonCol, code, line, END, terrno);
508✔
894

895
  char result[SCAN_DB_RESULT_FIELD1_LEN] = {0};
508✔
896
  char reason[SCAN_DB_RESULT_FIELD3_LEN] = {0};
508✔
897
  if (pRsp->bAccepted) {
508✔
898
    STR_TO_VARSTR(result, "accepted");
508✔
899
    code = colDataSetVal(pResultCol, 0, result, false);
508✔
900
    TSDB_CHECK_CODE(code, line, END);
508✔
901
    code = colDataSetVal(pIdCol, 0, (void*)&pRsp->scanId, false);
508✔
902
    TSDB_CHECK_CODE(code, line, END);
508✔
903
    STR_TO_VARSTR(reason, "success");
508✔
904
    code = colDataSetVal(pReasonCol, 0, reason, false);
508✔
905
    TSDB_CHECK_CODE(code, line, END);
508✔
906
  } else {
907
    STR_TO_VARSTR(result, "rejected");
×
908
    code = colDataSetVal(pResultCol, 0, result, false);
×
909
    TSDB_CHECK_CODE(code, line, END);
×
910
    colDataSetNULL(pIdCol, 0);
911
    STR_TO_VARSTR(reason, "scan is ongoing");
×
912
    code = colDataSetVal(pReasonCol, 0, reason, false);
×
913
    TSDB_CHECK_CODE(code, line, END);
×
914
  }
915
  pBlock->info.rows = 1;
508✔
916

917
  *block = pBlock;
508✔
918

919
  return TSDB_CODE_SUCCESS;
508✔
920
END:
×
921
  taosMemoryFree(pBlock);
×
922
  taosArrayDestroy(pBlock->pDataBlock);
×
923
  return code;
×
924
}
925

926
static int32_t buildRetriveTableRspForScanDb(SScanDbRsp* pScanDb, SRetrieveTableRsp** pRsp) {
508✔
927
  SSDataBlock* pBlock = NULL;
508✔
928
  int32_t      code = buildScanDbBlock(pScanDb, &pBlock);
508✔
929
  if (code) {
508✔
930
    return code;
×
931
  }
932

933
  size_t dataEncodeBufSize = blockGetEncodeSize(pBlock);
508✔
934
  size_t rspSize = sizeof(SRetrieveTableRsp) + dataEncodeBufSize + PAYLOAD_PREFIX_LEN;
508✔
935
  *pRsp = taosMemoryCalloc(1, rspSize);
508✔
936
  if (NULL == *pRsp) {
508✔
937
    code = terrno;
×
938
    goto _exit;
×
939
  }
940

941
  (*pRsp)->useconds = 0;
508✔
942
  (*pRsp)->completed = 1;
508✔
943
  (*pRsp)->precision = 0;
508✔
944
  (*pRsp)->compressed = 0;
508✔
945
  (*pRsp)->compLen = 0;
508✔
946
  (*pRsp)->payloadLen = 0;
508✔
947
  (*pRsp)->numOfRows = htobe64((int64_t)pBlock->info.rows);
508✔
948
  (*pRsp)->numOfCols = htonl(SCAN_DB_RESULT_COLS);
508✔
949

950
  int32_t len = blockEncode(pBlock, (*pRsp)->data + PAYLOAD_PREFIX_LEN, dataEncodeBufSize, SCAN_DB_RESULT_COLS);
508✔
951
  if (len < 0) {
508✔
952
    uError("%s error, len:%d", __func__, len);
×
953
    code = terrno;
×
954
    goto _exit;
×
955
  }
956
  blockDataDestroy(pBlock);
508✔
957

958
  SET_PAYLOAD_LEN((*pRsp)->data, len, len);
508✔
959

960
  int32_t payloadLen = len + PAYLOAD_PREFIX_LEN;
508✔
961
  (*pRsp)->payloadLen = htonl(payloadLen);
508✔
962
  (*pRsp)->compLen = htonl(payloadLen);
508✔
963

964
  if (payloadLen != rspSize - sizeof(SRetrieveTableRsp)) {
508✔
965
    uError("%s error, len:%d != rspSize - sizeof(SRetrieveTableRsp):%" PRIu64, __func__, len,
×
966
           (uint64_t)(rspSize - sizeof(SRetrieveTableRsp)));
967
    code = TSDB_CODE_TSC_INVALID_INPUT;
×
968
    goto _exit;
×
969
  }
970

971
  return TSDB_CODE_SUCCESS;
508✔
972
_exit:
×
973
  if (*pRsp) {
×
974
    taosMemoryFree(*pRsp);
×
975
    *pRsp = NULL;
×
976
  }
977
  if (pBlock) {
×
978
    blockDataDestroy(pBlock);
×
979
    pBlock = NULL;
×
980
  }
981
  return code;
×
982
}
983

984
static int32_t processScanDbRsp(void* param, SDataBuf* pMsg, int32_t code) {
762✔
985
  SRequestObj* pRequest = param;
762✔
986
  if (code != TSDB_CODE_SUCCESS) {
762✔
987
    setErrno(pRequest, code);
254✔
988
  } else {
989
    SScanDbRsp         rsp = {0};
508✔
990
    SRetrieveTableRsp* pRes = NULL;
508✔
991
    code = tDeserializeSScanDbRsp(pMsg->pData, pMsg->len, &rsp);
508✔
992
    if (TSDB_CODE_SUCCESS == code) {
508✔
993
      code = buildRetriveTableRspForScanDb(&rsp, &pRes);
508✔
994
    }
995
    if (TSDB_CODE_SUCCESS == code) {
508✔
996
      code = setQueryResultFromRsp(&pRequest->body.resInfo, pRes, false, pRequest->stmtBindVersion > 0);
508✔
997
    }
998

999
    if (code != 0) {
508✔
1000
      pRequest->body.resInfo.pRspMsg = NULL;
×
1001
      taosMemoryFree(pRes);
×
1002
    }
1003
  }
1004

1005
  taosMemoryFree(pMsg->pData);
762✔
1006
  taosMemoryFree(pMsg->pEpSet);
762✔
1007

1008
  if (pRequest->body.queryFp != NULL) {
762✔
1009
    pRequest->body.queryFp(((SSyncQueryParam*)pRequest->body.interParam)->userParam, pRequest, code);
762✔
1010
  } else {
1011
    if (tsem_post(&pRequest->body.rspSem) != 0) {
×
1012
      tscError("failed to post semaphore");
×
1013
    }
1014
  }
1015
  return code;
762✔
1016
}
1017

1018
int32_t processTrimDbRsp(void* param, SDataBuf* pMsg, int32_t code) {
42,986✔
1019
  SRequestObj* pRequest = param;
42,986✔
1020
  if (code != TSDB_CODE_SUCCESS) {
42,986✔
1021
    setErrno(pRequest, code);
14,022✔
1022
  } else {
1023
    STrimDbRsp         rsp = {0};
28,964✔
1024
    SRetrieveTableRsp* pRes = NULL;
28,964✔
1025
    code = tDeserializeSCompactDbRsp(pMsg->pData, pMsg->len, (SCompactDbRsp*)&rsp);
28,964✔
1026
    if (TSDB_CODE_SUCCESS == code) {
28,964✔
1027
      code = buildRetriveTableRspForCompactDb(&rsp, &pRes);
28,964✔
1028
    }
1029
    if (TSDB_CODE_SUCCESS == code) {
28,964✔
1030
      code = setQueryResultFromRsp(&pRequest->body.resInfo, pRes, false, pRequest->stmtBindVersion > 0);
28,964✔
1031
    }
1032

1033
    if (code != 0) {
28,964✔
1034
      pRequest->body.resInfo.pRspMsg = NULL;
×
1035
      taosMemoryFree(pRes);
×
1036
    }
1037
  }
1038

1039
  taosMemoryFree(pMsg->pData);
42,986✔
1040
  taosMemoryFree(pMsg->pEpSet);
42,986✔
1041

1042
  if (pRequest->body.queryFp != NULL) {
42,986✔
1043
    pRequest->body.queryFp(((SSyncQueryParam*)pRequest->body.interParam)->userParam, pRequest, code);
42,986✔
1044
  } else {
1045
    if (tsem_post(&pRequest->body.rspSem) != 0) {
×
1046
      tscError("failed to post semaphore");
×
1047
    }
1048
  }
1049
  return code;
42,986✔
1050
}
1051

1052
__async_send_cb_fn_t getMsgRspHandle(int32_t msgType) {
22,582,140✔
1053
  switch (msgType) {
22,582,140✔
1054
    case TDMT_MND_CONNECT:
3,688,373✔
1055
      return processConnectRsp;
3,688,373✔
1056
    case TDMT_MND_CREATE_DB:
1,478,756✔
1057
      return processCreateDbRsp;
1,478,756✔
1058
    case TDMT_MND_USE_DB:
3,018,601✔
1059
      return processUseDbRsp;
3,018,601✔
1060
    case TDMT_MND_CREATE_STB:
2,229,130✔
1061
      return processCreateSTableRsp;
2,229,130✔
1062
    case TDMT_MND_DROP_DB:
1,311,056✔
1063
      return processDropDbRsp;
1,311,056✔
1064
    case TDMT_MND_ALTER_STB:
6,013,592✔
1065
      return processAlterStbRsp;
6,013,592✔
1066
    case TDMT_MND_SHOW_VARIABLES:
44,881✔
1067
      return processShowVariablesRsp;
44,881✔
1068
    case TDMT_MND_COMPACT_DB:
33,567✔
1069
      return processCompactDbRsp;
33,567✔
1070
    case TDMT_MND_TRIM_DB:
42,986✔
1071
      return processTrimDbRsp;
42,986✔
1072
    case TDMT_MND_SCAN_DB:
762✔
1073
      return processScanDbRsp;
762✔
1074
    default:
4,720,436✔
1075
      return genericRspCallback;
4,720,436✔
1076
  }
1077
}
1078

STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc