123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323 |
- #include "StdAfx.h"
- #include "SATExecutor.h"
- #include "PythonExecutor.h"
- #include "CharEncoding.h"
- #include "SynSerial.h"
- CSATExecutor::CSATExecutor(void)
- {
- m_bLogin = FALSE;
- m_hEventHearbeat = NULL;
- m_hThreadHearbeat = NULL;
- m_hEventExcuteScript = NULL;
- m_hThreadExcuteScript = NULL;
- }
- CSATExecutor::~CSATExecutor(void)
- {
- }
- bool CSATExecutor::IsTaskExist(SATHTTP::STTask &task)
- {
- bool found = false;
- std::list<SATHTTP::STTask>::iterator it = m_vtTask.begin();
- for ( ; it != m_vtTask.end(); it++ ) {
- // 不要使用nTaskId,这个值没啥用;
- if ( it->Id == task.Id ) {
- found = true;
- break;
- }
- }
- return found;
- }
- SATHTTP::STTask* CSATExecutor::IsThereATaskInProcess()
- {
- std::list<SATHTTP::STTask>::iterator it = m_vtTask.begin();
- for ( ; it != m_vtTask.end(); it++ ) {
- // 执行中的任务;
- if ( it->_nExecutionState == SATHTTP::INEXECUTED ) {
- return &(*it);
- }
- }
- return NULL;
- }
- SATHTTP::STTask* CSATExecutor::GetFreeTask()
- {
- std::list<SATHTTP::STTask>::iterator it = m_vtTask.begin();
- for ( ; it != m_vtTask.end(); it++ ) {
- // 未执行的任务;
- if ( it->_nExecutionState == SATHTTP::UNEXECUTED ) {
- return &(*it);
- }
- }
- return NULL;
- }
- void CSATExecutor::DelFinishedTask()
- {
- AutoThreadSection ats(&m_csTask);
- std::list<SATHTTP::STTask>::iterator it = m_vtTask.begin();
- for ( ; it != m_vtTask.end(); it++ ) {
- // 状态为2的完成任务;
- if ( it->_nExecutionState == SATHTTP::EXECUTED ) {
- GLOBAL::WriteTextLog("==>删除已完成任务:%s", it->Job.strUniqueId.c_str());
- // 删除所有执行器对象;
- for (std::vector<SATHTTP::STCase>::iterator _case = it->Job.vtCases.begin(); _case != it->Job.vtCases.end(); _case++ ) {
- if ( _case->_pExcutor )
- delete _case->_pExcutor;
- _case->_pExcutor = NULL;
- }
- m_vtTask.erase(it);
- break;
- }
- }
- }
- SATHTTP::STCase* CSATExecutor::IsCaseScriptProcess(std::vector<SATHTTP::STCase> &vtCases)
- {
- std::vector<SATHTTP::STCase>::iterator it = vtCases.begin();
- for ( ; it != vtCases.end(); it++) {
- // 执行中的脚本;
- if ( it->_nExecutionState == SATHTTP::INEXECUTED ) {
- return &(*it);
- }
- }
- return NULL;
- }
- SATHTTP::STCase* CSATExecutor::GetFreeCaseScript(std::vector<SATHTTP::STCase> &vtCases)
- {
- std::vector<SATHTTP::STCase>::iterator it = vtCases.begin();
- for ( ; it != vtCases.end(); it++) {
- // 未执行的脚本;
- if ( it->_nExecutionState == SATHTTP::UNEXECUTED ) {
- return &(*it);
- }
- }
- return NULL;
- }
- SATHTTP::STCase* CSATExecutor::ExecuteFreeCaseScript(SATHTTP::STTask* pTask)
- {
- // 多取未执行的脚本;
- SATHTTP::STCase* pCase = GetFreeCaseScript(pTask->Job.vtCases);
- if (pCase) {
- if ( !pCase->_pExcutor ) {
- CPythonExecutor *pExcutor = new CPythonExecutor();
- if ( pExcutor ) {
- pCase->_pExcutor = pExcutor;
- // 用例的日志文件路径;
- pCase->_strCaseLog = pCase->_strFileDir + "\\" + pCase->_strFileName + ".txt";
- if ( pExcutor->InitScript(pCase->_strScriptPath, pCase->_strCaseLog, "") ) {
- // 设置用例对象;
- pExcutor->SetCaseObje(pCase);
- pExcutor->StartScript();
- // 标记用例执行中;
- pCase->_nExecutionState = SATHTTP::INEXECUTED;
- }
- else { // 标记脚本失败;
- pCase->_nExecutionResult = SATHTTP::FAIL;
- }
- // 标记任务为执行中;
- pTask->_nExecutionState = SATHTTP::INEXECUTED;
- // 记录开始时间;
- pCase->_ulStartTickCount = GetTickCount64();
- pCase->_strStartTime = CTime::GetCurrentTime().Format(_T("%Y-%m-%d %H:%M:%S"));
- }
- }
- else {
- //CScriptExecutor *pExcutor = (CScriptExecutor *)pCase->_pExcutor;
- }
- }
- return pCase;
- }
- void CSATExecutor::AddDevices(const SATDEV::STDevice &stDevice)
- {
- if ( IsDeviceExist(stDevice.strName) )
- return;
- SATHTTP::STDevice http_dev;
- // 设备使用状态;
- if ( stDevice.nStatus == SATDEV::Idle )
- http_dev.strStatus = "0";
- else if ( stDevice.nStatus == SATDEV::InUse )
- http_dev.strStatus = "1";
- // 设备序列号;
- http_dev.strDeviceSerial = stDevice.strName;
- // 余下变量固定值;
- http_dev.strComments = "";
- http_dev.strCPU = "";
- http_dev.strDeviceMac = "";
- http_dev.strElectric = "";
- http_dev.strHardwareVersion = "SAT-HV";
- http_dev.strLastJob = "";
- http_dev.strLastJobFinishTime = "";
- http_dev.strLastJobStartTime = "";
- http_dev.strLastTimeBreak = "";
- http_dev.strLastTimeConnected = "";
- http_dev.strManu = "";
- http_dev.strMemory = "";
- http_dev.strModel = "SATModel";
- http_dev.strPhoneNumber = "";
- http_dev.strSoftwareVersion = "0123456789";
- m_vtDevice.push_back(http_dev);
- }
- void CSATExecutor::DelDevices(const SATDEV::STDevice &stDevice)
- {
- std::vector<SATHTTP::STDevice>::iterator it = m_vtDevice.begin();
- for ( ; it != m_vtDevice.end(); it++ ) {
- if ( _tcsicmp(it->strDeviceSerial.c_str(), stDevice.strName.c_str()) == 0 ) {
- m_vtDevice.erase(it);
- break;
- }
- }
- }
- void CSATExecutor::SynchDeviceStatus(std::string strDevName, SATDEV::DEVICE_USAGE_STATUS status)
- {
- std::vector<SATHTTP::STDevice>::iterator it = m_vtDevice.begin();
- for ( ; it != m_vtDevice.end(); it++ ) {
- if ( _tcsicmp(it->strDeviceSerial.c_str(), strDevName.c_str()) == 0 ) {
- if ( status == SATDEV::Idle )
- it->strStatus = "0";
- else if ( status == SATDEV::InUse )
- it->strStatus = "1";
- break;
- }
- }
- CSATDevices::SetDeviceUsageStatus(strDevName, status);
- }
- bool CSATExecutor::IsDeviceExist(std::string strDevName)
- {
- bool bExist = false;
- std::vector<SATHTTP::STDevice>::iterator it = m_vtDevice.begin();
- for ( ; it != m_vtDevice.end(); it++ ) {
- if ( _tcsicmp(it->strDeviceSerial.c_str(), strDevName.c_str()) == 0 ) {
- bExist = true;
- break;
- }
- }
- return bExist;
- }
- bool CSATExecutor::Login(std::string user, std::string password, std::string actuator, bool bLogin /*= true*/)
- {
- std::string url = GLOBAL::g_stSATConfig.szExecuteServer;
- url.append("/ajaxInteractiveManage!executeLogin.action");
- // 填充数据;
- m_stLoginReq.strUserName = user;
- m_stLoginReq.strPassword = password;
- m_stLoginReq.strStatus = bLogin ? "0" : "1"; // 0表示登录;
- m_stLoginReq.strDeleteStatus = "";
- m_stLoginReq.strIP = GLOBAL::g_strIPAddress;
- m_stLoginReq.strStorage = "";
- if ( bLogin ) {
- m_stLoginReq.strDisconnectTime = "";
- m_stLoginReq.strConnectTime = CTime::GetCurrentTime().Format(_T("%Y-%m-%d %H:%M:%S"));
- } else {
- m_stLoginReq.strConnectTime = "";
- m_stLoginReq.strDisconnectTime = CTime::GetCurrentTime().Format(_T("%Y-%m-%d %H:%M:%S"));
- }
- // 执行器名称;
- m_stLoginReq.strExecuteName = m_strActuatorName = actuator;
- // 执行器PC物理地址;
- m_stLoginReq.strMAC = GLOBAL::g_strMacs;
- m_stLoginReq.strCPU = "";
- if ( ::Login(url, m_stLoginReq, m_stLoginResp) ) {
- GLOBAL::WriteTextLog("登录成功");
- m_bLogin = TRUE;
- return true;
- }
- GLOBAL::WriteTextLog("登录失败");
- return false;
- }
- bool CSATExecutor::Logout(std::string user, std::string password)
- {
- return Login(user, password, false);
- }
- bool CSATExecutor::UpdateDevice()
- {
- SATHTTP::STUpdateDeviceReq stUpdateDeviceReq;
- SATHTTP::STUpdateDeviceResp stUpdateDeviceResp;
- std::string url = GLOBAL::g_stSATConfig.szExecuteServer;
- url.append("/ajaxInteractiveManage!updateDeviceMessage.action");
- // 这个状态值要怎么设置?// 此处统一为0;
- stUpdateDeviceReq.strStatus = "0";
- stUpdateDeviceReq.strUserName = m_stLoginReq.strUserName;
- stUpdateDeviceReq.strIP = GLOBAL::g_strIPAddress;
- stUpdateDeviceReq.strStorage = "";
- stUpdateDeviceReq.strRunnerName = m_strActuatorName;
- // 这里使用PC物理地址;
- stUpdateDeviceReq.strMAC = GLOBAL::g_strMacs;
- // 这个reportType具体意义不明;
- stUpdateDeviceReq.strReportType = "1";
- stUpdateDeviceReq.strStartTime = CTime::GetCurrentTime().Format(_T("%Y-%m-%d %H:%M:%S"));
- stUpdateDeviceReq.strMemory = "";
- stUpdateDeviceReq.strEndTime = "";
- stUpdateDeviceReq.strCPU = "";
- stUpdateDeviceReq.devicelist.assign(m_vtDevice.begin(), m_vtDevice.end());
- if ( !::UpdateDeviceMessage(url, stUpdateDeviceReq, stUpdateDeviceResp) )
- {
- GLOBAL::WriteTextLog("更新设备信息失败");
- return false;
- }
-
- return true;
- }
- bool CSATExecutor::NotifyTaskStart(SATHTTP::STTask* pTask)
- {
- if ( !pTask )
- return false;
- SATHTTP::STNotifyJobStartReq stNotifyJobStartReq;
- SATHTTP::STNotifyJobStartResp stNotifyJobStartResp;
- std::string url = GLOBAL::g_stSATConfig.szExecuteServer;
- url.append("/ajaxInteractiveManage!setResult.action");
- TCHAR szValue[36] = {0};
- _itoa_s(pTask->nDeviceId, szValue, 10);
- stNotifyJobStartReq.strDeviceId = szValue;
- _itoa_s(pTask->nExecuteId, szValue, 10);
- stNotifyJobStartReq.strExecuteId = szValue;
- // _itoa_s(stTask.nInstanceId, szValue, 10); // 误导:应该使用id而不是nInstanceId
- _itoa_s(pTask->Id, szValue, 10);
- stNotifyJobStartReq.strInstanceId = szValue;
- //_itoa_s(pTask->nTaskId, szValue, 10);
- stNotifyJobStartReq.strTaskId = pTask->Job.strTaskId;
- // 这个映像路径有何用?
- stNotifyJobStartReq.strSignalImageUrl = GLOBAL::g_stSATConfig.szScriptDir;
- stNotifyJobStartReq.strSignalImageUrl.append(pTask->strTaskName+"\\\\");
- stNotifyJobStartReq.strSignalImageUrl.append(pTask->Job.strUniqueId+"\\\\");
- stNotifyJobStartReq.strSignalImageUrl.append(pTask->Job.strDeviceId);
- if ( SetResult(url, stNotifyJobStartReq, stNotifyJobStartResp) )
- {
- // 此处可能需要设置设备为忙碌状态;
- // SetDeviceStatus(BUSY);
- GLOBAL::WriteTextLog("更新任务状态成功:%s", pTask->Job.strUniqueId.c_str());
- return true;
- }
- GLOBAL::WriteTextLog("更新任务状态失败:%s", pTask->Job.strUniqueId.c_str());
- return false;
- }
- bool CSATExecutor::UploadCaseImg(SATHTTP::STTask* pTask, SATHTTP::STCase *pCase, std::string img)
- {
- TCHAR szValue[MAX_PATH] = {0};
- std::string url = GLOBAL::g_stSATConfig.szExecuteServer;
- url.append("/ajaxInteractiveManage!saveResultImg.action");
- SATHTTP::STSaveImgReq stSaveImgReq;
- SATHTTP::STSaveImgResp stSaveImgResp;
- stSaveImgReq.strCaseId = pCase->strId;
- stSaveImgReq.strCaseRepeat = "0";
- _itoa_s(pCase->_nCaseStep, szValue, 10);
- stSaveImgReq.strCaseStep = szValue;
- // 实例Id;
- _itoa_s(pTask->nDeviceId, szValue, 10);
- stSaveImgReq.strDeviceId = szValue;//pTask->Job.strDeviceId;
- // 就是Task中的ExecuteId
- _itoa_s(pTask->nExecuteId, szValue, 10);
- stSaveImgReq.strExecuteId = szValue;
- // 实例Id;
- _itoa_s(pTask->nInstanceId, szValue, 10);
- stSaveImgReq.strInstanceId = szValue;
- stSaveImgReq.strJobRepeat = "0";
- // 注意避坑:roundnum必须赋值0或1;
- stSaveImgReq.strRoundNum = "0";
- stSaveImgReq.strTaskType = pTask->strTaskType;
- stSaveImgReq.strUploads = img;
- // 上传用例图片;
- if ( SaveResultImg(url, stSaveImgReq, stSaveImgResp) )
- {
- GLOBAL::WriteTextLog("上传图片成功:任务=%s, 用例=%s, 图片=%s", pTask->Job.strUniqueId.c_str(), pCase->strCaseName.c_str(), img.c_str());
- return true;
- }
- GLOBAL::WriteTextLog("上传图片失败:任务=%s, 用例=%s, 图片=%s", pTask->Job.strUniqueId.c_str(), pCase->strCaseName.c_str(), img.c_str());
- return false;
- }
- bool CSATExecutor::UploadCaseLog(SATHTTP::STTask* pTask, SATHTTP::STCase *pCase)
- {
- TCHAR szValue[MAX_PATH] = {0};
- std::string url = GLOBAL::g_stSATConfig.szExecuteServer;
- url.append("/ajaxInteractiveManage!saveCaseOrTaskLog.action");
- SATHTTP::STSaveLogReq stSaveLogReq;
- SATHTTP::STSaveLogResp stSaveLogResp;
- stSaveLogReq.strCaseId = pCase->strId;
- // 执行ID;
- _itoa_s(pTask->nExecuteId, szValue, 10);
- stSaveLogReq.strExecuteId = szValue;
- stSaveLogReq.strFileType = "caseLogFile";
- // 任务Id;
- //_itoa_s(pTask->nTaskId, szValue, 10);
- stSaveLogReq.strTaskId = pTask->Job.strTaskInstanceId;
- stSaveLogReq.strUserId = pTask->Job.strUserId;
- // 要上传的日志文件;
- stSaveLogReq.strUploads = pCase->_strCaseLog;
- if ( SaveCaseOrTaskLog(url, stSaveLogReq, stSaveLogResp) )
- {
- GLOBAL::WriteTextLog("上传日志成功:任务=%s, 用例=%s, 日志=%s", pTask->Job.strUniqueId.c_str(), pCase->strCaseName.c_str(), pCase->_strCaseLog.c_str());
- return true;
- }
- GLOBAL::WriteTextLog("上传日志失败:任务=%s, 用例=%s, 日志=%s", pTask->Job.strUniqueId.c_str(), pCase->strCaseName.c_str(), pCase->_strCaseLog.c_str());
- return false;
- }
- bool CSATExecutor::ReportCaseItemFinish(SATHTTP::STTask* pTask, SATHTTP::STCase *pCase, STCaseItem &caseItem)
- {
- TCHAR szValue[MAX_PATH] = {0};
- std::string url = GLOBAL::g_stSATConfig.szExecuteServer;
- url.append("/ajaxInteractiveManage!setResultList.action");
- SATHTTP::STJobProcessReq stJobProcessReq;
- SATHTTP::STJobProcessResp stJobProcessResp;
- // 根据测试项结果决定测试项成功与否;
- stJobProcessReq.strResultState = caseItem.result ? "1" : "0";
- // 如果测试项失败,标记用例和任务失败;
- if ( !caseItem.result ) {
- pCase->_nExecutionResult = SATHTTP::FAIL;
- pTask->_nExecutionResult = SATHTTP::FAIL;
- }
- stJobProcessReq.strCaseScene = "";
- // 索引;
- _itoa_s(pCase->_nCaseStep, szValue, 10);
- stJobProcessReq.strCaseStep = szValue;
- stJobProcessReq.strApkMD5 = "";
- stJobProcessReq.strCrashTime = "";
- // 就是Task中的ExecuteId
- _itoa_s(pTask->nExecuteId, szValue, 10);
- stJobProcessReq.strRunnerId = szValue;
- stJobProcessReq.strCPUInfo = "0";
- stJobProcessReq.strRunnedActionNameList = "";
- stJobProcessReq.strArtificialResult = "";
- stJobProcessReq.strArtificialModify = "";
- stJobProcessReq.strRunnerName = "";
- stJobProcessReq.strTaskType = "FUNCTIONALITY";
- stJobProcessReq.strCaseRepeat = "0";
- stJobProcessReq.strApplicationGroup = "";
- // 实例Id;
- _itoa_s(pTask->Id, szValue, 10);
- stJobProcessReq.strInstanceId = szValue;
- stJobProcessReq.strCaseId = pCase->strId;
- // 进度;
- _itoa_s(100*(atoi(pCase->strIndex.c_str()))/pTask->Job.vtCases.size(), szValue, 10);
- stJobProcessReq.strProgress = szValue;
- // 需要将utf-8转gbk;
- stJobProcessReq.strReusltMessage = caseItem.name;//CharEncoding::UTF82ASCII(caseItem.name.c_str());
- stJobProcessReq.strJobRepeat = "0";
- stJobProcessReq.strScreenShot = "";
- stJobProcessReq.strStartTime = pCase->_strStartTime;
- stJobProcessReq.strCrashNumber = "";
- stJobProcessReq.strCaseName = pCase->strCaseName;
- //stJobProcessReq.strFailedReason = CharEncoding::UTF82ASCII(caseItem.remark.c_str());
- //stJobProcessReq.strFailedReason = (char*)CharEncoding::UTF82UNICODE(caseItem.remark.c_str());
- stJobProcessReq.strFailedReason = caseItem.remark;
- for (std::vector<std::string>::iterator it = caseItem.imgs.begin(); it != caseItem.imgs.end(); it++ )
- {
- int npos = it->find_last_of('/');
- if ( std::string::npos != npos )
- {
- stJobProcessReq.strImgName.append(it->substr(npos+1));
- stJobProcessReq.strImgName.append("&");
- }
- }
- if ( stJobProcessReq.strImgName.size() && stJobProcessReq.strImgName.at(stJobProcessReq.strImgName.size()-1) == '&')
- stJobProcessReq.strImgName.erase(stJobProcessReq.strImgName.size()-1);
- stJobProcessReq.strCaseIndex = pCase->strIndex;
- // 实例Id;
- _itoa_s(pTask->nDeviceId, szValue, 10);
- stJobProcessReq.strDeviceId = szValue;
- stJobProcessReq.strSceneIndex = "0";
- // 实例Id;
- //_itoa_s(pTask->nTaskId, szValue, 10);
- stJobProcessReq.strTaskId = pTask->Job.strTaskId;
- //stJobProcessReq.strAnalysis = CharEncoding::UTF82ASCII(caseItem.data.c_str());
- stJobProcessReq.strAnalysis = caseItem.data.c_str();
- // 设备名称:即DeviceSerial;
- stJobProcessReq.strDevnceName = pTask->Job.strDeviceId; // 命名及其不范围,一会deviceid是deviceserial,一会是id;
- // 固定为:TOTAL
- stJobProcessReq.strInfoType = "";
- // 如果是Android设备,需要通过adb获取;
- //stJobProcessReq.strMemoryInfo = stDevice.strMemory;
- stJobProcessReq.strEndTime = CTime::GetCurrentTime().Format(_T("%Y-%m-%d %H:%M:%S"));//"2019-12-16 10:18:20";
- stJobProcessReq.strRoundNumber = "1";
- stJobProcessReq.strResultType = "4"; // reportActionFinish;
- stJobProcessReq.strOperationStep = "";
- if ( SetResultList(url, stJobProcessReq, stJobProcessResp) )
- {
- GLOBAL::WriteTextLog("上传【用例测试项】结果完成【成功】:任务=%s, 用例=%s", pTask->Job.strUniqueId.c_str(), pCase->strCaseName.c_str());
- // 再上传图片;
- std::string img;
- for (std::vector<std::string>::iterator it = caseItem.imgs.begin(); it != caseItem.imgs.end(); it++ )
- {
- img = GLOBAL::g_stSATConfig.szCaseResultDir;
- img.append(it->substr(3));
- img = GLOBAL::Replace(img, "/", "\\");
- GLOBAL::WriteTextLog("图片路径=%s", img.c_str());
- UploadCaseImg(pTask, pCase, img);
- }
- return true;
- }
- GLOBAL::WriteTextLog("上传【用例测试项】结果完成【失败】:任务=%s, 用例=%s", pTask->Job.strUniqueId.c_str(), pCase->strCaseName.c_str());
- return false;
- }
- bool CSATExecutor::ReportCaseFinish(SATHTTP::STTask* pTask, SATHTTP::STCase *pCase)
- {
- TCHAR szValue[MAX_PATH] = {0};
- std::string url = GLOBAL::g_stSATConfig.szExecuteServer;
- url.append("/ajaxInteractiveManage!setResultList.action");
- SATHTTP::STJobProcessReq stJobProcessReq;
- SATHTTP::STJobProcessResp stJobProcessResp;
- // 上报用例结果:0表示脚本成功执行, 1表示脚本出错或超时;
- if ( pCase->_nExecutionState == SATHTTP::EXECUTED )
- {
- if ( pCase->_nExecutionResult == SATHTTP::SUCCESS )
- stJobProcessReq.strResultState = "0"; // 脚本未执行完成;
- else
- {
- if ( pCase->_nExecutionResult == SATHTTP::ABNORMAL )
- stJobProcessReq.strFailedReason = CharEncoding::ASCII2UTF8("脚本异常结束");
- stJobProcessReq.strResultState = "1";
- // 同时标记任务失败;
- pTask->_nExecutionResult = SATHTTP::FAIL;
- }
- }
- else
- {
- stJobProcessReq.strResultState = "1"; // 脚本执行未完成,认为fail;
- // 同时标记任务失败;
- pTask->_nExecutionResult = SATHTTP::FAIL;
- }
-
- stJobProcessReq.strCaseScene = "";
- // 索引;
- _itoa_s(pCase->_nCaseStep, szValue, 10);
- stJobProcessReq.strCaseStep = szValue;
- stJobProcessReq.strApkMD5 = "";
- stJobProcessReq.strCrashTime = "";
- // 就是Task中的ExecuteId
- _itoa_s(pTask->nExecuteId, szValue, 10);
- stJobProcessReq.strRunnerId = szValue;
- stJobProcessReq.strCPUInfo = "0";
- stJobProcessReq.strRunnedActionNameList = "";
- stJobProcessReq.strArtificialResult = "";
- stJobProcessReq.strArtificialModify = "";
- stJobProcessReq.strRunnerName = "";
- stJobProcessReq.strTaskType = "FUNCTIONALITY";
- stJobProcessReq.strCaseRepeat = "";
- stJobProcessReq.strApplicationGroup = "";
- // 实例Id;注意避坑;
- _itoa_s(pTask->Id, szValue, 10);
- stJobProcessReq.strInstanceId = szValue;
- stJobProcessReq.strCaseId = pCase->strId;
- // 进度(###需要修改此处###);
- _itoa_s(100*(atoi(pCase->strIndex.c_str()))/pTask->Job.vtCases.size(), szValue, 10);
- stJobProcessReq.strProgress = szValue;
- // 需要将utf-8转gbk;
- stJobProcessReq.strReusltMessage = CharEncoding::ASCII2UTF8("测试用例结果:");
- stJobProcessReq.strJobRepeat = "";
- stJobProcessReq.strScreenShot = "";
- stJobProcessReq.strStartTime = pCase->_strStartTime;
- stJobProcessReq.strCrashNumber = "";
- stJobProcessReq.strCaseName = pCase->strCaseName;
-
- stJobProcessReq.strImgName = "";
- stJobProcessReq.strCaseIndex = pCase->strIndex;
- // 实例Id;
- _itoa_s(pTask->nDeviceId, szValue, 10);
- stJobProcessReq.strDeviceId = szValue;
- stJobProcessReq.strSceneIndex = "0";
- // 实例Id;
- //_itoa_s(pTask->nTaskId, szValue, 10);
- stJobProcessReq.strTaskId = pTask->Job.strTaskId;
- stJobProcessReq.strAnalysis = "";
- // 设备名称:即DeviceSerial;
- stJobProcessReq.strDevnceName = pTask->Job.strDeviceId; // 命名及其不范围,一会deviceid是deviceserial,一会是id;
- // 固定为:TOTAL
- stJobProcessReq.strInfoType = "TOTAL";
- // 如果是Android设备,需要通过adb获取;
- //stJobProcessReq.strMemoryInfo = stDevice.strMemory;
- stJobProcessReq.strEndTime = pCase->_strEndTime;//CTime::GetCurrentTime().Format(_T("%Y-%m-%d %H:%M:%S"));//"2019-12-16 10:18:20";
- stJobProcessReq.strRoundNumber = "1";
- stJobProcessReq.strResultType = "5"; // reportCaseFinish;
- stJobProcessReq.strOperationStep = "";
- if ( SetResultList(url, stJobProcessReq, stJobProcessResp) )
- {
- GLOBAL::WriteTextLog("上传用例结果完成【成功】:任务=%s, 用例=%s", pTask->Job.strUniqueId.c_str(), pCase->strCaseName.c_str());
- return true;
- }
- GLOBAL::WriteTextLog("上传用例结果完成【失败】:任务=%s, 用例=%s", pTask->Job.strUniqueId.c_str(), pCase->strCaseName.c_str());
- return false;
- }
- bool CSATExecutor::ReportCaseResult(SATHTTP::STTask* pTask, SATHTTP::STCase *pCase)
- {
- // 获取xml文件内容;
- std::string xmlpath = GLOBAL::g_stSATConfig.szCaseResultDir;
- xmlpath.append("detail\\");
- xmlpath.append(pCase->_strFileName);
- xmlpath.append("_result.xml");
- std::vector<STCaseItem> vtCaseItem;
- GetCaseXMLResult(xmlpath, vtCaseItem);
- // 如果测试项空,任务失败;
- if ( vtCaseItem.size() == 0 ) {
- pCase->_nExecutionResult = SATHTTP::ABNORMAL;
- // 同时标记任务失败;
- pTask->_nExecutionResult = SATHTTP::FAIL;
- }
-
- int nIndex = 1;
- TCHAR szValue[MAX_PATH] = {0};
- std::string url = GLOBAL::g_stSATConfig.szExecuteServer;
- url.append("/ajaxInteractiveManage!setResultList.action");
- SATHTTP::STJobProcessReq stJobProcessReq;
- SATHTTP::STJobProcessResp stJobProcessResp;
- // 遍历所有用例测试项;
- std::vector<STCaseItem>::iterator it = vtCaseItem.begin();
- for (; it != vtCaseItem.end(); it++ )
- {
- // 上报测试项结果(包含相片);
- ReportCaseItemFinish(pTask, pCase, *it);
- }
- // 上报用例完成;
- ReportCaseFinish(pTask, pCase);
- // 上传用例日志;
- UploadCaseLog(pTask, pCase);
- // 删除执行对象;
- if ( pCase->_pExcutor )
- delete pCase->_pExcutor;
- pCase->_pExcutor = NULL;
- GLOBAL::WriteTextLog(_T("用例已完成,执行器对象删除成功,脚本用例名为=%s"), pCase->strCaseName.c_str());
- return true;
- }
- bool CSATExecutor::UploadTaskLog(SATHTTP::STTask* pTask)
- {
- TCHAR szValue[MAX_PATH] = {0};
- std::string url = GLOBAL::g_stSATConfig.szExecuteServer;
- url.append("/ajaxInteractiveManage!saveCaseOrTaskLog.action");
- SATHTTP::STSaveLogReq stSaveLogReq;
- SATHTTP::STSaveLogResp stSaveLogResp;
- stSaveLogReq.strCaseId = "";
- // 执行ID;
- _itoa_s(pTask->nExecuteId, szValue, 10);
- stSaveLogReq.strExecuteId = szValue;
- stSaveLogReq.strFileType = "taskLogFile";
- // 任务Id;
- //_itoa_s(pTask->nTaskId, szValue, 10);
- stSaveLogReq.strTaskId = pTask->Job.strTaskInstanceId;
- stSaveLogReq.strUserId = pTask->Job.strUserId;
- // 要上传的日志文件;
- stSaveLogReq.strUploads = "D:\\sat\\log.txt";//pTask->_strTaskLog;
- if ( SaveCaseOrTaskLog(url, stSaveLogReq, stSaveLogResp) )
- {
- GLOBAL::WriteTextLog(_T("任务已完成,上传任务日志【成功】,任务编号为=%s"), pTask->Job.strUniqueId.c_str());
- return true;
- }
- GLOBAL::WriteTextLog(_T("任务已完成,上传任务日志【失败】,任务编号为=%s"), pTask->Job.strUniqueId.c_str());
- return false;
- }
- bool CSATExecutor::ReportTaskStart(SATHTTP::STTask* pTask)
- {
- TCHAR szValue[MAX_PATH] = {0};
- std::string url = GLOBAL::g_stSATConfig.szExecuteServer;
- url.append("/ajaxInteractiveManage!setResultList.action");
- SATHTTP::STJobProcessReq stJobProcessReq;
- SATHTTP::STJobProcessResp stJobProcessResp;
- // 需要处理###
- stJobProcessReq.strResultState = ""; // 脚本执行中,认为fail;
- stJobProcessReq.strCaseScene = "";
- // 索引;
- stJobProcessReq.strCaseStep = "0";
- stJobProcessReq.strApkMD5 = "";
- stJobProcessReq.strCrashTime = "";
- // 就是Task中的ExecuteId
- _itoa_s(pTask->nExecuteId, szValue, 10);
- stJobProcessReq.strRunnerId = szValue;
- stJobProcessReq.strCPUInfo = "0";
- stJobProcessReq.strRunnedActionNameList = "";
- stJobProcessReq.strArtificialResult = "";
- stJobProcessReq.strArtificialModify = "";
- stJobProcessReq.strRunnerName = "";
- stJobProcessReq.strTaskType = "FUNCTIONALITY";
- stJobProcessReq.strCaseRepeat = "";
- stJobProcessReq.strApplicationGroup = "";
- // 实例Id;注意避坑;
- _itoa_s(pTask->Id, szValue, 10);
- stJobProcessReq.strInstanceId = szValue;
- stJobProcessReq.strCaseId = "";
- // 进度(###需要修改此处###);
- stJobProcessReq.strProgress = "0";
- // 需要将utf-8转gbk;
- stJobProcessReq.strReusltMessage = "任务开始";
- stJobProcessReq.strJobRepeat = "";
- stJobProcessReq.strScreenShot = "";
- stJobProcessReq.strStartTime = pTask->strStartTime;
- stJobProcessReq.strCrashNumber = "";
- stJobProcessReq.strCaseName = "";
- stJobProcessReq.strFailedReason = "";
- stJobProcessReq.strImgName = "";
- stJobProcessReq.strCaseIndex = "";
- // 实例Id;
- _itoa_s(pTask->nDeviceId, szValue, 10);
- stJobProcessReq.strDeviceId = szValue;
- stJobProcessReq.strSceneIndex = "";
- // 实例Id;
- //_itoa_s(pTask->nTaskId, szValue, 10);
- stJobProcessReq.strTaskId = pTask->Job.strTaskId;
- stJobProcessReq.strAnalysis = "";
- // 设备名称:即DeviceSerial;
- stJobProcessReq.strDevnceName = pTask->Job.strDeviceId; // 命名及其不范围,一会deviceid是deviceserial,一会是id;
- // 固定为:TOTAL
- stJobProcessReq.strInfoType = "TOTAL";
- // 如果是Android设备,需要通过adb获取;
- //stJobProcessReq.strMemoryInfo = stDevice.strMemory;
- stJobProcessReq.strEndTime = "";// CTime::GetCurrentTime().Format(_T("%Y-%m-%d %H:%M:%S"));//"2019-12-16 10:18:20";
- stJobProcessReq.strRoundNumber = "1";
- stJobProcessReq.strResultType = "0"; // reportJobStart;
- stJobProcessReq.strOperationStep = "";
- if ( SetResultList(url, stJobProcessReq, stJobProcessResp) )
- {
- GLOBAL::WriteTextLog(_T("上报任务开始【成功】,任务编号为=%s"), pTask->Job.strUniqueId.c_str());
- return true;
- }
- GLOBAL::WriteTextLog(_T("上报任务开始【失败】,任务编号为=%s"), pTask->Job.strUniqueId.c_str());
- return false;
- }
- bool CSATExecutor::ReportTaskFinish(SATHTTP::STTask* pTask)
- {
- TCHAR szValue[MAX_PATH] = {0};
- std::string url = GLOBAL::g_stSATConfig.szExecuteServer;
- url.append("/ajaxInteractiveManage!setResultList.action");
- SATHTTP::STJobProcessReq stJobProcessReq;
- SATHTTP::STJobProcessResp stJobProcessResp;
- // 需要处理(只要有用例失败,任务就失败)
- if ( pTask->_nExecutionState == SATHTTP::EXECUTED )
- {
- if ( pTask->_nExecutionResult == SATHTTP::SUCCESS )
- stJobProcessReq.strResultState = "0"; // 脚本执行中,认为fail;
- else
- stJobProcessReq.strResultState = "1"; // 脚本执行中,认为fail;
- }
- else
- stJobProcessReq.strResultState = "1"; // 脚本执行中,认为fail;
- stJobProcessReq.strCaseScene = "";
- // 索引;
- stJobProcessReq.strCaseStep = "0";
- stJobProcessReq.strApkMD5 = "";
- stJobProcessReq.strCrashTime = "";
- // 就是Task中的ExecuteId
- _itoa_s(pTask->nExecuteId, szValue, 10);
- stJobProcessReq.strRunnerId = szValue;
- stJobProcessReq.strCPUInfo = "0";
- stJobProcessReq.strRunnedActionNameList = "";
- stJobProcessReq.strArtificialResult = "";
- stJobProcessReq.strArtificialModify = "";
- stJobProcessReq.strRunnerName = "";
- stJobProcessReq.strTaskType = "FUNCTIONALITY";
- stJobProcessReq.strCaseRepeat = "0";
- stJobProcessReq.strApplicationGroup = "";
- // 实例Id;注意避坑;
- _itoa_s(pTask->Id, szValue, 10);
- stJobProcessReq.strInstanceId = szValue;
- stJobProcessReq.strCaseId = "";
- // 进度(###需要修改此处###);
- stJobProcessReq.strProgress = "100";
- // 需要将utf-8转gbk;
- stJobProcessReq.strReusltMessage = "任务结束";
- stJobProcessReq.strJobRepeat = "0";
- stJobProcessReq.strScreenShot = "";
- stJobProcessReq.strStartTime = pTask->strStartTime;
- stJobProcessReq.strCrashNumber = "";
- stJobProcessReq.strCaseName = "";
- stJobProcessReq.strFailedReason = "";
- stJobProcessReq.strImgName = "";
- stJobProcessReq.strCaseIndex = "";
- // 实例Id;
- _itoa_s(pTask->nDeviceId, szValue, 10);
- stJobProcessReq.strDeviceId = szValue;
- stJobProcessReq.strSceneIndex = "0";
- // 实例Id;
- //_itoa_s(pTask->nTaskId, szValue, 10);
- stJobProcessReq.strTaskId = pTask->Job.strTaskId;
- stJobProcessReq.strAnalysis = "";
- // 设备名称:即DeviceSerial;
- stJobProcessReq.strDevnceName = pTask->Job.strDeviceId; // 命名及其不范围,一会deviceid是deviceserial,一会是id;
- // 固定为:TOTAL
- stJobProcessReq.strInfoType = "";
- // 如果是Android设备,需要通过adb获取;
- //stJobProcessReq.strMemoryInfo = stDevice.strMemory;
- stJobProcessReq.strEndTime = CTime::GetCurrentTime().Format(_T("%Y-%m-%d %H:%M:%S"));//"2019-12-16 10:18:20";
- stJobProcessReq.strRoundNumber = "1";
- stJobProcessReq.strResultType = "1"; // reportJobFinish;
- stJobProcessReq.strOperationStep = "";
- if ( SetResultList(url, stJobProcessReq, stJobProcessResp) )
- {
- GLOBAL::WriteTextLog(_T("上报任务结束【成功】,任务编号为=%s"), pTask->Job.strUniqueId.c_str());
- return true;
- }
- GLOBAL::WriteTextLog(_T("上报任务结束【成功】,任务编号为=%s"), pTask->Job.strUniqueId.c_str());
- return false;
- }
- bool CSATExecutor::GetCaseXMLResult(std::string xmlpath, std::vector<STCaseItem> &vtCaseItem)
- {
- // 解析xml;
- tinyxml2::XMLDocument doc;
- if (tinyxml2::XML_SUCCESS != doc.LoadFile(xmlpath.c_str()) ) {
- return false;
- }
- tinyxml2::XMLElement *pXmlRoot = NULL;
- if ((pXmlRoot = doc.RootElement()) == NULL)
- return false;
-
- if (_tcsicmp(pXmlRoot->Value(), "results") != 0)
- return false;
-
- tinyxml2::XMLElement *pXmlElent = pXmlRoot->FirstChildElement();
- while (pXmlElent) {
- if (_tcsicmp(pXmlElent->Value(), _T("item")) == 0) {
- STCaseItem cItem;
- tinyxml2::XMLElement *pItem = pXmlElent->FirstChildElement();
- while (pItem) {
- if (_tcsicmp(pItem->Value(), _T("name")) == 0)
- {
- cItem.name = pItem->GetText();
- }
- else if (_tcsicmp(pItem->Value(), _T("result")) == 0)
- {
- cItem.result = pItem->BoolText();
- }
- else if (_tcsicmp(pItem->Value(), _T("data")) == 0)
- {
- cItem.data = pItem->GetText();
- }
- else if (_tcsicmp(pItem->Value(), _T("log")) == 0)
- {
- cItem.log = pItem->GetText();
- }
- else if (_tcsicmp(pItem->Value(), _T("remark")) == 0)
- {
- cItem.remark = pItem->GetText();
- }
- else if (_tcsicmp(pItem->Value(), _T("screen")) == 0)
- {
- cItem.imgs.push_back(pItem->GetText());
- }
- pItem = pItem->NextSiblingElement();
- }
- // 压入容器;
- if ( cItem.name.size() )
- vtCaseItem.push_back(cItem);
- }
- pXmlElent = pXmlElent->NextSiblingElement();
- }
-
- return true;
- }
- int CSATExecutor::AttachTaskInfo2Buffer(SATPROTO::TaskInfo (&pbuff)[SATPROTO::MAX_TASKS])
- {
- int count = 0;
- if ( pbuff ) {
- AutoThreadSection ats(&m_csTask);
- std::list<SATHTTP::STTask>::iterator it = m_vtTask.begin();
- for ( ;it != m_vtTask.end(); it++ ) {
- pbuff[count].nStatus = it->_nExecutionState;
- pbuff[count].nTaskId = it->Id;
- memcpy_s(pbuff[count].szTaskNo, SATPROTO::MAX_NAME, it->Job.strUniqueId.c_str(), it->Job.strUniqueId.size());
- memcpy_s(pbuff[count].szTaskName, SATPROTO::MAX_NAME, it->strTaskName.c_str(), it->strTaskName.size());
- int nIndex = 0;
- for (std::vector<SATHTTP::STCase>::iterator _case = it->Job.vtCases.begin(); _case != it->Job.vtCases.end(); _case++) {
- pbuff[count].ssCases[nIndex].nStatus = _case->_nExecutionState;
- //pbuff[count].ssCases[nIndex].nCaseId = _case->_nCaseStep;
- memcpy_s(pbuff[count].ssCases[nIndex].szCaseName, SATPROTO::MAX_NAME, _case->strCaseName.c_str(), _case->strCaseName.size());
- nIndex++;
- }
- count++;
- // 超过MAX_TASKS退出;
- if ( count == SATPROTO::MAX_TASKS )
- break;
- }
- }
- return count;
- }
- void CSATExecutor::StartWork()
- {
- m_hEventHearbeat = CreateEvent(NULL, TRUE, FALSE, NULL);
- if ( m_hEventHearbeat == NULL ) {
- _tprintf_s(_T("创建事件失败\n"));
- return;
- }
- m_hEventExcuteScript = CreateEvent(NULL, TRUE, FALSE, NULL);
- if ( m_hEventExcuteScript == NULL ) {
- _tprintf_s(_T("创建事件失败2\n"));
- return;
- }
- m_hThreadHearbeat = CreateThread(NULL, 0, HearbeatThread, this, 0, NULL);
- if ( m_hThreadHearbeat == NULL) {
- SetEvent(m_hEventHearbeat);
- SetEvent(m_hEventExcuteScript);
- CloseHandle(m_hEventHearbeat);
- CloseHandle(m_hEventExcuteScript);
- m_hEventHearbeat = NULL;
- m_hEventExcuteScript = NULL;
- _tprintf_s(_T("创建线程失败\n"));
- return;
- }
- m_hThreadExcuteScript = CreateThread(NULL, 0, ExecuteScriptThread, this, 0, NULL);
- if ( m_hThreadExcuteScript == NULL ) {
- SetEvent(m_hEventHearbeat);
- SetEvent(m_hEventExcuteScript);
- CloseHandle(m_hEventHearbeat);
- CloseHandle(m_hEventExcuteScript);
- m_hEventHearbeat = NULL;
- m_hEventExcuteScript = NULL;
- WaitForSingleObject(m_hThreadHearbeat,INFINITE);
- if (m_hThreadHearbeat)
- CloseHandle(m_hThreadHearbeat);
- m_hThreadHearbeat = NULL;
- _tprintf_s(_T("创建线程失败2\n"));
- return;
- }
- }
- void CSATExecutor::EndofWork()
- {
- //////////////////////////////////////////////////////////////////////////
- // 设置事件有信号;
- if ( m_hEventHearbeat )
- SetEvent(m_hEventHearbeat);
- // 等待线程结束;
- if ( m_hThreadHearbeat ) {
- WaitForSingleObject(m_hThreadHearbeat, INFINITE);
- CloseHandle(m_hThreadHearbeat);
- m_hThreadHearbeat = NULL;
- }
- // 关闭事件句柄;
- if ( m_hEventHearbeat ) {
- CloseHandle(m_hEventHearbeat);
- m_hEventHearbeat = NULL;
- }
- //////////////////////////////////////////////////////////////////////////
- // 设置事件有信号;
- if ( m_hEventExcuteScript )
- SetEvent(m_hEventExcuteScript);
- // 等待线程结束;
- if ( m_hThreadExcuteScript ) {
- WaitForSingleObject(m_hThreadExcuteScript, INFINITE);
- CloseHandle(m_hThreadExcuteScript);
- m_hThreadExcuteScript = NULL;
- }
- // 关闭事件句柄;
- if ( m_hEventExcuteScript ) {
- CloseHandle(m_hEventExcuteScript);
- m_hEventExcuteScript = NULL;
- }
- // 如果有脚本在执行,结束脚本;
- CPythonExecutor *pExecutor = NULL;
- for ( std::list<SATHTTP::STTask>::iterator it = m_vtTask.begin(); it != m_vtTask.end(); it++ ) {
- for ( std::vector<SATHTTP::STCase>::iterator _case = it->Job.vtCases.begin(); _case != it->Job.vtCases.end(); _case++ ) {
- if ( (pExecutor = (CPythonExecutor *)_case->_pExcutor) ) {
- pExecutor->EndThread();
- delete pExecutor;
- pExecutor = NULL;
- }
- }
- }
- m_vtTask.clear();
- }
- DWORD CSATExecutor::HearbeatThread(LPVOID lpVoid)
- {
- CSATExecutor *that = (CSATExecutor*)lpVoid;
- if ( !that ) return 0;
-
- do {
- // 没有登录成功,不查询;
- if ( !that->m_bLogin ) continue;
- // 更新设备;
- that->UpdateDevice();
- // 脚本保存目录;
- std::string strScriptSaveDir;
- SATHTTP::STHeartbeatReq stHeartbeatReq;
- SATHTTP::STHeartbeatResp stHeartbeatResp;
- std::string url = GLOBAL::g_stSATConfig.szExecuteServer;
- url.append("/ajaxInteractiveManage!executeHeartbeat.action");
- stHeartbeatReq.strUserName = that->m_stLoginReq.strUserName;
- stHeartbeatReq.strRunnerMac = that->m_stLoginReq.strMAC;
- stHeartbeatReq.devicelist.assign(that->m_vtDevice.begin(), that->m_vtDevice.end());
- if ( Heartbeat(url, stHeartbeatReq, stHeartbeatResp) ) {
- std::vector<SATHTTP::STTask>::iterator it = stHeartbeatResp.vtTask.begin();
- for ( ; it != stHeartbeatResp.vtTask.end(); it++ ) {
- if (!that->IsTaskExist(*it)) {
- // 将任务压入队列中;
- AutoThreadSection ats(&that->m_csTask);
- // 同时下载任务;
- std::string host = GLOBAL::g_stSATConfig.szCaseServer;
- std::string url = host + "/ajaxInteractiveManage!getCaseFileListUrl.action";
- std::vector<SATHTTP::STCase>::iterator _case = it->Job.vtCases.begin();
- for ( int i = 1; _case != it->Job.vtCases.end(); _case++) {
- // 下载脚本;
- _case->_nCaseStep = i++;
- SATHTTP::STScriptUrlResp stScriptUrlResp;
- // 脚本保存路径;
- strScriptSaveDir = GLOBAL::g_stSATConfig.szScriptDir;
- strScriptSaveDir.append(it->Job.strProjectName+"\\");
- strScriptSaveDir.append(it->Job.strUniqueId+"\\");
- // 把冒号改成下划线;
- strScriptSaveDir.append(GLOBAL::Replace(it->Job.strDeviceId, "_", ":")+"\\");
- if ( DownloadScript(url, _case->strId, strScriptSaveDir, stScriptUrlResp) ) {
- _case->_strFileDir = stScriptUrlResp._strFileDir;
- _case->_strFileName = stScriptUrlResp._strFileName;
- _case->_strScriptPath = stScriptUrlResp._strScripFile;
- }
- }
- that->m_vtTask.push_back(*it);
- // 通知SAT服务器,脚本开始执行;
- // 待开发:同时将任务存储到数据库中;
- /*
- db process
- */
- }
- }
- }
- } while ( WaitForSingleObject(that->m_hEventHearbeat, 5000) == WAIT_TIMEOUT );
- return 0;
- }
- DWORD CSATExecutor::ExecuteScriptThread(LPVOID lpVoid)
- {
- CSATExecutor *that = (CSATExecutor*)lpVoid;
- if ( !that ) return 0;
- do {
- // 删除已完成的任务;
- that->DelFinishedTask();
- // 是否有任务在执行;
- SATHTTP::STTask *pTask = that->IsThereATaskInProcess();
- if ( pTask ) {// 有任务在执行中;
- if ( pTask->_bConcurrent ) {// 并发;
- }
- else {// 串行;
- // 是否有脚本用例在执行;
- SATHTTP::STCase* pCase = that->IsCaseScriptProcess(pTask->Job.vtCases);
- if ( pCase ) {
- CPythonExecutor *pExcutor = (CPythonExecutor*)pCase->_pExcutor;
- if ( pExcutor ) {
- if ( pExcutor->IsScriptOver() ) {
- // 标记脚本已执行;
- pCase->_nExecutionState = SATHTTP::EXECUTED;
- // 如果脚本异常,标记任务失败;
- if ( pCase->_nExecutionResult == SATHTTP::ABNORMAL ) {
- // 设置任务执行结果失败;
- pTask->_nExecutionResult = SATHTTP::FAIL;
- GLOBAL::WriteTextLog("用例脚本异常退出(%s)", pCase->strCaseName.c_str());
- }
- // 上报服务器,完成脚本用例,并上传用例结果;
- that->ReportCaseResult(pTask, pCase);
- }
- else {
- // 判断是否超时;
- ULONGLONG ulCurTickCount = GetTickCount64();
- if ( ulCurTickCount - pExcutor->GetActiveTickCount() > GLOBAL::g_stSATConfig.dwScriptTimeout ) {
- // 结束进程;
- pExcutor->EndSubprocess();
- // 超时中断;
- pCase->_nExecutionState = 3;
- // 上报用例结果;
- that->ReportCaseResult(pTask, pCase);
- }
- }
- }
- }
- else {
- // 没有在执行的用例,开始执行新的用例;
- pCase = that->ExecuteFreeCaseScript(pTask);
- if ( NULL == pCase ) {
- // 没有空闲的用例可执行,说明所有用例已执行完成;
- pTask->_nExecutionState = 2;
- // 上报任务完成;
- that->ReportTaskFinish(pTask);
- // 上报任务结果;
- that->UploadTaskLog(pTask);
- }
- }
- }
- }
- else {
- // 获取空闲的任务;
- pTask = that->GetFreeTask();
- if ( pTask ) {
- // 是否支持并发;
- if ( pTask->_bConcurrent ) {
- // 暂时全部一起并发;
- std::vector<SATHTTP::STCase>::iterator _case = pTask->Job.vtCases.begin();
- for ( ; _case != pTask->Job.vtCases.end(); _case++) {
- if (!_case->_pExcutor) {
- CPythonExecutor *pExcutor = new CPythonExecutor();
- if ( pExcutor ) {
- _case->_pExcutor = pExcutor;
- pExcutor->InitScript(_case->_strScriptPath, _case->_strFileDir + "\\" + _case->_strFileName + ".txt", "");
- pExcutor->StartScript();
- // 标记用例执行中;
- _case->_nExecutionState = 1;
- }
- }
- }
- // 标记任务为执行中;
- pTask->_nExecutionState = 1;
- }
- else {
- // 是否有用例脚本在执行;
- SATHTTP::STCase* pCase = that->IsCaseScriptProcess(pTask->Job.vtCases);
- if ( !pCase ) {
- // 执行空闲用例脚本;
- that->ExecuteFreeCaseScript(pTask);
- }
- }
- // 通知SAT服务器,脚本开始执行;
- that->NotifyTaskStart(pTask);
- // 通知SAT服务器,脚本开始;
- that->ReportTaskStart(pTask);
- }
- }
- } while ( WaitForSingleObject(that->m_hEventExcuteScript, 10000) == WAIT_TIMEOUT );
- return 0;
- }
- DWORD CSATExecutor::WathTVPortThread(PVOID lpVoid)
- {
- CSynSerial tv;
- std::string buffer;
- TCHAR szLastPort[10] = {0};
- _tcscpy_s(szLastPort, GLOBAL::g_stSATConfig.szTVPort);
- std::vector<std::string> vtNotifyReboot;
- std::vector<std::string> vtNotifyShutdown;
- DWORD dwTickCount = GetTickCount();
- /*
- while(!g_bStopThread)
- {
- // 读取配置文件;
- GLOBAL::GetIniInfo();
- if ( !GLOBAL::g_stSATConfig.bWatchTVPort )
- {
- Sleep(5000);
- continue;
- }
- if ( GetTickCount() - dwTickCount > 5000 )
- {// 5秒更新一次;
- dwTickCount = GetTickCount();
- vtNotifyReboot.clear();
- vtNotifyShutdown.clear();
- GLOBAL::Split(GLOBAL::g_stSATConfig.szTVReboot, _T(";"), vtNotifyReboot);
- GLOBAL::Split(GLOBAL::g_stSATConfig.szTVShutdown, _T(";"), vtNotifyShutdown);
- }
- // 串口是否变更;
- if ( _tcsicmp(szLastPort, GLOBAL::g_stSATConfig.szTVPort) )
- {
- _tcscpy_s(szLastPort, GLOBAL::g_stSATConfig.szTVPort);
- // 重启打开串口;
- tv.CloseSerialPort();
- }
- if ( !tv.IsOpen() )
- {
- tv.OpenSerialPort(szLastPort, 115200, 8, 0, 1, 0, 1000);
- }
- if ( tv.IsOpen() )
- {
- BYTE szBuffer[1024] = {0};
- DWORD dwBuffer = tv.ReadComm(szBuffer, 1024, 1000);
- if ( dwBuffer != 0 )
- {
- int nType = 0; // 0表示无异常类型,-1表示关机异常,1表示重启异常;
- bool bAbnormal = false;
- buffer = (char*)szBuffer;
- __time64_t gmt = time(NULL);// 获取当前日历时间(1900-01-01开始的Unix时间戳);
- // 遍历是否有符合的子串;
- for ( std::vector<std::string>::iterator it = vtNotifyReboot.begin(); it != vtNotifyReboot.end(); it++ )
- {
- if ( _tcsstr(buffer.c_str(), it->c_str()) )
- {
- nType = 1;
- bAbnormal = true;
- break;
- }
- }
- if ( !bAbnormal )
- {
- for ( std::vector<std::string>::iterator it = vtNotifyShutdown.begin(); it != vtNotifyShutdown.end(); it++ )
- {
- if ( _tcsstr(buffer.c_str(), it->c_str()) )
- {
- nType = -1;
- bAbnormal = true;
- break;
- }
- }
- }
- // 1分钟前,是否有收到脚本通知;
- if ( Global::g_notify.notify )
- {
- __int64 nd = gmt - Global::g_notify.datetime;
- #ifdef _DEBUG
- TRACE3("判断时间%ld-通知时间%ld=相差时间%ld\n\n", gmt, Global::g_notify.datetime, nd);
- #endif
- if ( nd < 60)
- {
- // 监测的类型与通知类型是否一致;
- if ( (nType == 1 && Global::g_notify.report_type == _T("reboot")) ||
- (nType == -1 && Global::g_notify.report_type == _T("shutdown")) )
- {
- bAbnormal = false;
- // 重置;
- Global::g_notify.notify = false;
- Global::g_notify.datetime = 0;
- Global::g_notify.report_type.clear();
- }
- }
- }
- if (bAbnormal)
- {
- if ( nType == -1 )
- {
- // 遥控:重启电视机;
- if ( Global::g_SendPowerKey )
- Global::g_SendPowerKey();
- }
- // 压入容器中;
- Global::TLog tlog;
- if ( nType == -1 )
- tlog.report_type = "Abnormal shutdown";
- else if ( nType == 1 )
- tlog.report_type = "Abnormal restart";
- tlog.datetime = gmt; // 发生时间;
- struct tm gmtm = {0};
- localtime_s(&gmtm, &gmt); // 时间戳转成本地时间;
- TCHAR szDataTime[64] = {0};
- _stprintf_s(szDataTime,_T("Time of exception:%04d-%02d-%02d %02d:%02d:%02d"), gmtm.tm_year + 1900, gmtm.tm_mon+1, gmtm.tm_mday, gmtm.tm_hour, gmtm.tm_min, gmtm.tm_sec);
- tlog.report_data = szDataTime;
- Global::g_vtAbnormal.push_back(tlog);
- // 最后,重置;
- Global::g_notify.notify = false;
- Global::g_notify.datetime = 0;
- Global::g_notify.report_type.clear();
- }
- }
- }
- Sleep(200);
- }
- */
- return 0;
- }
|