Merge branch '3.0' of https://github.com/taosdata/TDengine into TD-20251
This commit is contained in:
commit
8ec9ca5c64
|
@ -152,13 +152,13 @@ int32_t stmtRestoreQueryFields(STscStmt* pStmt) {
|
||||||
return TSDB_CODE_SUCCESS;
|
return TSDB_CODE_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t stmtUpdateBindInfo(TAOS_STMT* stmt, STableMeta* pTableMeta, void* tags, char* tbFName, const char* sTableName) {
|
int32_t stmtUpdateBindInfo(TAOS_STMT* stmt, STableMeta* pTableMeta, void* tags, char* tbFName, const char* sTableName, bool autoCreateTbl) {
|
||||||
STscStmt* pStmt = (STscStmt*)stmt;
|
STscStmt* pStmt = (STscStmt*)stmt;
|
||||||
|
|
||||||
strncpy(pStmt->bInfo.tbFName, tbFName, sizeof(pStmt->bInfo.tbFName) - 1);
|
strncpy(pStmt->bInfo.tbFName, tbFName, sizeof(pStmt->bInfo.tbFName) - 1);
|
||||||
pStmt->bInfo.tbFName[sizeof(pStmt->bInfo.tbFName) - 1] = 0;
|
pStmt->bInfo.tbFName[sizeof(pStmt->bInfo.tbFName) - 1] = 0;
|
||||||
|
|
||||||
pStmt->bInfo.tbUid = pTableMeta->uid;
|
pStmt->bInfo.tbUid = autoCreateTbl ? 0 : pTableMeta->uid;
|
||||||
pStmt->bInfo.tbSuid = pTableMeta->suid;
|
pStmt->bInfo.tbSuid = pTableMeta->suid;
|
||||||
pStmt->bInfo.tbType = pTableMeta->tableType;
|
pStmt->bInfo.tbType = pTableMeta->tableType;
|
||||||
pStmt->bInfo.boundTags = tags;
|
pStmt->bInfo.boundTags = tags;
|
||||||
|
@ -182,7 +182,7 @@ int32_t stmtUpdateInfo(TAOS_STMT* stmt, STableMeta* pTableMeta, void* tags, char
|
||||||
SHashObj* pVgHash, SHashObj* pBlockHash, const char* sTableName) {
|
SHashObj* pVgHash, SHashObj* pBlockHash, const char* sTableName) {
|
||||||
STscStmt* pStmt = (STscStmt*)stmt;
|
STscStmt* pStmt = (STscStmt*)stmt;
|
||||||
|
|
||||||
STMT_ERR_RET(stmtUpdateBindInfo(stmt, pTableMeta, tags, tbFName, sTableName));
|
STMT_ERR_RET(stmtUpdateBindInfo(stmt, pTableMeta, tags, tbFName, sTableName, autoCreateTbl));
|
||||||
STMT_ERR_RET(stmtUpdateExecInfo(stmt, pVgHash, pBlockHash, autoCreateTbl));
|
STMT_ERR_RET(stmtUpdateExecInfo(stmt, pVgHash, pBlockHash, autoCreateTbl));
|
||||||
|
|
||||||
pStmt->sql.autoCreateTbl = autoCreateTbl;
|
pStmt->sql.autoCreateTbl = autoCreateTbl;
|
||||||
|
@ -623,6 +623,8 @@ int stmtSetTbTags(TAOS_STMT* stmt, TAOS_MULTI_BIND* tags) {
|
||||||
pStmt->bInfo.sname.tname, tags, pStmt->exec.pRequest->msgBuf,
|
pStmt->bInfo.sname.tname, tags, pStmt->exec.pRequest->msgBuf,
|
||||||
pStmt->exec.pRequest->msgBufLen));
|
pStmt->exec.pRequest->msgBufLen));
|
||||||
|
|
||||||
|
pStmt->exec.autoCreateTbl = true;
|
||||||
|
|
||||||
return TSDB_CODE_SUCCESS;
|
return TSDB_CODE_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -771,10 +773,6 @@ int stmtAddBatch(TAOS_STMT* stmt) {
|
||||||
int stmtUpdateTableUid(STscStmt* pStmt, SSubmitRsp* pRsp) {
|
int stmtUpdateTableUid(STscStmt* pStmt, SSubmitRsp* pRsp) {
|
||||||
tscDebug("stmt start to update tbUid, blockNum: %d", pRsp->nBlocks);
|
tscDebug("stmt start to update tbUid, blockNum: %d", pRsp->nBlocks);
|
||||||
|
|
||||||
if (pRsp->nBlocks <= 0) {
|
|
||||||
return TSDB_CODE_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t keyLen = 0;
|
size_t keyLen = 0;
|
||||||
STableDataBlocks** pIter = taosHashIterate(pStmt->exec.pBlockHash, NULL);
|
STableDataBlocks** pIter = taosHashIterate(pStmt->exec.pBlockHash, NULL);
|
||||||
while (pIter) {
|
while (pIter) {
|
||||||
|
@ -809,8 +807,30 @@ int stmtUpdateTableUid(STscStmt* pStmt, SSubmitRsp* pRsp) {
|
||||||
pMeta->uid = blkRsp->uid;
|
pMeta->uid = blkRsp->uid;
|
||||||
pStmt->bInfo.tbUid = blkRsp->uid;
|
pStmt->bInfo.tbUid = blkRsp->uid;
|
||||||
} else {
|
} else {
|
||||||
tscError("table %s not found in submit rsp", pStmt->bInfo.tbFName);
|
tscDebug("table %s not found in submit rsp, will update from catalog", pStmt->bInfo.tbFName);
|
||||||
STMT_ERR_RET(TSDB_CODE_TSC_APP_ERROR);
|
if (NULL == pStmt->pCatalog) {
|
||||||
|
STMT_ERR_RET(catalogGetHandle(pStmt->taos->pAppInfo->clusterId, &pStmt->pCatalog));
|
||||||
|
}
|
||||||
|
|
||||||
|
STMT_ERR_RET(stmtCreateRequest(pStmt));
|
||||||
|
|
||||||
|
STableMeta* pTableMeta = NULL;
|
||||||
|
SRequestConnInfo conn = {.pTrans = pStmt->taos->pAppInfo->pTransporter,
|
||||||
|
.requestId = pStmt->exec.pRequest->requestId,
|
||||||
|
.requestObjRefId = pStmt->exec.pRequest->self,
|
||||||
|
.mgmtEps = getEpSet_s(&pStmt->taos->pAppInfo->mgmtEp)};
|
||||||
|
int32_t code = catalogGetTableMeta(pStmt->pCatalog, &conn, &pStmt->bInfo.sname, &pTableMeta);
|
||||||
|
|
||||||
|
taos_free_result(pStmt->exec.pRequest);
|
||||||
|
pStmt->exec.pRequest = NULL;
|
||||||
|
|
||||||
|
if (TSDB_CODE_PAR_TABLE_NOT_EXIST == code) {
|
||||||
|
tscDebug("tb %s not exist", pStmt->bInfo.tbFName);
|
||||||
|
return TSDB_CODE_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
pMeta->uid = pTableMeta->uid;
|
||||||
|
pStmt->bInfo.tbUid = pTableMeta->uid;
|
||||||
}
|
}
|
||||||
|
|
||||||
pIter = taosHashIterate(pStmt->exec.pBlockHash, pIter);
|
pIter = taosHashIterate(pStmt->exec.pBlockHash, pIter);
|
||||||
|
|
|
@ -981,6 +981,11 @@ static int metaUpdateTableTagVal(SMeta *pMeta, int64_t version, SVAlterTbReq *pA
|
||||||
|
|
||||||
/* get stbEntry*/
|
/* get stbEntry*/
|
||||||
tdbTbGet(pMeta->pUidIdx, &ctbEntry.ctbEntry.suid, sizeof(tb_uid_t), &pVal, &nVal);
|
tdbTbGet(pMeta->pUidIdx, &ctbEntry.ctbEntry.suid, sizeof(tb_uid_t), &pVal, &nVal);
|
||||||
|
if (!pVal) {
|
||||||
|
terrno = TSDB_CODE_INVALID_MSG;
|
||||||
|
goto _err;
|
||||||
|
}
|
||||||
|
|
||||||
tdbTbGet(pMeta->pTbDb, &((STbDbKey){.uid = ctbEntry.ctbEntry.suid, .version = ((SUidIdxVal *)pVal)[0].version}),
|
tdbTbGet(pMeta->pTbDb, &((STbDbKey){.uid = ctbEntry.ctbEntry.suid, .version = ((SUidIdxVal *)pVal)[0].version}),
|
||||||
sizeof(STbDbKey), (void **)&stbEntry.pBuf, &nVal);
|
sizeof(STbDbKey), (void **)&stbEntry.pBuf, &nVal);
|
||||||
tdbFree(pVal);
|
tdbFree(pVal);
|
||||||
|
|
|
@ -918,7 +918,12 @@ static int32_t preParseBoundColumnsClause(SInsertParseContext* pCxt, SVnodeModif
|
||||||
|
|
||||||
static int32_t getTableDataBlocks(SInsertParseContext* pCxt, SVnodeModifOpStmt* pStmt, STableDataBlocks** pDataBuf) {
|
static int32_t getTableDataBlocks(SInsertParseContext* pCxt, SVnodeModifOpStmt* pStmt, STableDataBlocks** pDataBuf) {
|
||||||
if (pCxt->pComCxt->async) {
|
if (pCxt->pComCxt->async) {
|
||||||
return insGetDataBlockFromList(pStmt->pTableBlockHashObj, &pStmt->pTableMeta->uid, sizeof(pStmt->pTableMeta->uid),
|
uint64_t uid = pStmt->pTableMeta->uid;
|
||||||
|
if (pStmt->usingTableProcessing) {
|
||||||
|
pStmt->pTableMeta->uid = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return insGetDataBlockFromList(pStmt->pTableBlockHashObj, &uid, sizeof(pStmt->pTableMeta->uid),
|
||||||
TSDB_DEFAULT_PAYLOAD_SIZE, sizeof(SSubmitBlk),
|
TSDB_DEFAULT_PAYLOAD_SIZE, sizeof(SSubmitBlk),
|
||||||
getTableInfo(pStmt->pTableMeta).rowSize, pStmt->pTableMeta, pDataBuf, NULL,
|
getTableInfo(pStmt->pTableMeta).rowSize, pStmt->pTableMeta, pDataBuf, NULL,
|
||||||
&pStmt->createTblReq);
|
&pStmt->createTblReq);
|
||||||
|
|
|
@ -741,14 +741,12 @@ static int tdbBtreeBalanceNonRoot(SBTree *pBt, SPage *pParent, int idx, TXN *pTx
|
||||||
tdbPageCreate(pOlds[0]->pageSize, &pOldsCopy[i], tdbDefaultMalloc, NULL);
|
tdbPageCreate(pOlds[0]->pageSize, &pOldsCopy[i], tdbDefaultMalloc, NULL);
|
||||||
tdbBtreeInitPage(pOldsCopy[i], &iarg, 0);
|
tdbBtreeInitPage(pOldsCopy[i], &iarg, 0);
|
||||||
tdbPageCopy(pOlds[i], pOldsCopy[i], 0);
|
tdbPageCopy(pOlds[i], pOldsCopy[i], 0);
|
||||||
}
|
pOlds[i]->nOverflow = 0;
|
||||||
|
|
||||||
for (iNew = 0; iNew < nNews; ++iNew) {
|
|
||||||
tdbBtreeInitPage(pNews[iNew], &iarg, 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
iNew = 0;
|
iNew = 0;
|
||||||
nNewCells = 0;
|
nNewCells = 0;
|
||||||
|
tdbBtreeInitPage(pNews[iNew], &iarg, 0);
|
||||||
|
|
||||||
for (int iOld = 0; iOld < nOlds; iOld++) {
|
for (int iOld = 0; iOld < nOlds; iOld++) {
|
||||||
SPage *pPage;
|
SPage *pPage;
|
||||||
|
|
|
@ -28,12 +28,12 @@ typedef struct {
|
||||||
TDB_STATIC_ASSERT(sizeof(SFileHdr) == 128, "Size of file header is not correct");
|
TDB_STATIC_ASSERT(sizeof(SFileHdr) == 128, "Size of file header is not correct");
|
||||||
|
|
||||||
struct hashset_st {
|
struct hashset_st {
|
||||||
size_t nbits;
|
size_t nbits;
|
||||||
size_t mask;
|
size_t mask;
|
||||||
size_t capacity;
|
size_t capacity;
|
||||||
size_t *items;
|
size_t *items;
|
||||||
size_t nitems;
|
size_t nitems;
|
||||||
double load_factor;
|
double load_factor;
|
||||||
};
|
};
|
||||||
|
|
||||||
static const unsigned int prime = 39;
|
static const unsigned int prime = 39;
|
||||||
|
@ -68,11 +68,11 @@ void hashset_destroy(hashset_t set) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int hashset_add_member(hashset_t set, void *item) {
|
int hashset_add_member(hashset_t set, void *item) {
|
||||||
size_t value = (size_t) item;
|
size_t value = (size_t)item;
|
||||||
size_t h;
|
size_t h;
|
||||||
|
|
||||||
if (value == 0) {
|
if (value == 0) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (h = set->mask & (prime * value); set->items[h] != 0; h = set->mask & (h + prime2)) {
|
for (h = set->mask & (prime * value); set->items[h] != 0; h = set->mask & (h + prime2)) {
|
||||||
|
@ -103,7 +103,7 @@ int hashset_add(hashset_t set, void *item) {
|
||||||
|
|
||||||
set->nitems = 0;
|
set->nitems = 0;
|
||||||
for (size_t i = 0; i < old_capacity; ++i) {
|
for (size_t i = 0; i < old_capacity; ++i) {
|
||||||
hashset_add_member(set, (void*)old_items[i]);
|
hashset_add_member(set, (void *)old_items[i]);
|
||||||
}
|
}
|
||||||
tdbOsFree(old_items);
|
tdbOsFree(old_items);
|
||||||
}
|
}
|
||||||
|
@ -112,7 +112,7 @@ int hashset_add(hashset_t set, void *item) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int hashset_remove(hashset_t set, void *item) {
|
int hashset_remove(hashset_t set, void *item) {
|
||||||
size_t value = (size_t) item;
|
size_t value = (size_t)item;
|
||||||
|
|
||||||
for (size_t h = set->mask & (prime * value); set->items[h] != 0; h = set->mask & (h + prime2)) {
|
for (size_t h = set->mask & (prime * value); set->items[h] != 0; h = set->mask & (h + prime2)) {
|
||||||
if (set->items[h] == value) {
|
if (set->items[h] == value) {
|
||||||
|
@ -126,7 +126,7 @@ int hashset_remove(hashset_t set, void *item) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int hashset_contains(hashset_t set, void *item) {
|
int hashset_contains(hashset_t set, void *item) {
|
||||||
size_t value = (size_t) item;
|
size_t value = (size_t)item;
|
||||||
|
|
||||||
for (size_t h = set->mask & (prime * value); set->items[h] != 0; h = set->mask & (h + prime2)) {
|
for (size_t h = set->mask & (prime * value); set->items[h] != 0; h = set->mask & (h + prime2)) {
|
||||||
if (set->items[h] == value) {
|
if (set->items[h] == value) {
|
||||||
|
@ -319,7 +319,8 @@ int tdbPagerWrite(SPager *pPager, SPage *pPage) {
|
||||||
tRBTreePut(&pPager->rbt, (SRBTreeNode *)pPage);
|
tRBTreePut(&pPager->rbt, (SRBTreeNode *)pPage);
|
||||||
|
|
||||||
// Write page to journal if neccessary
|
// Write page to journal if neccessary
|
||||||
if (TDB_PAGE_PGNO(pPage) <= pPager->dbOrigSize && (pPager->jPageSet == NULL || !hashset_contains(pPager->jPageSet, (void*)((long)TDB_PAGE_PGNO(pPage))))) {
|
if (TDB_PAGE_PGNO(pPage) <= pPager->dbOrigSize &&
|
||||||
|
(pPager->jPageSet == NULL || !hashset_contains(pPager->jPageSet, (void *)((long)TDB_PAGE_PGNO(pPage))))) {
|
||||||
ret = tdbPagerWritePageToJournal(pPager, pPage);
|
ret = tdbPagerWritePageToJournal(pPager, pPage);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
tdbError("failed to write page to journal since %s", tstrerror(terrno));
|
tdbError("failed to write page to journal since %s", tstrerror(terrno));
|
||||||
|
@ -327,7 +328,7 @@ int tdbPagerWrite(SPager *pPager, SPage *pPage) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pPager->jPageSet) {
|
if (pPager->jPageSet) {
|
||||||
hashset_add(pPager->jPageSet, (void*)((long)TDB_PAGE_PGNO(pPage)));
|
hashset_add(pPager->jPageSet, (void *)((long)TDB_PAGE_PGNO(pPage)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -372,6 +373,7 @@ int tdbPagerCommit(SPager *pPager, TXN *pTxn) {
|
||||||
SRBTreeNode *pNode = NULL;
|
SRBTreeNode *pNode = NULL;
|
||||||
while ((pNode = tRBTreeIterNext(&iter)) != NULL) {
|
while ((pNode = tRBTreeIterNext(&iter)) != NULL) {
|
||||||
pPage = (SPage *)pNode;
|
pPage = (SPage *)pNode;
|
||||||
|
ASSERT(pPage->nOverflow == 0);
|
||||||
ret = tdbPagerWritePageToDB(pPager, pPage);
|
ret = tdbPagerWritePageToDB(pPager, pPage);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
tdbError("failed to write page to db since %s", tstrerror(terrno));
|
tdbError("failed to write page to db since %s", tstrerror(terrno));
|
||||||
|
@ -391,7 +393,7 @@ int tdbPagerCommit(SPager *pPager, TXN *pTxn) {
|
||||||
|
|
||||||
tRBTreeDrop(&pPager->rbt, (SRBTreeNode *)pPage);
|
tRBTreeDrop(&pPager->rbt, (SRBTreeNode *)pPage);
|
||||||
if (pPager->jPageSet) {
|
if (pPager->jPageSet) {
|
||||||
hashset_remove(pPager->jPageSet, (void*)((long)TDB_PAGE_PGNO(pPage)));
|
hashset_remove(pPager->jPageSet, (void *)((long)TDB_PAGE_PGNO(pPage)));
|
||||||
}
|
}
|
||||||
tdbPCacheRelease(pPager->pCache, pPage, pTxn);
|
tdbPCacheRelease(pPager->pCache, pPage, pTxn);
|
||||||
}
|
}
|
||||||
|
@ -503,7 +505,7 @@ int tdbPagerAbort(SPager *pPager, TXN *pTxn) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
u8 *pageBuf = tdbOsCalloc(1, pPager->pageSize);
|
u8 *pageBuf = tdbOsCalloc(1, pPager->pageSize);
|
||||||
if (pageBuf == NULL) {
|
if (pageBuf == NULL) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -560,7 +562,7 @@ int tdbPagerAbort(SPager *pPager, TXN *pTxn) {
|
||||||
pPage->isDirty = 0;
|
pPage->isDirty = 0;
|
||||||
|
|
||||||
tRBTreeDrop(&pPager->rbt, (SRBTreeNode *)pPage);
|
tRBTreeDrop(&pPager->rbt, (SRBTreeNode *)pPage);
|
||||||
hashset_remove(pPager->jPageSet, (void*)((long)TDB_PAGE_PGNO(pPage)));
|
hashset_remove(pPager->jPageSet, (void *)((long)TDB_PAGE_PGNO(pPage)));
|
||||||
tdbPCacheRelease(pPager->pCache, pPage, pTxn);
|
tdbPCacheRelease(pPager->pCache, pPage, pTxn);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -794,15 +794,18 @@ void cliSend(SCliConn* pConn) {
|
||||||
int msgLen = transMsgLenFromCont(pMsg->contLen);
|
int msgLen = transMsgLenFromCont(pMsg->contLen);
|
||||||
STransMsgHead* pHead = transHeadFromCont(pMsg->pCont);
|
STransMsgHead* pHead = transHeadFromCont(pMsg->pCont);
|
||||||
|
|
||||||
pHead->ahandle = pCtx != NULL ? (uint64_t)pCtx->ahandle : 0;
|
if (pHead->comp == 0) {
|
||||||
pHead->noResp = REQUEST_NO_RESP(pMsg) ? 1 : 0;
|
pHead->ahandle = pCtx != NULL ? (uint64_t)pCtx->ahandle : 0;
|
||||||
pHead->persist = REQUEST_PERSIS_HANDLE(pMsg) ? 1 : 0;
|
pHead->noResp = REQUEST_NO_RESP(pMsg) ? 1 : 0;
|
||||||
pHead->msgType = pMsg->msgType;
|
pHead->persist = REQUEST_PERSIS_HANDLE(pMsg) ? 1 : 0;
|
||||||
pHead->msgLen = (int32_t)htonl((uint32_t)msgLen);
|
pHead->msgType = pMsg->msgType;
|
||||||
pHead->release = REQUEST_RELEASE_HANDLE(pCliMsg) ? 1 : 0;
|
pHead->msgLen = (int32_t)htonl((uint32_t)msgLen);
|
||||||
memcpy(pHead->user, pTransInst->user, strlen(pTransInst->user));
|
pHead->release = REQUEST_RELEASE_HANDLE(pCliMsg) ? 1 : 0;
|
||||||
pHead->traceId = pMsg->info.traceId;
|
memcpy(pHead->user, pTransInst->user, strlen(pTransInst->user));
|
||||||
pHead->magicNum = htonl(TRANS_MAGIC_NUM);
|
pHead->traceId = pMsg->info.traceId;
|
||||||
|
pHead->magicNum = htonl(TRANS_MAGIC_NUM);
|
||||||
|
}
|
||||||
|
|
||||||
if (pHead->persist == 1) {
|
if (pHead->persist == 1) {
|
||||||
CONN_SET_PERSIST_BY_APP(pConn);
|
CONN_SET_PERSIST_BY_APP(pConn);
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,21 +60,20 @@ int32_t transDecompressMsg(char** msg, int32_t len) {
|
||||||
STransMsgHead* pHead = (STransMsgHead*)(*msg);
|
STransMsgHead* pHead = (STransMsgHead*)(*msg);
|
||||||
if (pHead->comp == 0) return 0;
|
if (pHead->comp == 0) return 0;
|
||||||
|
|
||||||
char* pCont = transContFromHead(pHead);
|
char* pCont = transContFromHead(pHead);
|
||||||
|
|
||||||
STransCompMsg* pComp = (STransCompMsg*)pCont;
|
STransCompMsg* pComp = (STransCompMsg*)pCont;
|
||||||
int32_t oriLen = htonl(pComp->contLen);
|
int32_t oriLen = htonl(pComp->contLen);
|
||||||
|
|
||||||
char* buf = taosMemoryCalloc(1, oriLen + sizeof(STransMsgHead));
|
char* buf = taosMemoryCalloc(1, oriLen + sizeof(STransMsgHead));
|
||||||
STransMsgHead* pNewHead = (STransMsgHead*)buf;
|
STransMsgHead* pNewHead = (STransMsgHead*)buf;
|
||||||
|
int32_t decompLen = LZ4_decompress_safe(pCont + sizeof(STransCompMsg), pNewHead->content,
|
||||||
int32_t decompLen = LZ4_decompress_safe(pCont + sizeof(STransCompMsg), pNewHead->content,
|
len - sizeof(STransMsgHead) - sizeof(STransCompMsg), oriLen);
|
||||||
len - sizeof(STransMsgHead) - sizeof(STransCompMsg), oriLen);
|
|
||||||
memcpy((char*)pNewHead, (char*)pHead, sizeof(STransMsgHead));
|
memcpy((char*)pNewHead, (char*)pHead, sizeof(STransMsgHead));
|
||||||
|
|
||||||
pNewHead->msgLen = htonl(oriLen + sizeof(STransMsgHead));
|
pNewHead->msgLen = htonl(oriLen + sizeof(STransMsgHead));
|
||||||
|
|
||||||
taosMemoryFree(pHead);
|
taosMemoryFree(pHead);
|
||||||
|
|
||||||
*msg = buf;
|
*msg = buf;
|
||||||
if (decompLen != oriLen) {
|
if (decompLen != oriLen) {
|
||||||
return -1;
|
return -1;
|
||||||
|
|
|
@ -278,7 +278,7 @@
|
||||||
,,y,script,./test.sh -f tsim/stable/values.sim
|
,,y,script,./test.sh -f tsim/stable/values.sim
|
||||||
,,y,script,./test.sh -f tsim/stable/vnode3.sim
|
,,y,script,./test.sh -f tsim/stable/vnode3.sim
|
||||||
,,y,script,./test.sh -f tsim/stable/metrics_idx.sim
|
,,y,script,./test.sh -f tsim/stable/metrics_idx.sim
|
||||||
,,,script,./test.sh -f tsim/sma/drop_sma.sim
|
,,n,script,./test.sh -f tsim/sma/drop_sma.sim
|
||||||
,,y,script,./test.sh -f tsim/sma/sma_leak.sim
|
,,y,script,./test.sh -f tsim/sma/sma_leak.sim
|
||||||
,,y,script,./test.sh -f tsim/sma/tsmaCreateInsertQuery.sim
|
,,y,script,./test.sh -f tsim/sma/tsmaCreateInsertQuery.sim
|
||||||
,,y,script,./test.sh -f tsim/sma/rsmaCreateInsertQuery.sim
|
,,y,script,./test.sh -f tsim/sma/rsmaCreateInsertQuery.sim
|
||||||
|
@ -428,7 +428,7 @@
|
||||||
,,n,system-test,python3 ./test.py -f 1-insert/boundary.py
|
,,n,system-test,python3 ./test.py -f 1-insert/boundary.py
|
||||||
,,n,system-test,python3 ./test.py -f 1-insert/insertWithMoreVgroup.py
|
,,n,system-test,python3 ./test.py -f 1-insert/insertWithMoreVgroup.py
|
||||||
,,y,system-test,./pytest.sh python3 ./test.py -f 1-insert/table_comment.py
|
,,y,system-test,./pytest.sh python3 ./test.py -f 1-insert/table_comment.py
|
||||||
,,,system-test,python3 ./test.py -f 1-insert/time_range_wise.py
|
,,n,system-test,python3 ./test.py -f 1-insert/time_range_wise.py
|
||||||
,,,system-test,python3 ./test.py -f 1-insert/block_wise.py
|
,,,system-test,python3 ./test.py -f 1-insert/block_wise.py
|
||||||
,,,system-test,python3 ./test.py -f 1-insert/create_retentions.py
|
,,,system-test,python3 ./test.py -f 1-insert/create_retentions.py
|
||||||
,,y,system-test,./pytest.sh python3 ./test.py -f 1-insert/mutil_stage.py
|
,,y,system-test,./pytest.sh python3 ./test.py -f 1-insert/mutil_stage.py
|
||||||
|
@ -632,7 +632,7 @@
|
||||||
,,y,system-test,./pytest.sh python3 ./test.py -f 2-query/elapsed.py
|
,,y,system-test,./pytest.sh python3 ./test.py -f 2-query/elapsed.py
|
||||||
,,y,system-test,./pytest.sh python3 ./test.py -f 2-query/csum.py
|
,,y,system-test,./pytest.sh python3 ./test.py -f 2-query/csum.py
|
||||||
,,y,system-test,./pytest.sh python3 ./test.py -f 2-query/function_diff.py
|
,,y,system-test,./pytest.sh python3 ./test.py -f 2-query/function_diff.py
|
||||||
,,,system-test,python3 ./test.py -f 2-query/queryQnode.py
|
,,n,system-test,python3 ./test.py -f 2-query/queryQnode.py
|
||||||
,,,system-test,python3 ./test.py -f 6-cluster/5dnode1mnode.py
|
,,,system-test,python3 ./test.py -f 6-cluster/5dnode1mnode.py
|
||||||
,,,system-test,python3 ./test.py -f 6-cluster/5dnode2mnode.py -N 5
|
,,,system-test,python3 ./test.py -f 6-cluster/5dnode2mnode.py -N 5
|
||||||
,,,system-test,python3 ./test.py -f 6-cluster/5dnode3mnodeStop.py -N 5 -M 3
|
,,,system-test,python3 ./test.py -f 6-cluster/5dnode3mnodeStop.py -N 5 -M 3
|
||||||
|
@ -669,7 +669,7 @@
|
||||||
,,,system-test,python3 test.py -f 6-cluster/vnode/4dnode1mnode_basic_replica3_insertdatas_querys.py -N 4 -M 1
|
,,,system-test,python3 test.py -f 6-cluster/vnode/4dnode1mnode_basic_replica3_insertdatas_querys.py -N 4 -M 1
|
||||||
,,,system-test,python3 test.py -f 6-cluster/vnode/4dnode1mnode_basic_replica3_vgroups.py -N 4 -M 1
|
,,,system-test,python3 test.py -f 6-cluster/vnode/4dnode1mnode_basic_replica3_vgroups.py -N 4 -M 1
|
||||||
,,y,system-test,./pytest.sh python3 ./test.py -f 7-tmq/create_wrong_topic.py
|
,,y,system-test,./pytest.sh python3 ./test.py -f 7-tmq/create_wrong_topic.py
|
||||||
,,,system-test,python3 ./test.py -f 7-tmq/dropDbR3ConflictTransaction.py -N 3
|
,,y,system-test,./pytest.sh python3 ./test.py -f 7-tmq/dropDbR3ConflictTransaction.py -N 3
|
||||||
,,,system-test,python3 ./test.py -f 7-tmq/basic5.py
|
,,,system-test,python3 ./test.py -f 7-tmq/basic5.py
|
||||||
,,,system-test,python3 ./test.py -f 7-tmq/subscribeDb.py
|
,,,system-test,python3 ./test.py -f 7-tmq/subscribeDb.py
|
||||||
,,,system-test,python3 ./test.py -f 7-tmq/subscribeDb0.py
|
,,,system-test,python3 ./test.py -f 7-tmq/subscribeDb0.py
|
||||||
|
@ -725,7 +725,7 @@
|
||||||
,,,system-test,python3 ./test.py -f 7-tmq/dataFromTsdbNWal-multiCtb.py
|
,,,system-test,python3 ./test.py -f 7-tmq/dataFromTsdbNWal-multiCtb.py
|
||||||
,,,system-test,python3 ./test.py -f 7-tmq/tmq_taosx.py
|
,,,system-test,python3 ./test.py -f 7-tmq/tmq_taosx.py
|
||||||
,,,system-test,python3 ./test.py -f 7-tmq/stbTagFilter-multiCtb.py
|
,,,system-test,python3 ./test.py -f 7-tmq/stbTagFilter-multiCtb.py
|
||||||
,,,system-test,python3 ./test.py -f 99-TDcase/TD-19201.py
|
,,y,system-test,./pytest.sh python3 ./test.py -f 99-TDcase/TD-19201.py
|
||||||
,,,system-test,python3 ./test.py -f 7-tmq/tmqSubscribeStb-r3.py -N 5
|
,,,system-test,python3 ./test.py -f 7-tmq/tmqSubscribeStb-r3.py -N 5
|
||||||
,,,system-test,python3 ./test.py -f 7-tmq/tmq3mnodeSwitch.py -N 6 -M 3
|
,,,system-test,python3 ./test.py -f 7-tmq/tmq3mnodeSwitch.py -N 6 -M 3
|
||||||
,,,system-test,python3 ./test.py -f 7-tmq/tmq3mnodeSwitch.py -N 6 -M 3 -n 3
|
,,,system-test,python3 ./test.py -f 7-tmq/tmq3mnodeSwitch.py -N 6 -M 3 -n 3
|
||||||
|
|
|
@ -115,6 +115,7 @@ int insertMBMETest3(TAOS_STMT *stmt, TAOS *taos);
|
||||||
int insertMBMETest4(TAOS_STMT *stmt, TAOS *taos);
|
int insertMBMETest4(TAOS_STMT *stmt, TAOS *taos);
|
||||||
int insertMPMETest1(TAOS_STMT *stmt, TAOS *taos);
|
int insertMPMETest1(TAOS_STMT *stmt, TAOS *taos);
|
||||||
int insertAUTOTest1(TAOS_STMT *stmt, TAOS *taos);
|
int insertAUTOTest1(TAOS_STMT *stmt, TAOS *taos);
|
||||||
|
int insertAUTOTest2(TAOS_STMT *stmt, TAOS *taos);
|
||||||
int queryColumnTest(TAOS_STMT *stmt, TAOS *taos);
|
int queryColumnTest(TAOS_STMT *stmt, TAOS *taos);
|
||||||
int queryMiscTest(TAOS_STMT *stmt, TAOS *taos);
|
int queryMiscTest(TAOS_STMT *stmt, TAOS *taos);
|
||||||
|
|
||||||
|
@ -128,7 +129,7 @@ typedef struct {
|
||||||
int32_t colNum;
|
int32_t colNum;
|
||||||
int32_t *colList; // full table column list
|
int32_t *colList; // full table column list
|
||||||
int32_t testType;
|
int32_t testType;
|
||||||
bool autoCreateTbl;
|
int32_t autoCreateTbl;
|
||||||
bool fullCol;
|
bool fullCol;
|
||||||
int32_t (*runFn)(TAOS_STMT*, TAOS*);
|
int32_t (*runFn)(TAOS_STMT*, TAOS*);
|
||||||
int32_t tblNum;
|
int32_t tblNum;
|
||||||
|
@ -142,45 +143,46 @@ typedef struct {
|
||||||
} CaseCfg;
|
} CaseCfg;
|
||||||
|
|
||||||
CaseCfg gCase[] = {
|
CaseCfg gCase[] = {
|
||||||
{"insert:MBSE0-FULL", tListLen(shortColList), shortColList, TTYPE_INSERT, false, true, insertMBSETest1, 1, 10, 10, 0, 0, 0, 1, -1},
|
{"insert:MBSE0-FULL", tListLen(shortColList), shortColList, TTYPE_INSERT, 0, true, insertMBSETest1, 1, 10, 10, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBSE0-FULL", tListLen(shortColList), shortColList, TTYPE_INSERT, false, true, insertMBSETest1, 10, 100, 10, 0, 0, 0, 1, -1},
|
{"insert:MBSE0-FULL", tListLen(shortColList), shortColList, TTYPE_INSERT, 0, true, insertMBSETest1, 10, 100, 10, 0, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"insert:MBSE1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBSETest1, 10, 10, 2, 0, 0, 0, 1, -1},
|
{"insert:MBSE1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, true, insertMBSETest1, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBSE1-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBSETest1, 10, 10, 2, 12, 0, 0, 1, -1},
|
{"insert:MBSE1-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMBSETest1, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
{"insert:MBSE1-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBSETest1, 10, 10, 2, 2, 0, 0, 1, -1},
|
{"insert:MBSE1-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMBSETest1, 10, 10, 2, 2, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"insert:MBSE2-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBSETest2, 10, 10, 2, 0, 0, 0, 1, -1},
|
{"insert:MBSE2-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, true, insertMBSETest2, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBSE2-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBSETest2, 10, 10, 2, 12, 0, 0, 1, -1},
|
{"insert:MBSE2-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMBSETest2, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
{"insert:MBSE2-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBSETest2, 10, 10, 2, 2, 0, 0, 1, -1},
|
{"insert:MBSE2-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMBSETest2, 10, 10, 2, 2, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"insert:MBME1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBMETest1, 10, 10, 2, 0, 0, 0, 1, -1},
|
{"insert:MBME1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, true, insertMBMETest1, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBME1-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest1, 10, 10, 2, 12, 0, 0, 1, -1},
|
{"insert:MBME1-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMBMETest1, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
{"insert:MBME1-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest1, 10, 10, 2, 2, 0, 0, 1, -1},
|
{"insert:MBME1-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMBMETest1, 10, 10, 2, 2, 0, 0, 1, -1},
|
||||||
|
|
||||||
// 11
|
// 11
|
||||||
{"insert:MBME2-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBMETest2, 10, 10, 2, 0, 0, 0, 1, -1},
|
{"insert:MBME2-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, true, insertMBMETest2, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBME2-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest2, 10, 10, 2, 12, 0, 0, 1, -1},
|
{"insert:MBME2-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMBMETest2, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
{"insert:MBME2-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest2, 10, 10, 2, 2, 0, 0, 1, -1},
|
{"insert:MBME2-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMBMETest2, 10, 10, 2, 2, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"insert:MBME3-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBMETest3, 10, 10, 2, 0, 0, 0, 1, -1},
|
{"insert:MBME3-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, true, insertMBMETest3, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBME3-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest3, 10, 10, 2, 12, 0, 0, 1, -1},
|
{"insert:MBME3-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMBMETest3, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
{"insert:MBME3-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest3, 10, 10, 2, 2, 0, 0, 1, -1},
|
{"insert:MBME3-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMBMETest3, 10, 10, 2, 2, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"insert:MBME4-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBMETest4, 10, 10, 2, 0, 0, 0, 1, -1},
|
{"insert:MBME4-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, true, insertMBMETest4, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBME4-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest4, 10, 10, 2, 12, 0, 0, 1, -1},
|
{"insert:MBME4-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMBMETest4, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
{"insert:MBME4-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest4, 10, 10, 2, 2, 0, 0, 1, -1},
|
{"insert:MBME4-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMBMETest4, 10, 10, 2, 2, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"insert:MPME1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMPMETest1, 10, 10, 2, 0, 0, 0, 1, -1},
|
{"insert:MPME1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, true, insertMPMETest1, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MPME1-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMPMETest1, 10, 10, 2, 12, 0, 0, 1, -1},
|
{"insert:MPME1-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, 0, false, insertMPMETest1, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
|
|
||||||
// 22
|
// 22
|
||||||
{"insert:AUTO1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, true, true, insertAUTOTest1, 10, 10, 2, 0, 0, 0, 1, -1},
|
{"insert:AUTO1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, 1, true, insertAUTOTest1, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
|
{"insert:AUTO1-TBEXISTS", tListLen(fullColList), fullColList, TTYPE_INSERT, 3, true, insertAUTOTest2, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"query:SUBT-COLUMN", tListLen(fullColList), fullColList, TTYPE_QUERY, false, false, queryColumnTest, 10, 10, 1, 3, 0, 0, 1, 2},
|
{"query:SUBT-COLUMN", tListLen(fullColList), fullColList, TTYPE_QUERY, 0, false, queryColumnTest, 10, 10, 1, 3, 0, 0, 1, 2},
|
||||||
{"query:SUBT-MISC", tListLen(fullColList), fullColList, TTYPE_QUERY, false, false, queryMiscTest, 10, 10, 1, 3, 0, 0, 1, 2},
|
{"query:SUBT-MISC", tListLen(fullColList), fullColList, TTYPE_QUERY, 0, false, queryMiscTest, 10, 10, 1, 3, 0, 0, 1, 2},
|
||||||
|
|
||||||
// {"query:SUBT-COLUMN", tListLen(fullColList), fullColList, TTYPE_QUERY, false, false, queryColumnTest, 1, 10, 1, 1, 0, 0, 1, 2},
|
// {"query:SUBT-COLUMN", tListLen(fullColList), fullColList, TTYPE_QUERY, 0, false, queryColumnTest, 1, 10, 1, 1, 0, 0, 1, 2},
|
||||||
// {"query:SUBT-MISC", tListLen(fullColList), fullColList, TTYPE_QUERY, false, false, queryMiscTest, 2, 10, 1, 1, 0, 0, 1, 2},
|
// {"query:SUBT-MISC", tListLen(fullColList), fullColList, TTYPE_QUERY, 0, false, queryMiscTest, 2, 10, 1, 1, 0, 0, 1, 2},
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -221,7 +223,7 @@ typedef struct {
|
||||||
CaseCtrl gCaseCtrl = {
|
CaseCtrl gCaseCtrl = {
|
||||||
.precision = TIME_PRECISION_MICRO,
|
.precision = TIME_PRECISION_MICRO,
|
||||||
.bindNullNum = 0,
|
.bindNullNum = 0,
|
||||||
.printCreateTblSql = false,
|
.printCreateTblSql = true,
|
||||||
.printQuerySql = true,
|
.printQuerySql = true,
|
||||||
.printStmtSql = true,
|
.printStmtSql = true,
|
||||||
.printVerbose = false,
|
.printVerbose = false,
|
||||||
|
@ -230,7 +232,7 @@ CaseCtrl gCaseCtrl = {
|
||||||
.numericParam = false,
|
.numericParam = false,
|
||||||
.rowNum = 0,
|
.rowNum = 0,
|
||||||
.bindColNum = 0,
|
.bindColNum = 0,
|
||||||
.bindTagNum = 0,
|
.bindTagNum = 14,
|
||||||
.bindRowNum = 0,
|
.bindRowNum = 0,
|
||||||
.bindColTypeNum = 0,
|
.bindColTypeNum = 0,
|
||||||
.bindColTypeList = NULL,
|
.bindColTypeList = NULL,
|
||||||
|
@ -242,8 +244,8 @@ CaseCtrl gCaseCtrl = {
|
||||||
.funcIdxList = NULL,
|
.funcIdxList = NULL,
|
||||||
.checkParamNum = false,
|
.checkParamNum = false,
|
||||||
.runTimes = 0,
|
.runTimes = 0,
|
||||||
.caseIdx = -1,
|
.caseIdx = 23,
|
||||||
.caseNum = -1,
|
.caseNum = 1,
|
||||||
.caseRunIdx = -1,
|
.caseRunIdx = -1,
|
||||||
.caseRunNum = -1,
|
.caseRunNum = -1,
|
||||||
};
|
};
|
||||||
|
@ -1946,6 +1948,73 @@ int insertAUTOTest1(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* [prepare [settbnametag [bind add exec]]] */
|
||||||
|
int insertAUTOTest2(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
|
int32_t loop = 0;
|
||||||
|
|
||||||
|
while (gCurCase->bindTagNum > 0 && gCurCase->bindColNum > 0) {
|
||||||
|
BindData data = {0};
|
||||||
|
prepareInsertData(&data);
|
||||||
|
|
||||||
|
int code = taos_stmt_prepare(stmt, data.sql, 0);
|
||||||
|
if (code != 0){
|
||||||
|
printf("!!!failed to execute taos_stmt_prepare. error:%s\n", taos_stmt_errstr(stmt));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
bpCheckIsInsert(stmt, 1);
|
||||||
|
|
||||||
|
int32_t bindTimes = gCurCase->rowNum/gCurCase->bindRowNum;
|
||||||
|
for (int32_t b = 0; b <bindTimes; ++b) {
|
||||||
|
for (int32_t t = 0; t< gCurCase->tblNum; ++t) {
|
||||||
|
if (gCurCase->tblNum > 1) {
|
||||||
|
char buf[32];
|
||||||
|
sprintf(buf, "t%d", t);
|
||||||
|
code = bpSetTableNameTags(&data, t, buf, stmt);
|
||||||
|
if (code != 0){
|
||||||
|
printf("!!!taos_stmt_set_tbname_tags error:%s\n", taos_stmt_errstr(stmt));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gCaseCtrl.checkParamNum) {
|
||||||
|
bpCheckParamNum(stmt);
|
||||||
|
}
|
||||||
|
if (bpBindParam(stmt, data.pBind + t*bindTimes*gCurCase->bindColNum + b*gCurCase->bindColNum)) {
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (taos_stmt_add_batch(stmt)) {
|
||||||
|
printf("!!!taos_stmt_add_batch error:%s\n", taos_stmt_errstr(stmt));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (taos_stmt_execute(stmt) != 0) {
|
||||||
|
printf("!!!taos_stmt_execute error:%s\n", taos_stmt_errstr(stmt));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bpCheckIsInsert(stmt, 1);
|
||||||
|
|
||||||
|
destroyData(&data);
|
||||||
|
|
||||||
|
gCurCase->bindColNum -= 2;
|
||||||
|
gCurCase->bindTagNum -= 2;
|
||||||
|
gCurCase->fullCol = false;
|
||||||
|
loop++;
|
||||||
|
}
|
||||||
|
|
||||||
|
bpCheckAffectedRows(stmt, loop);
|
||||||
|
|
||||||
|
gExecLoopTimes = loop;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* select * from table */
|
/* select * from table */
|
||||||
int queryColumnTest(TAOS_STMT *stmt, TAOS *taos) {
|
int queryColumnTest(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
BindData data = {0};
|
BindData data = {0};
|
||||||
|
@ -2243,70 +2312,76 @@ int sql_s_perf1(TAOS *taos) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void generateCreateTableSQL(char *buf, int32_t tblIdx, int32_t colNum, int32_t *colList, bool stable) {
|
void generateCreateTableSQL(char *buf, int32_t tblIdx, int32_t colNum, int32_t *colList, int32_t tableType) {
|
||||||
int32_t blen = 0;
|
int32_t blen = 0;
|
||||||
blen = sprintf(buf, "create table %s%d ", (stable ? bpStbPrefix : bpTbPrefix), tblIdx);
|
blen = sprintf(buf, "create table %s%d ", (1 == tableType ? bpStbPrefix : bpTbPrefix), tblIdx);
|
||||||
|
|
||||||
blen += sprintf(buf + blen, " (");
|
if (tableType == 3) {
|
||||||
|
blen += sprintf(buf + blen, "using %s%d", bpStbPrefix, bpDefaultStbId);
|
||||||
for (int c = 0; c < colNum; ++c) {
|
|
||||||
if (c > 0) {
|
|
||||||
blen += sprintf(buf + blen, ",");
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (colList[c]) {
|
|
||||||
case TSDB_DATA_TYPE_BOOL:
|
|
||||||
blen += sprintf(buf + blen, "booldata bool");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_TINYINT:
|
|
||||||
blen += sprintf(buf + blen, "tinydata tinyint");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_SMALLINT:
|
|
||||||
blen += sprintf(buf + blen, "smalldata smallint");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_INT:
|
|
||||||
blen += sprintf(buf + blen, "intdata int");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_BIGINT:
|
|
||||||
blen += sprintf(buf + blen, "bigdata bigint");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_FLOAT:
|
|
||||||
blen += sprintf(buf + blen, "floatdata float");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_DOUBLE:
|
|
||||||
blen += sprintf(buf + blen, "doubledata double");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_VARCHAR:
|
|
||||||
blen += sprintf(buf + blen, "binarydata binary(%d)", gVarCharSize);
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_TIMESTAMP:
|
|
||||||
blen += sprintf(buf + blen, "ts timestamp");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_NCHAR:
|
|
||||||
blen += sprintf(buf + blen, "nchardata nchar(%d)", gVarCharSize);
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_UTINYINT:
|
|
||||||
blen += sprintf(buf + blen, "utinydata tinyint unsigned");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_USMALLINT:
|
|
||||||
blen += sprintf(buf + blen, "usmalldata smallint unsigned");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_UINT:
|
|
||||||
blen += sprintf(buf + blen, "uintdata int unsigned");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_UBIGINT:
|
|
||||||
blen += sprintf(buf + blen, "ubigdata bigint unsigned");
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
printf("invalid col type:%d", colList[c]);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
blen += sprintf(buf + blen, ")");
|
if (tableType == 0 || tableType == 1) {
|
||||||
|
blen += sprintf(buf + blen, " (");
|
||||||
|
|
||||||
|
for (int c = 0; c < colNum; ++c) {
|
||||||
|
if (c > 0) {
|
||||||
|
blen += sprintf(buf + blen, ",");
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (colList[c]) {
|
||||||
|
case TSDB_DATA_TYPE_BOOL:
|
||||||
|
blen += sprintf(buf + blen, "booldata bool");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_TINYINT:
|
||||||
|
blen += sprintf(buf + blen, "tinydata tinyint");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_SMALLINT:
|
||||||
|
blen += sprintf(buf + blen, "smalldata smallint");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_INT:
|
||||||
|
blen += sprintf(buf + blen, "intdata int");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_BIGINT:
|
||||||
|
blen += sprintf(buf + blen, "bigdata bigint");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_FLOAT:
|
||||||
|
blen += sprintf(buf + blen, "floatdata float");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_DOUBLE:
|
||||||
|
blen += sprintf(buf + blen, "doubledata double");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_VARCHAR:
|
||||||
|
blen += sprintf(buf + blen, "binarydata binary(%d)", gVarCharSize);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_TIMESTAMP:
|
||||||
|
blen += sprintf(buf + blen, "ts timestamp");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_NCHAR:
|
||||||
|
blen += sprintf(buf + blen, "nchardata nchar(%d)", gVarCharSize);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_UTINYINT:
|
||||||
|
blen += sprintf(buf + blen, "utinydata tinyint unsigned");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_USMALLINT:
|
||||||
|
blen += sprintf(buf + blen, "usmalldata smallint unsigned");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_UINT:
|
||||||
|
blen += sprintf(buf + blen, "uintdata int unsigned");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_UBIGINT:
|
||||||
|
blen += sprintf(buf + blen, "ubigdata bigint unsigned");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
printf("invalid col type:%d", colList[c]);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (stable) {
|
blen += sprintf(buf + blen, ")");
|
||||||
blen += sprintf(buf + blen, "tags (");
|
}
|
||||||
|
|
||||||
|
if (1 == tableType) {
|
||||||
|
blen += sprintf(buf + blen, " tags (");
|
||||||
for (int c = 0; c < colNum; ++c) {
|
for (int c = 0; c < colNum; ++c) {
|
||||||
if (c > 0) {
|
if (c > 0) {
|
||||||
blen += sprintf(buf + blen, ",");
|
blen += sprintf(buf + blen, ",");
|
||||||
|
@ -2363,6 +2438,64 @@ void generateCreateTableSQL(char *buf, int32_t tblIdx, int32_t colNum, int32_t *
|
||||||
blen += sprintf(buf + blen, ")");
|
blen += sprintf(buf + blen, ")");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (3 == tableType) {
|
||||||
|
blen += sprintf(buf + blen, " tags (");
|
||||||
|
for (int c = 0; c < colNum; ++c) {
|
||||||
|
if (c > 0) {
|
||||||
|
blen += sprintf(buf + blen, ",");
|
||||||
|
}
|
||||||
|
switch (colList[c]) {
|
||||||
|
case TSDB_DATA_TYPE_BOOL:
|
||||||
|
blen += sprintf(buf + blen, "%s", rand() % 2 ? "true": "false");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_TINYINT:
|
||||||
|
blen += sprintf(buf + blen, "%d", rand() % 128);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_SMALLINT:
|
||||||
|
blen += sprintf(buf + blen, "%d", rand() % 128);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_INT:
|
||||||
|
blen += sprintf(buf + blen, "%d", rand() % 128);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_BIGINT:
|
||||||
|
blen += sprintf(buf + blen, "%d", rand() % 128);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_FLOAT:
|
||||||
|
blen += sprintf(buf + blen, "%f", rand() % 128);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_DOUBLE:
|
||||||
|
blen += sprintf(buf + blen, "%f", rand() % 128);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_VARCHAR:
|
||||||
|
blen += sprintf(buf + blen, "'var%d'", rand() % 128);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_TIMESTAMP:
|
||||||
|
blen += sprintf(buf + blen, "%lld", bpTs);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_NCHAR:
|
||||||
|
blen += sprintf(buf + blen, "'nch%d'", rand() % 128);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_UTINYINT:
|
||||||
|
blen += sprintf(buf + blen, "%d", rand() % 128);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_USMALLINT:
|
||||||
|
blen += sprintf(buf + blen, "%d", rand() % 128);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_UINT:
|
||||||
|
blen += sprintf(buf + blen, "%d", rand() % 128);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_UBIGINT:
|
||||||
|
blen += sprintf(buf + blen, "%d", rand() % 128);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
printf("invalid col type:%d", colList[c]);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
blen += sprintf(buf + blen, ")");
|
||||||
|
}
|
||||||
|
|
||||||
if (gCaseCtrl.printCreateTblSql) {
|
if (gCaseCtrl.printCreateTblSql) {
|
||||||
printf("\tCreate Table SQL:%s\n", buf);
|
printf("\tCreate Table SQL:%s\n", buf);
|
||||||
}
|
}
|
||||||
|
@ -2421,11 +2554,11 @@ void prepare(TAOS *taos, int32_t colNum, int32_t *colList, int prepareStb) {
|
||||||
result = taos_query(taos, "use demo");
|
result = taos_query(taos, "use demo");
|
||||||
taos_free_result(result);
|
taos_free_result(result);
|
||||||
|
|
||||||
if (!prepareStb) {
|
if (0 == prepareStb) {
|
||||||
// create table
|
// create table
|
||||||
for (int i = 0 ; i < 10; i++) {
|
for (int i = 0 ; i < 10; i++) {
|
||||||
char buf[1024];
|
char buf[1024];
|
||||||
generateCreateTableSQL(buf, i, colNum, colList, false);
|
generateCreateTableSQL(buf, i, colNum, colList, 0);
|
||||||
result = taos_query(taos, buf);
|
result = taos_query(taos, buf);
|
||||||
code = taos_errno(result);
|
code = taos_errno(result);
|
||||||
if (code != 0) {
|
if (code != 0) {
|
||||||
|
@ -2436,17 +2569,35 @@ void prepare(TAOS *taos, int32_t colNum, int32_t *colList, int prepareStb) {
|
||||||
taos_free_result(result);
|
taos_free_result(result);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
char buf[1024];
|
if (1 == prepareStb || 3 == prepareStb) {
|
||||||
generateCreateTableSQL(buf, bpDefaultStbId, colNum, colList, true);
|
char buf[1024];
|
||||||
|
generateCreateTableSQL(buf, bpDefaultStbId, colNum, colList, 1);
|
||||||
result = taos_query(taos, buf);
|
|
||||||
code = taos_errno(result);
|
result = taos_query(taos, buf);
|
||||||
if (code != 0) {
|
code = taos_errno(result);
|
||||||
printf("!!!failed to create table, reason:%s\n", taos_errstr(result));
|
if (code != 0) {
|
||||||
|
printf("!!!failed to create table, reason:%s\n", taos_errstr(result));
|
||||||
|
taos_free_result(result);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
taos_free_result(result);
|
taos_free_result(result);
|
||||||
exit(1);
|
|
||||||
}
|
}
|
||||||
taos_free_result(result);
|
|
||||||
|
|
||||||
|
if (3 == prepareStb) {
|
||||||
|
for (int i = 0 ; i < 10; i++) {
|
||||||
|
char buf[1024];
|
||||||
|
generateCreateTableSQL(buf, i, colNum, colList, 3);
|
||||||
|
result = taos_query(taos, buf);
|
||||||
|
code = taos_errno(result);
|
||||||
|
if (code != 0) {
|
||||||
|
printf("!!!failed to create table, reason:%s\n", taos_errstr(result));
|
||||||
|
taos_free_result(result);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
taos_free_result(result);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -2486,7 +2637,7 @@ int32_t runCase(TAOS *taos, int32_t caseIdx, int32_t caseRunIdx, bool silent) {
|
||||||
|
|
||||||
if (gCaseCtrl.autoCreateTbl) {
|
if (gCaseCtrl.autoCreateTbl) {
|
||||||
if (gCurCase->testType == TTYPE_INSERT && gCurCase->tblNum > 1) {
|
if (gCurCase->testType == TTYPE_INSERT && gCurCase->tblNum > 1) {
|
||||||
gCurCase->autoCreateTbl = true;
|
gCurCase->autoCreateTbl = 1;
|
||||||
if (gCurCase->bindTagNum <= 0) {
|
if (gCurCase->bindTagNum <= 0) {
|
||||||
gCurCase->bindTagNum = gCurCase->colNum;
|
gCurCase->bindTagNum = gCurCase->colNum;
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,8 +37,9 @@ python_error=`cat ${LOG_DIR}/*.info | grep -w "stack" | wc -l`
|
||||||
# TD-20569
|
# TD-20569
|
||||||
# /root/TDengine/source/libs/function/src/builtinsimpl.c:856:29: runtime error: signed integer overflow: 9223372036854775806 + 9223372036854775805 cannot be represented in type 'long int'
|
# /root/TDengine/source/libs/function/src/builtinsimpl.c:856:29: runtime error: signed integer overflow: 9223372036854775806 + 9223372036854775805 cannot be represented in type 'long int'
|
||||||
# /root/TDengine/source/libs/scalar/src/sclvector.c:1075:66: runtime error: signed integer overflow: 9223372034707292160 + 1668838476672 cannot be represented in type 'long int'
|
# /root/TDengine/source/libs/scalar/src/sclvector.c:1075:66: runtime error: signed integer overflow: 9223372034707292160 + 1668838476672 cannot be represented in type 'long int'
|
||||||
|
# /root/TDengine/source/common/src/tdataformat.c:1876:7: runtime error: signed integer overflow: 8252423483843671206 + 2406154664059062870 cannot be represented in type 'long int'
|
||||||
|
|
||||||
runtime_error=`cat ${LOG_DIR}/*.asan | grep "runtime error" | grep -v "trees.c:873" | grep -v "sclfunc.c.*outside the range of representable values of type"| grep -v "builtinsimpl.c.*signed integer overflow"| grep -v "sclvector.c.*signed integer overflow" | wc -l`
|
runtime_error=`cat ${LOG_DIR}/*.asan | grep "runtime error" | grep -v "trees.c:873" | grep -v "sclfunc.c.*outside the range of representable values of type"| grep -v "signed integer overflow" | wc -l`
|
||||||
|
|
||||||
echo -e "\033[44;32;1m"asan error_num: $error_num"\033[0m"
|
echo -e "\033[44;32;1m"asan error_num: $error_num"\033[0m"
|
||||||
echo -e "\033[44;32;1m"asan memory_leak: $memory_leak"\033[0m"
|
echo -e "\033[44;32;1m"asan memory_leak: $memory_leak"\033[0m"
|
||||||
|
|
Loading…
Reference in New Issue