/* * Copyright (c) 2019 TAOS Data, Inc. * * This program is free software: you can use, redistribute, and/or modify * it under the terms of the GNU Affero General Public License, version 3 * or later ("AGPL"), as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ #define _DEFAULT_SOURCE #include "os.h" #include "sim.h" #include "taos.h" #include "tglobal.h" #include "ttimer.h" #include "tutil.h" #include "tsocket.h" #include "taoserror.h" #undef TAOS_MEM_CHECK SScript *simScriptList[MAX_MAIN_SCRIPT_NUM]; SCommand simCmdList[SIM_CMD_END]; int32_t simScriptPos = -1; int32_t simScriptSucced = 0; int32_t simDebugFlag = 135; void simCloseTaosdConnect(SScript *script); char simHostName[128]; extern bool simExecSuccess; char *simParseArbitratorName(char *varName) { static char hostName[140]; sprintf(hostName, "%s:%d", simHostName, 8000); return hostName; } char *simParseHostName(char *varName) { static char hostName[140]; int32_t index = atoi(varName + 8); int32_t port = 7100; switch (index) { case 1: port = 7100; break; case 2: port = 7200; break; case 3: port = 7300; break; case 4: port = 7400; break; case 5: port = 7500; break; case 6: port = 7600; break; case 7: port = 7700; break; case 8: port = 7800; break; case 9: port = 7900; break; } sprintf(hostName, "'%s:%d'", simHostName, port); // simInfo("hostName:%s", hostName); return hostName; } bool simSystemInit() { taos_init(); taosGetFqdn(simHostName); simInitsimCmdList(); memset(simScriptList, 0, sizeof(SScript *) * MAX_MAIN_SCRIPT_NUM); return true; } void simSystemCleanUp() {} void simFreeScript(SScript *script) { if (script->type == SIM_SCRIPT_TYPE_MAIN) { simInfo("script:%s, background script num:%d, stop them", script->fileName, script->bgScriptLen); for (int32_t i = 0; i < script->bgScriptLen; ++i) { SScript *bgScript = script->bgScripts[i]; simDebug("script:%s, is background script, set stop flag", bgScript->fileName); bgScript->killed = true; if (taosCheckPthreadValid(bgScript->bgPid)) { pthread_join(bgScript->bgPid, NULL); } simDebug("script:%s, background thread joined", bgScript->fileName); taos_close(bgScript->taos); tfree(bgScript->lines); tfree(bgScript->optionBuffer); tfree(bgScript); } simDebug("script:%s, is cleaned", script->fileName); taos_close(script->taos); tfree(script->lines); tfree(script->optionBuffer); tfree(script); } } SScript *simProcessCallOver(SScript *script) { if (script->type == SIM_SCRIPT_TYPE_MAIN) { simDebug("script:%s, is main script, set stop flag", script->fileName); if (script->killed) { simExecSuccess = false; simInfo("script:" FAILED_PREFIX "%s" FAILED_POSTFIX ", " FAILED_PREFIX "failed" FAILED_POSTFIX ", error:%s", script->fileName, script->error); return NULL; } else { simExecSuccess = true; simInfo("script:" SUCCESS_PREFIX "%s" SUCCESS_POSTFIX ", " SUCCESS_PREFIX "success" SUCCESS_POSTFIX, script->fileName); simCloseTaosdConnect(script); simScriptSucced++; simScriptPos--; simFreeScript(script); if (simScriptPos == -1) { simInfo("----------------------------------------------------------------------"); simInfo("Simulation Test Done, " SUCCESS_PREFIX "%d" SUCCESS_POSTFIX " Passed:\n", simScriptSucced); return NULL; } return simScriptList[simScriptPos]; } } else { simDebug("script:%s, is stopped", script->fileName); simFreeScript(script); return NULL; } } void *simExecuteScript(void *inputScript) { SScript *script = (SScript *)inputScript; while (1) { if (script->type == SIM_SCRIPT_TYPE_MAIN) { script = simScriptList[simScriptPos]; } if (script->killed || script->linePos >= script->numOfLines) { script = simProcessCallOver(script); if (script == NULL) break; } else { SCmdLine *line = &script->lines[script->linePos]; char * option = script->optionBuffer + line->optionOffset; simDebug("script:%s, line:%d with option \"%s\"", script->fileName, line->lineNum, option); SCommand *cmd = &simCmdList[line->cmdno]; int32_t ret = (*(cmd->executeCmd))(script, option); if (!ret) { script->killed = true; } } } simInfo("thread is stopped"); return NULL; }