FATP_FQCDlg.cpp 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325
  1. // FATP_FQCDlg.cpp : 实现文件
  2. //
  3. #include "stdafx.h"
  4. #include "FATP_FQC.h"
  5. #include "FATP_FQCDlg.h"
  6. #ifdef _DEBUG
  7. #define new DEBUG_NEW
  8. #endif
  9. // 用于应用程序“关于”菜单项的 CAboutDlg 对话框
  10. //CFATP_FQCDlg::m_filePath = {0};
  11. class CAboutDlg : public CDialog
  12. {
  13. public:
  14. CAboutDlg();
  15. // 对话框数据
  16. enum { IDD = IDD_ABOUTBOX };
  17. protected:
  18. virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持
  19. // 实现
  20. protected:
  21. DECLARE_MESSAGE_MAP()
  22. };
  23. CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
  24. {
  25. }
  26. void CAboutDlg::DoDataExchange(CDataExchange* pDX)
  27. {
  28. CDialog::DoDataExchange(pDX);
  29. }
  30. BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
  31. END_MESSAGE_MAP()
  32. // CFATP_FQCDlg 对话框
  33. CFATP_FQCDlg::CFATP_FQCDlg(CWnd* pParent /*=NULL*/)
  34. : CDialog(CFATP_FQCDlg::IDD, pParent)
  35. {
  36. m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
  37. }
  38. void CFATP_FQCDlg::DoDataExchange(CDataExchange* pDX)
  39. {
  40. CDialog::DoDataExchange(pDX);
  41. DDX_Control(pDX, IDC_LIST1, m_list);
  42. }
  43. BEGIN_MESSAGE_MAP(CFATP_FQCDlg, CDialog)
  44. ON_WM_SYSCOMMAND()
  45. ON_WM_PAINT()
  46. ON_WM_QUERYDRAGICON()
  47. //}}AFX_MSG_MAP
  48. ON_BN_CLICKED(BTN_GET_LOG, &CFATP_FQCDlg::OnBnClickedGetLog)
  49. ON_BN_CLICKED(BTN_SHOP_INIT, &CFATP_FQCDlg::OnBnClickedShopInit)
  50. ON_BN_CLICKED(IDC_BUTTON1, &CFATP_FQCDlg::OnBnClickedButton1)
  51. END_MESSAGE_MAP()
  52. // CFATP_FQCDlg 消息处理程序
  53. BOOL CFATP_FQCDlg::OnInitDialog()
  54. {
  55. CDialog::OnInitDialog();
  56. // 将“关于...”菜单项添加到系统菜单中。
  57. // IDM_ABOUTBOX 必须在系统命令范围内。
  58. ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
  59. ASSERT(IDM_ABOUTBOX < 0xF000);
  60. CMenu* pSysMenu = GetSystemMenu(FALSE);
  61. if (pSysMenu != NULL)
  62. {
  63. BOOL bNameValid;
  64. CString strAboutMenu;
  65. bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
  66. ASSERT(bNameValid);
  67. if (!strAboutMenu.IsEmpty())
  68. {
  69. pSysMenu->AppendMenu(MF_SEPARATOR);
  70. pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
  71. }
  72. }
  73. // 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
  74. // 执行此操作
  75. SetIcon(m_hIcon, TRUE); // 设置大图标
  76. SetIcon(m_hIcon, FALSE); // 设置小图标
  77. // TODO: 在此添加额外的初始化代码
  78. // 初始化列表;
  79. m_list.InsertColumn( 0, _T("DSN"));
  80. m_list.SetColumnWidth( 0, 200 );
  81. m_list.InsertColumn( 1, _T("Log"));
  82. m_list.SetColumnWidth( 1, 100 );
  83. m_list.InsertColumn( 2, _T("percent"));
  84. m_list.SetColumnWidth( 2, 120);
  85. m_list.InsertColumn( 3, _T("Result"));
  86. m_list.SetColumnWidth( 3, 100);
  87. #ifdef _DEBUG
  88. TCHAR szLogDir[MAX_PATH] = {0};
  89. _stprintf_s(szLogDir, _T("%s%s"), GLOBAL::g_szModulePath, _T("G9V28801216702RR"));
  90. CheckLog(szLogDir);
  91. #endif
  92. return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
  93. }
  94. void CFATP_FQCDlg::OnSysCommand(UINT nID, LPARAM lParam)
  95. {
  96. if ((nID & 0xFFF0) == IDM_ABOUTBOX)
  97. {
  98. CAboutDlg dlgAbout;
  99. dlgAbout.DoModal();
  100. }
  101. else
  102. {
  103. CDialog::OnSysCommand(nID, lParam);
  104. }
  105. }
  106. // 如果向对话框添加最小化按钮,则需要下面的代码
  107. // 来绘制该图标。对于使用文档/视图模型的 MFC 应用程序,
  108. // 这将由框架自动完成。
  109. void CFATP_FQCDlg::OnPaint()
  110. {
  111. if (IsIconic())
  112. {
  113. CPaintDC dc(this); // 用于绘制的设备上下文
  114. SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
  115. // 使图标在工作区矩形中居中
  116. int cxIcon = GetSystemMetrics(SM_CXICON);
  117. int cyIcon = GetSystemMetrics(SM_CYICON);
  118. CRect rect;
  119. GetClientRect(&rect);
  120. int x = (rect.Width() - cxIcon + 1) / 2;
  121. int y = (rect.Height() - cyIcon + 1) / 2;
  122. // 绘制图标
  123. dc.DrawIcon(x, y, m_hIcon);
  124. }
  125. else
  126. {
  127. CDialog::OnPaint();
  128. }
  129. }
  130. //当用户拖动最小化窗口时系统调用此函数取得光标
  131. //显示。
  132. HCURSOR CFATP_FQCDlg::OnQueryDragIcon()
  133. {
  134. return static_cast<HCURSOR>(m_hIcon);
  135. }
  136. BOOL CFATP_FQCDlg::CheckLog(CString strLogDir)
  137. {
  138. if ( PathFileExists(strLogDir) )
  139. {
  140. INT nPassLog = 0;
  141. CString strLogFile;
  142. for ( int i = 1; i < 6; i++ )
  143. {
  144. strLogFile.Format(_T("%s\\radar_data_fan_dmesg_%d.log"), strLogDir, i);
  145. if ( !PathFileExists(strLogFile) )
  146. return FALSE;
  147. CStringList listStr;
  148. CString strData = GLOBAL::ReadFileContent(strLogFile);
  149. GLOBAL::GetStringList(strData, _T("\n"), listStr);
  150. INT nPassCount = GLOBAL::CheckListData(listStr);
  151. FLOAT fPercent = (float)nPassCount/(float)(listStr.GetSize()/2)*100;
  152. CString strResult;
  153. strResult.Format(_T("%s,log_%d,%d/%d=%.2f%%,%s"),
  154. m_strDSN,
  155. i,
  156. nPassCount,
  157. listStr.GetSize()/2,
  158. fPercent,
  159. (90.0 < fPercent) ? _T("PASS") : _T("FAIL"));
  160. m_listResult.AddTail(strResult);
  161. INT nItemCount = m_list.GetItemCount();
  162. m_list.InsertItem(nItemCount, m_strDSN);
  163. strResult.Format(_T("Log.%d"), i);
  164. m_list.SetItemText(nItemCount, 1, strResult);
  165. strResult.Format(_T("%d/%d=%.2f%%"), nPassCount, listStr.GetSize()/2, fPercent);
  166. m_list.SetItemText(nItemCount, 2, strResult);
  167. strResult.Format(_T("%s"), (90.0 < fPercent) ? _T("PASS") : _T("FAIL"));
  168. m_list.SetItemText(nItemCount, 3, strResult);
  169. if ( 90.0 < fPercent )
  170. nPassLog++;
  171. UpdateData();
  172. }
  173. GLOBAL::SaveList(m_listResult);
  174. m_listResult.RemoveAll();
  175. if ( nPassLog == 1 )
  176. return TRUE;
  177. }
  178. return FALSE;
  179. }
  180. void CFATP_FQCDlg::OnBnClickedGetLog()
  181. {
  182. // TODO: 在此添加控件通知处理程序代码
  183. CString strStdOutput;
  184. TCHAR szApplicationName[MAX_PATH] = {0};
  185. #ifdef _DEBUG
  186. _stprintf_s(szApplicationName, _T("%s%s"), GLOBAL::g_szModulePath, _T("test.bat"));
  187. #else
  188. _stprintf_s(szApplicationName, _T("%s%s"), GLOBAL::g_szModulePath, _T("radar_data_collection_V03.bat"));
  189. #endif
  190. if ( GLOBAL::StartProcess(szApplicationName, NULL, strStdOutput) )
  191. {
  192. // 获取DSN;
  193. CStringList listDSN;
  194. GLOBAL::GetStringList(strStdOutput, _T("\r\n"), listDSN);
  195. CString strDSN, strTemp;
  196. CString strFindStr = _T("folder is ");
  197. if ( GLOBAL::FindString(listDSN, strFindStr, strDSN) )
  198. {
  199. m_strDSN = strDSN.Mid(strDSN.Find(strFindStr) + strFindStr.GetLength());
  200. m_strDSN.Trim();
  201. strFindStr.Format(_T("[%s][PASS]radar fan data collection"), m_strDSN);
  202. if ( GLOBAL::FindString(listDSN, strFindStr, strTemp) )
  203. {
  204. CString strLogDir;
  205. strLogDir.Format(_T("%s%s"),GLOBAL::g_szModulePath, m_strDSN);
  206. if ( CheckLog(strLogDir) )
  207. {
  208. OnBnClickedShopInit();
  209. }
  210. else
  211. {
  212. MessageBox(_T("日志统计失败"), _T("提示"), MB_ICONERROR);
  213. }
  214. }
  215. else
  216. {
  217. MessageBox(_T("未找到关键字<[PASS]radar fan data collection]>,执行结果失败"), _T("提示"), MB_ICONERROR);
  218. }
  219. }
  220. else
  221. {
  222. MessageBox(_T("未找到关键字<folder is>"), _T("提示"), MB_ICONERROR);
  223. }
  224. }
  225. else
  226. {
  227. MessageBox(_T("运行BAT失败"), _T("提示"), MB_ICONERROR);
  228. }
  229. }
  230. void CFATP_FQCDlg::OnBnClickedShopInit()
  231. {
  232. // TODO: 在此添加控件通知处理程序代码
  233. CString strStdOutput;
  234. TCHAR szApplicationName[MAX_PATH] = {0};
  235. _stprintf_s(szApplicationName, _T("%s%s"), GLOBAL::g_szModulePath, _T("radar_tv_set_shop_init_V03.bat"));
  236. if ( GLOBAL::StartProcess(szApplicationName, NULL, strStdOutput) )
  237. {
  238. // 获取DSN;
  239. CStringList listStr;
  240. GLOBAL::GetStringList(strStdOutput, _T("\r\n"), listStr);
  241. CString strResult;
  242. CString strFindStr = _T("[PASS]TV shop init finished ...[PASS]");
  243. if ( GLOBAL::FindString(listStr, strFindStr, strResult) )
  244. {
  245. MessageBox(_T("TV shop init finished ...[PASS]"), _T("提示"), MB_OK);
  246. }
  247. else
  248. {
  249. MessageBox(_T("未找到关键字<[PASS]TV shop init finished ...[PASS]>"), _T("提示"), MB_ICONERROR);
  250. }
  251. }
  252. else
  253. {
  254. MessageBox(_T("运行BAT失败"), _T("提示"), MB_ICONERROR);
  255. }
  256. }
  257. void CFATP_FQCDlg::OnBnClickedButton1()
  258. {
  259. m_list.DeleteAllItems();
  260. TCHAR szFolderPath[MAX_PATH] = {0};
  261. GLOBAL::GetFilePath(szFolderPath, m_hWnd, _T("请选择Log文件夹!"), BIF_USENEWUI | BIF_RETURNFSANCESTORS | BIF_RETURNONLYFSDIRS);
  262. if ( CheckLog(szFolderPath) )
  263. {
  264. OnBnClickedShopInit();
  265. }
  266. else
  267. {
  268. MessageBox(_T("日志统计失败"), _T("提示"), MB_ICONERROR);
  269. }
  270. }