Merge branch '3.0' of https://github.com/taosdata/TDengine into feat/tsdb_refact
This commit is contained in:
commit
e52400dd44
|
@ -63,7 +63,7 @@ int32_t qAnalyseSqlSemantic(SParseContext* pCxt, const struct SCatalogReq* pCata
|
||||||
void qDestroyQuery(SQuery* pQueryNode);
|
void qDestroyQuery(SQuery* pQueryNode);
|
||||||
|
|
||||||
int32_t qExtractResultSchema(const SNode* pRoot, int32_t* numOfCols, SSchema** pSchema);
|
int32_t qExtractResultSchema(const SNode* pRoot, int32_t* numOfCols, SSchema** pSchema);
|
||||||
int32_t qSetSTableIdForRSma(SNode* pStmt, int64_t uid);
|
int32_t qSetSTableIdForRsma(SNode* pStmt, int64_t uid);
|
||||||
|
|
||||||
int32_t qBuildStmtOutput(SQuery* pQuery, SHashObj* pVgHash, SHashObj* pBlockHash);
|
int32_t qBuildStmtOutput(SQuery* pQuery, SHashObj* pVgHash, SHashObj* pBlockHash);
|
||||||
int32_t qResetStmtDataBlock(void* block, bool keepBuf);
|
int32_t qResetStmtDataBlock(void* block, bool keepBuf);
|
||||||
|
|
|
@ -27,10 +27,10 @@ void mndCleanupScheduler(SMnode* pMnode);
|
||||||
|
|
||||||
int32_t mndSchedInitSubEp(SMnode* pMnode, const SMqTopicObj* pTopic, SMqSubscribeObj* pSub);
|
int32_t mndSchedInitSubEp(SMnode* pMnode, const SMqTopicObj* pTopic, SMqSubscribeObj* pSub);
|
||||||
|
|
||||||
int32_t mndScheduleStream1(SMnode* pMnode, STrans* pTrans, SStreamObj* pStream);
|
int32_t mndScheduleStream(SMnode* pMnode, STrans* pTrans, SStreamObj* pStream);
|
||||||
|
|
||||||
int32_t mndConvertRSmaTask(const char* ast, int64_t uid, int8_t triggerType, int64_t watermark, char** pStr,
|
int32_t mndConvertRsmaTask(char** pDst, int32_t* pDstLen, const char* ast, int64_t uid, int8_t triggerType,
|
||||||
int32_t* pLen, double filesFactor);
|
int64_t watermark, double filesFactor);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,8 +42,8 @@ static int32_t mndAddTaskToTaskSet(SArray* pArray, SStreamTask* pTask) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t mndConvertRSmaTask(const char* ast, int64_t uid, int8_t triggerType, int64_t watermark, char** pStr,
|
int32_t mndConvertRsmaTask(char** pDst, int32_t* pDstLen, const char* ast, int64_t uid, int8_t triggerType,
|
||||||
int32_t* pLen, double filesFactor) {
|
int64_t watermark, double filesFactor) {
|
||||||
SNode* pAst = NULL;
|
SNode* pAst = NULL;
|
||||||
SQueryPlan* pPlan = NULL;
|
SQueryPlan* pPlan = NULL;
|
||||||
terrno = TSDB_CODE_SUCCESS;
|
terrno = TSDB_CODE_SUCCESS;
|
||||||
|
@ -53,7 +53,7 @@ int32_t mndConvertRSmaTask(const char* ast, int64_t uid, int8_t triggerType, int
|
||||||
goto END;
|
goto END;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (qSetSTableIdForRSma(pAst, uid) < 0) {
|
if (qSetSTableIdForRsma(pAst, uid) < 0) {
|
||||||
terrno = TSDB_CODE_QRY_INVALID_INPUT;
|
terrno = TSDB_CODE_QRY_INVALID_INPUT;
|
||||||
goto END;
|
goto END;
|
||||||
}
|
}
|
||||||
|
@ -86,7 +86,7 @@ int32_t mndConvertRSmaTask(const char* ast, int64_t uid, int8_t triggerType, int
|
||||||
}
|
}
|
||||||
|
|
||||||
SSubplan* plan = nodesListGetNode(inner->pNodeList, 0);
|
SSubplan* plan = nodesListGetNode(inner->pNodeList, 0);
|
||||||
if (qSubPlanToString(plan, pStr, pLen) < 0) {
|
if (qSubPlanToString(plan, pDst, pDstLen) < 0) {
|
||||||
terrno = TSDB_CODE_QRY_INVALID_INPUT;
|
terrno = TSDB_CODE_QRY_INVALID_INPUT;
|
||||||
goto END;
|
goto END;
|
||||||
}
|
}
|
||||||
|
@ -335,7 +335,7 @@ int32_t mndAddFixedSinkTaskToStream(SMnode* pMnode, STrans* pTrans, SStreamObj*
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t mndScheduleStream1(SMnode* pMnode, STrans* pTrans, SStreamObj* pStream) {
|
int32_t mndScheduleStream(SMnode* pMnode, STrans* pTrans, SStreamObj* pStream) {
|
||||||
SSdb* pSdb = pMnode->pSdb;
|
SSdb* pSdb = pMnode->pSdb;
|
||||||
SQueryPlan* pPlan = qStringToQueryPlan(pStream->physicalPlan);
|
SQueryPlan* pPlan = qStringToQueryPlan(pStream->physicalPlan);
|
||||||
if (pPlan == NULL) {
|
if (pPlan == NULL) {
|
||||||
|
@ -361,6 +361,7 @@ int32_t mndScheduleStream1(SMnode* pMnode, STrans* pTrans, SStreamObj* pStream)
|
||||||
mndAddFixedSinkTaskToStream(pMnode, pTrans, pStream);
|
mndAddFixedSinkTaskToStream(pMnode, pTrans, pStream);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (totLevel > 1) {
|
if (totLevel > 1) {
|
||||||
SStreamTask* pFinalTask;
|
SStreamTask* pFinalTask;
|
||||||
// inner plan
|
// inner plan
|
||||||
|
@ -472,229 +473,7 @@ int32_t mndScheduleStream1(SMnode* pMnode, STrans* pTrans, SStreamObj* pStream)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int32_t mndScheduleStream(SMnode* pMnode, STrans* pTrans, SStreamObj* pStream) {
|
|
||||||
SSdb* pSdb = pMnode->pSdb;
|
|
||||||
SQueryPlan* pPlan = qStringToQueryPlan(pStream->physicalPlan);
|
|
||||||
if (pPlan == NULL) {
|
|
||||||
terrno = TSDB_CODE_QRY_INVALID_INPUT;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
ASSERT(pStream->vgNum == 0);
|
|
||||||
|
|
||||||
int32_t totLevel = LIST_LENGTH(pPlan->pSubplans);
|
|
||||||
ASSERT(totLevel <= 2);
|
|
||||||
pStream->tasks = taosArrayInit(totLevel, sizeof(void*));
|
|
||||||
|
|
||||||
bool hasExtraSink = false;
|
|
||||||
bool externalTargetDB = strcmp(pStream->sourceDb, pStream->targetDb) != 0;
|
|
||||||
if (totLevel == 2 || externalTargetDB) {
|
|
||||||
SArray* taskOneLevel = taosArrayInit(0, sizeof(void*));
|
|
||||||
taosArrayPush(pStream->tasks, &taskOneLevel);
|
|
||||||
// add extra sink
|
|
||||||
hasExtraSink = true;
|
|
||||||
if (pStream->fixedSinkVgId == 0) {
|
|
||||||
mndAddShuffleSinkTasksToStream(pMnode, pTrans, pStream);
|
|
||||||
} else {
|
|
||||||
mndAddFixedSinkTaskToStream(pMnode, pTrans, pStream);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int32_t level = 0; level < totLevel; level++) {
|
|
||||||
SArray* taskOneLevel = taosArrayInit(0, sizeof(void*));
|
|
||||||
taosArrayPush(pStream->tasks, &taskOneLevel);
|
|
||||||
SNodeListNode* inner = nodesListGetNode(pPlan->pSubplans, level);
|
|
||||||
ASSERT(LIST_LENGTH(inner->pNodeList) == 1);
|
|
||||||
|
|
||||||
SSubplan* plan = nodesListGetNode(inner->pNodeList, 0);
|
|
||||||
|
|
||||||
// if (level == totLevel - 1 /* or no snode */) {
|
|
||||||
if (level == totLevel - 1) {
|
|
||||||
// last level, source, must assign to vnode
|
|
||||||
// must be scan type
|
|
||||||
ASSERT(plan->subplanType == SUBPLAN_TYPE_SCAN);
|
|
||||||
|
|
||||||
// replicate task to each vnode
|
|
||||||
void* pIter = NULL;
|
|
||||||
while (1) {
|
|
||||||
SVgObj* pVgroup;
|
|
||||||
pIter = sdbFetch(pSdb, SDB_VGROUP, pIter, (void**)&pVgroup);
|
|
||||||
if (pIter == NULL) break;
|
|
||||||
if (pVgroup->dbUid != pStream->dbUid) {
|
|
||||||
sdbRelease(pSdb, pVgroup);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
SStreamTask* pTask = tNewSStreamTask(pStream->uid);
|
|
||||||
mndAddTaskToTaskSet(taskOneLevel, pTask);
|
|
||||||
// source part
|
|
||||||
pTask->sourceType = TASK_SOURCE__SCAN;
|
|
||||||
pTask->inputType = TASK_INPUT_TYPE__SUMBIT_BLOCK;
|
|
||||||
|
|
||||||
// sink part
|
|
||||||
if (level == 0) {
|
|
||||||
// only for inplace
|
|
||||||
pTask->sinkType = TASK_SINK__NONE;
|
|
||||||
if (!hasExtraSink) {
|
|
||||||
#if 1
|
|
||||||
if (pStream->createdBy == STREAM_CREATED_BY__SMA) {
|
|
||||||
pTask->sinkType = TASK_SINK__SMA;
|
|
||||||
pTask->smaSink.smaId = pStream->smaId;
|
|
||||||
} else {
|
|
||||||
pTask->sinkType = TASK_SINK__TABLE;
|
|
||||||
pTask->tbSink.stbUid = pStream->targetStbUid;
|
|
||||||
memcpy(pTask->tbSink.stbFullName, pStream->targetSTbName, TSDB_TABLE_FNAME_LEN);
|
|
||||||
pTask->tbSink.pSchemaWrapper = tCloneSSchemaWrapper(&pStream->outputSchema);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
pTask->sinkType = TASK_SINK__NONE;
|
|
||||||
}
|
|
||||||
|
|
||||||
// dispatch part
|
|
||||||
if (level == 0 && !hasExtraSink) {
|
|
||||||
pTask->dispatchType = TASK_DISPATCH__NONE;
|
|
||||||
} else {
|
|
||||||
// add fixed ep dispatcher
|
|
||||||
int32_t lastLevel = level - 1;
|
|
||||||
if (hasExtraSink) lastLevel++;
|
|
||||||
ASSERT(lastLevel == 0);
|
|
||||||
SArray* pArray = taosArrayGetP(pStream->tasks, lastLevel);
|
|
||||||
// one merge only
|
|
||||||
ASSERT(taosArrayGetSize(pArray) == 1);
|
|
||||||
SStreamTask* lastLevelTask = taosArrayGetP(pArray, 0);
|
|
||||||
pTask->dispatchMsgType = TDMT_STREAM_TASK_DISPATCH;
|
|
||||||
pTask->dispatchType = TASK_DISPATCH__FIXED;
|
|
||||||
|
|
||||||
pTask->fixedEpDispatcher.taskId = lastLevelTask->taskId;
|
|
||||||
pTask->fixedEpDispatcher.nodeId = lastLevelTask->nodeId;
|
|
||||||
pTask->fixedEpDispatcher.epSet = lastLevelTask->epSet;
|
|
||||||
}
|
|
||||||
|
|
||||||
// exec part
|
|
||||||
pTask->execType = TASK_EXEC__PIPE;
|
|
||||||
if (mndAssignTaskToVg(pMnode, pTrans, pTask, plan, pVgroup) < 0) {
|
|
||||||
sdbRelease(pSdb, pVgroup);
|
|
||||||
qDestroyQueryPlan(pPlan);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
sdbRelease(pSdb, pVgroup);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// merge plan
|
|
||||||
|
|
||||||
// TODO if has snode, assign to snode
|
|
||||||
|
|
||||||
// else, assign to vnode
|
|
||||||
ASSERT(plan->subplanType == SUBPLAN_TYPE_MERGE);
|
|
||||||
SStreamTask* pTask = tNewSStreamTask(pStream->uid);
|
|
||||||
mndAddTaskToTaskSet(taskOneLevel, pTask);
|
|
||||||
|
|
||||||
// source part, currently only support multi source
|
|
||||||
pTask->sourceType = TASK_SOURCE__PIPE;
|
|
||||||
pTask->inputType = TASK_INPUT_TYPE__DATA_BLOCK;
|
|
||||||
|
|
||||||
// sink part
|
|
||||||
pTask->sinkType = TASK_SINK__NONE;
|
|
||||||
|
|
||||||
// dispatch part
|
|
||||||
ASSERT(hasExtraSink);
|
|
||||||
/*pTask->dispatchType = TASK_DISPATCH__NONE;*/
|
|
||||||
#if 1
|
|
||||||
|
|
||||||
if (hasExtraSink) {
|
|
||||||
// add dispatcher
|
|
||||||
if (pStream->fixedSinkVgId == 0) {
|
|
||||||
pTask->dispatchType = TASK_DISPATCH__SHUFFLE;
|
|
||||||
|
|
||||||
pTask->dispatchMsgType = TDMT_STREAM_TASK_DISPATCH;
|
|
||||||
SDbObj* pDb = mndAcquireDb(pMnode, pStream->targetDb);
|
|
||||||
ASSERT(pDb);
|
|
||||||
if (mndExtractDbInfo(pMnode, pDb, &pTask->shuffleDispatcher.dbInfo, NULL) < 0) {
|
|
||||||
sdbRelease(pSdb, pDb);
|
|
||||||
qDestroyQueryPlan(pPlan);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
sdbRelease(pSdb, pDb);
|
|
||||||
|
|
||||||
// put taskId to useDbRsp
|
|
||||||
// TODO: optimize
|
|
||||||
SArray* pVgs = pTask->shuffleDispatcher.dbInfo.pVgroupInfos;
|
|
||||||
int32_t sz = taosArrayGetSize(pVgs);
|
|
||||||
SArray* sinkLv = taosArrayGetP(pStream->tasks, 0);
|
|
||||||
int32_t sinkLvSize = taosArrayGetSize(sinkLv);
|
|
||||||
for (int32_t i = 0; i < sz; i++) {
|
|
||||||
SVgroupInfo* pVgInfo = taosArrayGet(pVgs, i);
|
|
||||||
for (int32_t j = 0; j < sinkLvSize; j++) {
|
|
||||||
SStreamTask* pLastLevelTask = taosArrayGetP(sinkLv, j);
|
|
||||||
if (pLastLevelTask->nodeId == pVgInfo->vgId) {
|
|
||||||
pVgInfo->taskId = pLastLevelTask->taskId;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
pTask->dispatchType = TASK_DISPATCH__FIXED;
|
|
||||||
/*pTask->dispatchMsgType = TDMT_VND_TASK_WRITE_EXEC;*/
|
|
||||||
pTask->dispatchMsgType = TDMT_STREAM_TASK_DISPATCH;
|
|
||||||
SArray* pArray = taosArrayGetP(pStream->tasks, 0);
|
|
||||||
// one sink only
|
|
||||||
ASSERT(taosArrayGetSize(pArray) == 1);
|
|
||||||
SStreamTask* lastLevelTask = taosArrayGetP(pArray, 0);
|
|
||||||
pTask->fixedEpDispatcher.taskId = lastLevelTask->taskId;
|
|
||||||
pTask->fixedEpDispatcher.nodeId = lastLevelTask->nodeId;
|
|
||||||
pTask->fixedEpDispatcher.epSet = lastLevelTask->epSet;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// exec part
|
|
||||||
pTask->execType = TASK_EXEC__MERGE;
|
|
||||||
SVgObj* pVgroup = mndSchedFetchOneVg(pMnode, pStream->dbUid);
|
|
||||||
ASSERT(pVgroup);
|
|
||||||
if (mndAssignTaskToVg(pMnode, pTrans, pTask, plan, pVgroup) < 0) {
|
|
||||||
sdbRelease(pSdb, pVgroup);
|
|
||||||
qDestroyQueryPlan(pPlan);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
sdbRelease(pSdb, pVgroup);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
if (totLevel == 2) {
|
|
||||||
void* pIter = NULL;
|
|
||||||
while (1) {
|
|
||||||
SVgObj* pVgroup;
|
|
||||||
pIter = sdbFetch(pSdb, SDB_VGROUP, pIter, (void**)&pVgroup);
|
|
||||||
if (pIter == NULL) break;
|
|
||||||
if (pVgroup->dbUid != pStream->dbUid) {
|
|
||||||
sdbRelease(pSdb, pVgroup);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
SStreamTask* pTask = tNewSStreamTask(pStream->uid);
|
|
||||||
|
|
||||||
// source part
|
|
||||||
pTask->sourceType = TASK_SOURCE__MERGE;
|
|
||||||
pTask->inputType = TASK_INPUT_TYPE__DATA_BLOCK;
|
|
||||||
|
|
||||||
// sink part
|
|
||||||
pTask->sinkType = TASK_SINK__NONE;
|
|
||||||
|
|
||||||
// dispatch part
|
|
||||||
pTask->dispatchType = TASK_DISPATCH__NONE;
|
|
||||||
|
|
||||||
// exec part
|
|
||||||
pTask->execType = TASK_EXEC__NONE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// free memory
|
|
||||||
qDestroyQueryPlan(pPlan);
|
qDestroyQueryPlan(pPlan);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -395,13 +395,13 @@ static void *mndBuildVCreateStbReq(SMnode *pMnode, SVgObj *pVgroup, SStbObj *pSt
|
||||||
req.pRSmaParam.xFilesFactor = pStb->xFilesFactor;
|
req.pRSmaParam.xFilesFactor = pStb->xFilesFactor;
|
||||||
req.pRSmaParam.delay = pStb->delay;
|
req.pRSmaParam.delay = pStb->delay;
|
||||||
if (pStb->ast1Len > 0) {
|
if (pStb->ast1Len > 0) {
|
||||||
if (mndConvertRSmaTask(pStb->pAst1, pStb->uid, STREAM_TRIGGER_AT_ONCE, 0, &req.pRSmaParam.qmsg1, &req.pRSmaParam.qmsg1Len,
|
if (mndConvertRsmaTask(&req.pRSmaParam.qmsg1, &req.pRSmaParam.qmsg1Len, pStb->pAst1, pStb->uid, STREAM_TRIGGER_AT_ONCE, 0,
|
||||||
req.pRSmaParam.xFilesFactor) != TSDB_CODE_SUCCESS) {
|
req.pRSmaParam.xFilesFactor) != TSDB_CODE_SUCCESS) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (pStb->ast2Len > 0) {
|
if (pStb->ast2Len > 0) {
|
||||||
if (mndConvertRSmaTask(pStb->pAst2, pStb->uid, STREAM_TRIGGER_AT_ONCE, 0, &req.pRSmaParam.qmsg2, &req.pRSmaParam.qmsg2Len,
|
if (mndConvertRsmaTask(&req.pRSmaParam.qmsg2, &req.pRSmaParam.qmsg2Len, pStb->pAst2, pStb->uid, STREAM_TRIGGER_AT_ONCE, 0,
|
||||||
req.pRSmaParam.xFilesFactor) != TSDB_CODE_SUCCESS) {
|
req.pRSmaParam.xFilesFactor) != TSDB_CODE_SUCCESS) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -269,7 +269,7 @@ int32_t mndAddStreamToTrans(SMnode *pMnode, SStreamObj *pStream, const char *ast
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mndScheduleStream1(pMnode, pTrans, pStream) < 0) {
|
if (mndScheduleStream(pMnode, pTrans, pStream) < 0) {
|
||||||
mError("stream:%ld, schedule stream since %s", pStream->uid, terrstr());
|
mError("stream:%ld, schedule stream since %s", pStream->uid, terrstr());
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -76,7 +76,7 @@ static int32_t setValueByBindParam(SValueNode* pVal, TAOS_MULTI_BIND* pParam) {
|
||||||
int32_t inputSize = (NULL != pParam->length ? *(pParam->length) : tDataTypes[pParam->buffer_type].bytes);
|
int32_t inputSize = (NULL != pParam->length ? *(pParam->length) : tDataTypes[pParam->buffer_type].bytes);
|
||||||
pVal->node.resType.type = pParam->buffer_type;
|
pVal->node.resType.type = pParam->buffer_type;
|
||||||
pVal->node.resType.bytes = inputSize;
|
pVal->node.resType.bytes = inputSize;
|
||||||
|
|
||||||
switch (pParam->buffer_type) {
|
switch (pParam->buffer_type) {
|
||||||
case TSDB_DATA_TYPE_VARCHAR:
|
case TSDB_DATA_TYPE_VARCHAR:
|
||||||
case TSDB_DATA_TYPE_VARBINARY:
|
case TSDB_DATA_TYPE_VARBINARY:
|
||||||
|
@ -186,7 +186,7 @@ int32_t qExtractResultSchema(const SNode* pRoot, int32_t* numOfCols, SSchema** p
|
||||||
return extractResultSchema(pRoot, numOfCols, pSchema);
|
return extractResultSchema(pRoot, numOfCols, pSchema);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t qSetSTableIdForRSma(SNode* pStmt, int64_t uid) {
|
int32_t qSetSTableIdForRsma(SNode* pStmt, int64_t uid) {
|
||||||
if (QUERY_NODE_SELECT_STMT == nodeType(pStmt)) {
|
if (QUERY_NODE_SELECT_STMT == nodeType(pStmt)) {
|
||||||
SNode* pTable = ((SSelectStmt*)pStmt)->pFromTable;
|
SNode* pTable = ((SSelectStmt*)pStmt)->pFromTable;
|
||||||
if (QUERY_NODE_REAL_TABLE == nodeType(pTable)) {
|
if (QUERY_NODE_REAL_TABLE == nodeType(pTable)) {
|
||||||
|
|
|
@ -23,6 +23,10 @@ from util.sql import *
|
||||||
import threading
|
import threading
|
||||||
from util.types import TDSmlProtocolType, TDSmlTimestampType
|
from util.types import TDSmlProtocolType, TDSmlTimestampType
|
||||||
from util.common import tdCom
|
from util.common import tdCom
|
||||||
|
import platform
|
||||||
|
import io
|
||||||
|
if platform.system().lower() == 'windows':
|
||||||
|
sys.stdout = io.TextIOWrapper(sys.stdout.buffer,encoding='utf8')
|
||||||
|
|
||||||
class TDTestCase:
|
class TDTestCase:
|
||||||
def init(self, conn, logSql):
|
def init(self, conn, logSql):
|
||||||
|
|
|
@ -22,6 +22,10 @@ from util.sql import *
|
||||||
from util.common import tdCom
|
from util.common import tdCom
|
||||||
from util.types import TDSmlProtocolType, TDSmlTimestampType
|
from util.types import TDSmlProtocolType, TDSmlTimestampType
|
||||||
import threading
|
import threading
|
||||||
|
import platform
|
||||||
|
import io
|
||||||
|
if platform.system().lower() == 'windows':
|
||||||
|
sys.stdout = io.TextIOWrapper(sys.stdout.buffer,encoding='utf8')
|
||||||
|
|
||||||
class TDTestCase:
|
class TDTestCase:
|
||||||
def init(self, conn, logSql):
|
def init(self, conn, logSql):
|
||||||
|
|
|
@ -1,94 +1,93 @@
|
||||||
|
|
||||||
@REM python3 .\test.py -f 0-others\taosShell.py
|
python3 .\test.py -f 0-others\taosShell.py
|
||||||
@REM python3 .\test.py -f 0-others\taosShellError.py
|
python3 .\test.py -f 0-others\taosShellError.py
|
||||||
python3 .\test.py -f 0-others\taosShellNetChk.py
|
python3 .\test.py -f 0-others\taosShellNetChk.py
|
||||||
python3 .\test.py -f 0-others\telemetry.py
|
python3 .\test.py -f 0-others\telemetry.py
|
||||||
python3 .\test.py -f 0-others\taosdMonitor.py
|
python3 .\test.py -f 0-others\taosdMonitor.py
|
||||||
python3 .\test.py -f 0-others\udfTest.py
|
python3 .\test.py -f 0-others\udfTest.py
|
||||||
python3 .\test.py -f 0-others\udf_create.py
|
python3 .\test.py -f 0-others\udf_create.py
|
||||||
@REM python3 .\test.py -f 0-others\udf_restart_taosd.py
|
@REM python3 .\test.py -f 0-others\udf_restart_taosd.py
|
||||||
@REM python3 .\test.py -f 0-others\cachelast.py
|
python3 .\test.py -f 0-others\cachelast.py
|
||||||
|
|
||||||
@REM python3 .\test.py -f 0-others\user_control.py
|
python3 .\test.py -f 0-others\user_control.py
|
||||||
@REM python3 .\test.py -f 0-others\fsync.py
|
python3 .\test.py -f 0-others\fsync.py
|
||||||
|
|
||||||
@REM python3 .\test.py -f 1-insert\influxdb_line_taosc_insert.py
|
python3 .\test.py -f 1-insert\influxdb_line_taosc_insert.py
|
||||||
@REM python3 .\test.py -f 1-insert\opentsdb_telnet_line_taosc_insert.py
|
python3 .\test.py -f 1-insert\opentsdb_telnet_line_taosc_insert.py
|
||||||
@REM python3 .\test.py -f 1-insert\opentsdb_json_taosc_insert.py
|
python3 .\test.py -f 1-insert\opentsdb_json_taosc_insert.py
|
||||||
@REM #python3 .\test.py -f 1-insert\test_stmt_muti_insert_query.py
|
@REM #python3 .\test.py -f 1-insert\test_stmt_muti_insert_query.py
|
||||||
@REM python3 .\test.py -f 1-insert\alter_stable.py
|
python3 .\test.py -f 1-insert\alter_stable.py
|
||||||
@REM python3 .\test.py -f 1-insert\alter_table.py
|
python3 .\test.py -f 1-insert\alter_table.py
|
||||||
@REM python3 .\test.py -f 2-query\between.py
|
python3 .\test.py -f 2-query\between.py
|
||||||
@REM python3 .\test.py -f 2-query\distinct.py
|
python3 .\test.py -f 2-query\distinct.py
|
||||||
@REM python3 .\test.py -f 2-query\varchar.py
|
python3 .\test.py -f 2-query\varchar.py
|
||||||
@REM python3 .\test.py -f 2-query\ltrim.py
|
@REM python3 .\test.py -f 2-query\ltrim.py
|
||||||
@REM python3 .\test.py -f 2-query\rtrim.py
|
python3 .\test.py -f 2-query\rtrim.py
|
||||||
@REM python3 .\test.py -f 2-query\length.py
|
python3 .\test.py -f 2-query\length.py
|
||||||
@REM python3 .\test.py -f 2-query\char_length.py
|
python3 .\test.py -f 2-query\char_length.py
|
||||||
@REM python3 .\test.py -f 2-query\upper.py
|
python3 .\test.py -f 2-query\upper.py
|
||||||
@REM python3 .\test.py -f 2-query\lower.py
|
python3 .\test.py -f 2-query\lower.py
|
||||||
@REM python3 .\test.py -f 2-query\join.py
|
python3 .\test.py -f 2-query\join.py
|
||||||
@REM python3 .\test.py -f 2-query\join2.py
|
python3 .\test.py -f 2-query\join2.py
|
||||||
@REM python3 .\test.py -f 2-query\cast.py
|
python3 .\test.py -f 2-query\cast.py
|
||||||
@REM python3 .\test.py -f 2-query\union.py
|
python3 .\test.py -f 2-query\union.py
|
||||||
@REM python3 .\test.py -f 2-query\union1.py
|
python3 .\test.py -f 2-query\union1.py
|
||||||
@REM python3 .\test.py -f 2-query\concat.py
|
@REM python3 .\test.py -f 2-query\concat.py
|
||||||
@REM python3 .\test.py -f 2-query\concat2.py
|
python3 .\test.py -f 2-query\concat2.py
|
||||||
@REM python3 .\test.py -f 2-query\concat_ws.py
|
python3 .\test.py -f 2-query\concat_ws.py
|
||||||
@REM python3 .\test.py -f 2-query\concat_ws2.py
|
python3 .\test.py -f 2-query\concat_ws2.py
|
||||||
@REM python3 .\test.py -f 2-query\check_tsdb.py
|
@REM python3 .\test.py -f 2-query\check_tsdb.py
|
||||||
@REM python3 .\test.py -f 2-query\spread.py
|
@REM python3 .\test.py -f 2-query\spread.py
|
||||||
@REM python3 .\test.py -f 2-query\hyperloglog.py
|
@REM python3 .\test.py -f 2-query\hyperloglog.py
|
||||||
|
|
||||||
|
python3 .\test.py -f 2-query\timezone.py
|
||||||
|
python3 .\test.py -f 2-query\Now.py
|
||||||
|
python3 .\test.py -f 2-query\Today.py
|
||||||
|
python3 .\test.py -f 2-query\max.py
|
||||||
|
python3 .\test.py -f 2-query\min.py
|
||||||
|
python3 .\test.py -f 2-query\count.py
|
||||||
|
python3 .\test.py -f 2-query\last.py
|
||||||
|
python3 .\test.py -f 2-query\first.py
|
||||||
|
python3 .\test.py -f 2-query\To_iso8601.py
|
||||||
|
python3 .\test.py -f 2-query\To_unixtimestamp.py
|
||||||
|
python3 .\test.py -f 2-query\timetruncate.py
|
||||||
|
python3 .\test.py -f 2-query\diff.py
|
||||||
|
python3 .\test.py -f 2-query\Timediff.py
|
||||||
|
|
||||||
@REM python3 .\test.py -f 2-query\timezone.py
|
python3 .\test.py -f 2-query\top.py
|
||||||
@REM python3 .\test.py -f 2-query\Now.py
|
python3 .\test.py -f 2-query\bottom.py
|
||||||
@REM python3 .\test.py -f 2-query\Today.py
|
python3 .\test.py -f 2-query\percentile.py
|
||||||
@REM python3 .\test.py -f 2-query\max.py
|
python3 .\test.py -f 2-query\apercentile.py
|
||||||
@REM python3 .\test.py -f 2-query\min.py
|
python3 .\test.py -f 2-query\abs.py
|
||||||
@REM python3 .\test.py -f 2-query\count.py
|
python3 .\test.py -f 2-query\ceil.py
|
||||||
@REM python3 .\test.py -f 2-query\last.py
|
python3 .\test.py -f 2-query\floor.py
|
||||||
@REM python3 .\test.py -f 2-query\first.py
|
python3 .\test.py -f 2-query\round.py
|
||||||
@REM python3 .\test.py -f 2-query\To_iso8601.py
|
python3 .\test.py -f 2-query\log.py
|
||||||
@REM python3 .\test.py -f 2-query\To_unixtimestamp.py
|
python3 .\test.py -f 2-query\pow.py
|
||||||
@REM python3 .\test.py -f 2-query\timetruncate.py
|
python3 .\test.py -f 2-query\sqrt.py
|
||||||
@REM python3 .\test.py -f 2-query\diff.py
|
python3 .\test.py -f 2-query\sin.py
|
||||||
@REM python3 .\test.py -f 2-query\Timediff.py
|
python3 .\test.py -f 2-query\cos.py
|
||||||
|
python3 .\test.py -f 2-query\tan.py
|
||||||
@REM python3 .\test.py -f 2-query\top.py
|
python3 .\test.py -f 2-query\arcsin.py
|
||||||
@REM python3 .\test.py -f 2-query\bottom.py
|
python3 .\test.py -f 2-query\arccos.py
|
||||||
@REM python3 .\test.py -f 2-query\percentile.py
|
python3 .\test.py -f 2-query\arctan.py
|
||||||
@REM python3 .\test.py -f 2-query\apercentile.py
|
|
||||||
@REM python3 .\test.py -f 2-query\abs.py
|
|
||||||
@REM python3 .\test.py -f 2-query\ceil.py
|
|
||||||
@REM python3 .\test.py -f 2-query\floor.py
|
|
||||||
@REM python3 .\test.py -f 2-query\round.py
|
|
||||||
@REM python3 .\test.py -f 2-query\log.py
|
|
||||||
@REM python3 .\test.py -f 2-query\pow.py
|
|
||||||
@REM python3 .\test.py -f 2-query\sqrt.py
|
|
||||||
@REM python3 .\test.py -f 2-query\sin.py
|
|
||||||
@REM python3 .\test.py -f 2-query\cos.py
|
|
||||||
@REM python3 .\test.py -f 2-query\tan.py
|
|
||||||
@REM python3 .\test.py -f 2-query\arcsin.py
|
|
||||||
@REM python3 .\test.py -f 2-query\arccos.py
|
|
||||||
@REM python3 .\test.py -f 2-query\arctan.py
|
|
||||||
@REM python3 .\test.py -f 2-query\query_cols_tags_and_or.py
|
@REM python3 .\test.py -f 2-query\query_cols_tags_and_or.py
|
||||||
@REM # python3 .\test.py -f 2-query\nestedQuery.py
|
@REM # python3 .\test.py -f 2-query\nestedQuery.py
|
||||||
@REM # TD-15983 subquery output duplicate name column.
|
@REM # TD-15983 subquery output duplicate name column.
|
||||||
@REM # Please Xiangyang Guo modify the following script
|
@REM # Please Xiangyang Guo modify the following script
|
||||||
@REM # python3 .\test.py -f 2-query\nestedQuery_str.py
|
@REM # python3 .\test.py -f 2-query\nestedQuery_str.py
|
||||||
|
|
||||||
@REM python3 .\test.py -f 2-query\avg.py
|
python3 .\test.py -f 2-query\avg.py
|
||||||
@REM python3 .\test.py -f 2-query\elapsed.py
|
python3 .\test.py -f 2-query\elapsed.py
|
||||||
@REM python3 .\test.py -f 2-query\csum.py
|
@REM python3 .\test.py -f 2-query\csum.py
|
||||||
@REM python3 .\test.py -f 2-query\mavg.py
|
python3 .\test.py -f 2-query\mavg.py
|
||||||
@REM python3 .\test.py -f 2-query\diff.py
|
python3 .\test.py -f 2-query\diff.py
|
||||||
@REM python3 .\test.py -f 2-query\sample.py
|
python3 .\test.py -f 2-query\sample.py
|
||||||
@REM python3 .\test.py -f 2-query\function_diff.py
|
@REM python3 .\test.py -f 2-query\function_diff.py
|
||||||
@REM python3 .\test.py -f 2-query\unique.py
|
python3 .\test.py -f 2-query\unique.py
|
||||||
@REM python3 .\test.py -f 2-query\stateduration.py
|
python3 .\test.py -f 2-query\stateduration.py
|
||||||
@REM python3 .\test.py -f 2-query\function_stateduration.py
|
python3 .\test.py -f 2-query\function_stateduration.py
|
||||||
@REM python3 .\test.py -f 2-query\statecount.py
|
python3 .\test.py -f 2-query\statecount.py
|
||||||
|
|
||||||
@REM python3 .\test.py -f 7-tmq\basic5.py
|
@REM python3 .\test.py -f 7-tmq\basic5.py
|
||||||
@REM python3 .\test.py -f 7-tmq\subscribeDb.py
|
@REM python3 .\test.py -f 7-tmq\subscribeDb.py
|
||||||
|
@ -100,4 +99,4 @@ python3 .\test.py -f 0-others\udf_create.py
|
||||||
@REM python3 .\test.py -f 7-tmq\subscribeStb2.py
|
@REM python3 .\test.py -f 7-tmq\subscribeStb2.py
|
||||||
@REM python3 .\test.py -f 7-tmq\subscribeStb3.py
|
@REM python3 .\test.py -f 7-tmq\subscribeStb3.py
|
||||||
@REM python3 .\test.py -f 7-tmq\subscribeStb4.py
|
@REM python3 .\test.py -f 7-tmq\subscribeStb4.py
|
||||||
@REM python3 .\test.py -f 7-tmq\db.py
|
@REM python3 .\test.py -f 7-tmq\db.py
|
|
@ -98,7 +98,7 @@ python3 ./test.py -f 2-query/statecount.py
|
||||||
python3 ./test.py -f 7-tmq/basic5.py
|
python3 ./test.py -f 7-tmq/basic5.py
|
||||||
python3 ./test.py -f 7-tmq/subscribeDb.py
|
python3 ./test.py -f 7-tmq/subscribeDb.py
|
||||||
python3 ./test.py -f 7-tmq/subscribeDb0.py
|
python3 ./test.py -f 7-tmq/subscribeDb0.py
|
||||||
python3 ./test.py -f 7-tmq/subscribeDb1.py
|
#python3 ./test.py -f 7-tmq/subscribeDb1.py
|
||||||
python3 ./test.py -f 7-tmq/subscribeStb.py
|
python3 ./test.py -f 7-tmq/subscribeStb.py
|
||||||
python3 ./test.py -f 7-tmq/subscribeStb0.py
|
python3 ./test.py -f 7-tmq/subscribeStb0.py
|
||||||
python3 ./test.py -f 7-tmq/subscribeStb1.py
|
python3 ./test.py -f 7-tmq/subscribeStb1.py
|
||||||
|
|
|
@ -0,0 +1,103 @@
|
||||||
|
|
||||||
|
@REM python3 .\test.py -f 0-others\taosShell.py
|
||||||
|
@REM python3 .\test.py -f 0-others\taosShellError.py
|
||||||
|
python3 .\test.py -f 0-others\taosShellNetChk.py
|
||||||
|
python3 .\test.py -f 0-others\telemetry.py
|
||||||
|
python3 .\test.py -f 0-others\taosdMonitor.py
|
||||||
|
python3 .\test.py -f 0-others\udfTest.py
|
||||||
|
python3 .\test.py -f 0-others\udf_create.py
|
||||||
|
@REM python3 .\test.py -f 0-others\udf_restart_taosd.py
|
||||||
|
@REM python3 .\test.py -f 0-others\cachelast.py
|
||||||
|
|
||||||
|
@REM python3 .\test.py -f 0-others\user_control.py
|
||||||
|
@REM python3 .\test.py -f 0-others\fsync.py
|
||||||
|
|
||||||
|
@REM python3 .\test.py -f 1-insert\influxdb_line_taosc_insert.py
|
||||||
|
@REM python3 .\test.py -f 1-insert\opentsdb_telnet_line_taosc_insert.py
|
||||||
|
@REM python3 .\test.py -f 1-insert\opentsdb_json_taosc_insert.py
|
||||||
|
@REM #python3 .\test.py -f 1-insert\test_stmt_muti_insert_query.py
|
||||||
|
@REM python3 .\test.py -f 1-insert\alter_stable.py
|
||||||
|
@REM python3 .\test.py -f 1-insert\alter_table.py
|
||||||
|
@REM python3 .\test.py -f 2-query\between.py
|
||||||
|
@REM python3 .\test.py -f 2-query\distinct.py
|
||||||
|
@REM python3 .\test.py -f 2-query\varchar.py
|
||||||
|
@REM python3 .\test.py -f 2-query\ltrim.py
|
||||||
|
@REM python3 .\test.py -f 2-query\rtrim.py
|
||||||
|
@REM python3 .\test.py -f 2-query\length.py
|
||||||
|
@REM python3 .\test.py -f 2-query\char_length.py
|
||||||
|
@REM python3 .\test.py -f 2-query\upper.py
|
||||||
|
@REM python3 .\test.py -f 2-query\lower.py
|
||||||
|
@REM python3 .\test.py -f 2-query\join.py
|
||||||
|
@REM python3 .\test.py -f 2-query\join2.py
|
||||||
|
@REM python3 .\test.py -f 2-query\cast.py
|
||||||
|
@REM python3 .\test.py -f 2-query\union.py
|
||||||
|
@REM python3 .\test.py -f 2-query\union1.py
|
||||||
|
@REM python3 .\test.py -f 2-query\concat.py
|
||||||
|
@REM python3 .\test.py -f 2-query\concat2.py
|
||||||
|
@REM python3 .\test.py -f 2-query\concat_ws.py
|
||||||
|
@REM python3 .\test.py -f 2-query\concat_ws2.py
|
||||||
|
@REM python3 .\test.py -f 2-query\check_tsdb.py
|
||||||
|
@REM python3 .\test.py -f 2-query\spread.py
|
||||||
|
@REM python3 .\test.py -f 2-query\hyperloglog.py
|
||||||
|
|
||||||
|
|
||||||
|
@REM python3 .\test.py -f 2-query\timezone.py
|
||||||
|
@REM python3 .\test.py -f 2-query\Now.py
|
||||||
|
@REM python3 .\test.py -f 2-query\Today.py
|
||||||
|
@REM python3 .\test.py -f 2-query\max.py
|
||||||
|
@REM python3 .\test.py -f 2-query\min.py
|
||||||
|
@REM python3 .\test.py -f 2-query\count.py
|
||||||
|
@REM python3 .\test.py -f 2-query\last.py
|
||||||
|
@REM python3 .\test.py -f 2-query\first.py
|
||||||
|
@REM python3 .\test.py -f 2-query\To_iso8601.py
|
||||||
|
@REM python3 .\test.py -f 2-query\To_unixtimestamp.py
|
||||||
|
@REM python3 .\test.py -f 2-query\timetruncate.py
|
||||||
|
@REM python3 .\test.py -f 2-query\diff.py
|
||||||
|
@REM python3 .\test.py -f 2-query\Timediff.py
|
||||||
|
|
||||||
|
@REM python3 .\test.py -f 2-query\top.py
|
||||||
|
@REM python3 .\test.py -f 2-query\bottom.py
|
||||||
|
@REM python3 .\test.py -f 2-query\percentile.py
|
||||||
|
@REM python3 .\test.py -f 2-query\apercentile.py
|
||||||
|
@REM python3 .\test.py -f 2-query\abs.py
|
||||||
|
@REM python3 .\test.py -f 2-query\ceil.py
|
||||||
|
@REM python3 .\test.py -f 2-query\floor.py
|
||||||
|
@REM python3 .\test.py -f 2-query\round.py
|
||||||
|
@REM python3 .\test.py -f 2-query\log.py
|
||||||
|
@REM python3 .\test.py -f 2-query\pow.py
|
||||||
|
@REM python3 .\test.py -f 2-query\sqrt.py
|
||||||
|
@REM python3 .\test.py -f 2-query\sin.py
|
||||||
|
@REM python3 .\test.py -f 2-query\cos.py
|
||||||
|
@REM python3 .\test.py -f 2-query\tan.py
|
||||||
|
@REM python3 .\test.py -f 2-query\arcsin.py
|
||||||
|
@REM python3 .\test.py -f 2-query\arccos.py
|
||||||
|
@REM python3 .\test.py -f 2-query\arctan.py
|
||||||
|
@REM python3 .\test.py -f 2-query\query_cols_tags_and_or.py
|
||||||
|
@REM # python3 .\test.py -f 2-query\nestedQuery.py
|
||||||
|
@REM # TD-15983 subquery output duplicate name column.
|
||||||
|
@REM # Please Xiangyang Guo modify the following script
|
||||||
|
@REM # python3 .\test.py -f 2-query\nestedQuery_str.py
|
||||||
|
|
||||||
|
@REM python3 .\test.py -f 2-query\avg.py
|
||||||
|
@REM python3 .\test.py -f 2-query\elapsed.py
|
||||||
|
@REM python3 .\test.py -f 2-query\csum.py
|
||||||
|
@REM python3 .\test.py -f 2-query\mavg.py
|
||||||
|
@REM python3 .\test.py -f 2-query\diff.py
|
||||||
|
@REM python3 .\test.py -f 2-query\sample.py
|
||||||
|
@REM python3 .\test.py -f 2-query\function_diff.py
|
||||||
|
@REM python3 .\test.py -f 2-query\unique.py
|
||||||
|
@REM python3 .\test.py -f 2-query\stateduration.py
|
||||||
|
@REM python3 .\test.py -f 2-query\function_stateduration.py
|
||||||
|
@REM python3 .\test.py -f 2-query\statecount.py
|
||||||
|
|
||||||
|
@REM python3 .\test.py -f 7-tmq\basic5.py
|
||||||
|
@REM python3 .\test.py -f 7-tmq\subscribeDb.py
|
||||||
|
@REM python3 .\test.py -f 7-tmq\subscribeDb0.py
|
||||||
|
@REM python3 .\test.py -f 7-tmq\subscribeDb1.py
|
||||||
|
@REM python3 .\test.py -f 7-tmq\subscribeStb.py
|
||||||
|
@REM python3 .\test.py -f 7-tmq\subscribeStb0.py
|
||||||
|
@REM python3 .\test.py -f 7-tmq\subscribeStb1.py
|
||||||
|
@REM python3 .\test.py -f 7-tmq\subscribeStb2.py
|
||||||
|
@REM python3 .\test.py -f 7-tmq\subscribeStb3.py
|
||||||
|
@REM python3 .\test.py -f 7-tmq\subscribeStb4.py
|
||||||
|
@REM python3 .\test.py -f 7-tmq\db.py
|
|
@ -2,26 +2,42 @@
|
||||||
SETLOCAL EnableDelayedExpansion
|
SETLOCAL EnableDelayedExpansion
|
||||||
for /F "tokens=1,2 delims=#" %%a in ('"prompt #$H#$E# & echo on & for %%b in (1) do rem"') do ( set "DEL=%%a")
|
for /F "tokens=1,2 delims=#" %%a in ('"prompt #$H#$E# & echo on & for %%b in (1) do rem"') do ( set "DEL=%%a")
|
||||||
set /a a=0
|
set /a a=0
|
||||||
|
if %1 == full (
|
||||||
|
echo Windows Taosd Full Test
|
||||||
|
set /a exitNum=0
|
||||||
|
for /F "usebackq tokens=*" %%i in (fulltest.bat) do (
|
||||||
|
for /f "tokens=1* delims= " %%a in ("%%i") do if not "%%a" == "@REM" (
|
||||||
|
set /a a+=1
|
||||||
|
echo !a! Processing %%i
|
||||||
|
call :GetTimeSeconds !time!
|
||||||
|
set time1=!_timeTemp!
|
||||||
|
echo Start at !time!
|
||||||
|
call %%i ARG1 > result_!a!.txt 2>error_!a!.txt
|
||||||
|
if errorlevel 1 ( call :colorEcho 0c "failed" &echo. && set /a exitNum=8 ) else ( call :colorEcho 0a "Success" &echo. )
|
||||||
|
)
|
||||||
|
)
|
||||||
|
exit !exitNum!
|
||||||
|
)
|
||||||
echo Windows Taosd Test
|
echo Windows Taosd Test
|
||||||
for /F "usebackq tokens=*" %%i in (fulltest.bat) do (
|
for /F "usebackq tokens=*" %%i in (simpletest.bat) do (
|
||||||
for /f "tokens=1* delims= " %%a in ("%%i") do if not "%%a" == "@REM" (
|
for /f "tokens=1* delims= " %%a in ("%%i") do if not "%%a" == "@REM" (
|
||||||
echo Processing %%i
|
|
||||||
call :GetTimeSeconds %time%
|
|
||||||
set time1=!_timeTemp!
|
|
||||||
echo Start at %time%
|
|
||||||
set /a a+=1
|
set /a a+=1
|
||||||
|
echo !a! Processing %%i
|
||||||
|
call :GetTimeSeconds !time!
|
||||||
|
set time1=!_timeTemp!
|
||||||
|
echo Start at !time!
|
||||||
call %%i ARG1 > result_!a!.txt 2>error_!a!.txt
|
call %%i ARG1 > result_!a!.txt 2>error_!a!.txt
|
||||||
if errorlevel 1 ( call :colorEcho 0c "failed" &echo. && echo result: && cat result_!a!.txt && echo error: && cat error_!a!.txt && exit 8 ) else ( call :colorEcho 0a "Success" &echo. )
|
if errorlevel 1 ( call :colorEcho 0c "failed" &echo. && echo result: && cat result_!a!.txt && echo error: && cat error_!a!.txt && exit 8 ) else ( call :colorEcho 0a "Success" &echo. )
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
@REM echo Linux Taosd Test
|
@REM echo Linux Taosd Test
|
||||||
@REM for /F "usebackq tokens=*" %%i in (fulltest.bat) do (
|
@REM for /F "usebackq tokens=*" %%i in (simpletest.bat) do (
|
||||||
@REM for /f "tokens=1* delims= " %%a in ("%%i") do if not "%%a" == "@REM" (
|
@REM for /f "tokens=1* delims= " %%a in ("%%i") do if not "%%a" == "@REM" (
|
||||||
@REM echo Processing %%i
|
|
||||||
@REM call :GetTimeSeconds %time%
|
|
||||||
@REM set time1=!_timeTemp!
|
|
||||||
@REM echo Start at %time%
|
|
||||||
@REM set /a a+=1
|
@REM set /a a+=1
|
||||||
|
@REM echo !a! Processing %%i
|
||||||
|
@REM call :GetTimeSeconds !time!
|
||||||
|
@REM set time1=!_timeTemp!
|
||||||
|
@REM echo Start at !time!
|
||||||
@REM call %%i ARG1 -m %1 > result_!a!.txt 2>error_!a!.txt
|
@REM call %%i ARG1 -m %1 > result_!a!.txt 2>error_!a!.txt
|
||||||
@REM if errorlevel 1 ( call :colorEcho 0c "failed" &echo. && echo result: && cat result_!a!.txt && echo error: && cat error_!a!.txt && exit 8 ) else ( call :colorEcho 0a "Success" &echo. )
|
@REM if errorlevel 1 ( call :colorEcho 0c "failed" &echo. && echo result: && cat result_!a!.txt && echo error: && cat error_!a!.txt && exit 8 ) else ( call :colorEcho 0a "Success" &echo. )
|
||||||
@REM )
|
@REM )
|
||||||
|
@ -57,5 +73,5 @@ for %%a in (%tt%) do (
|
||||||
)
|
)
|
||||||
set /a index=index+1
|
set /a index=index+1
|
||||||
)
|
)
|
||||||
set /a _timeTemp=(%hh%*60+%mm%)*60+%ss%
|
set /a _timeTemp=(%hh%*60+%mm%)*60+%ss% || echo hh:%hh% mm:%mm% ss:%ss%
|
||||||
goto :eof
|
goto :eof
|
Loading…
Reference in New Issue