Commit ca46482b3a3a7e968fa6b355b12b3e970d7bc638

Authored by liujiqiang
1 parent f1f467ef

更新测试报告删除方法

commons/scripts/delReport.py 0 → 100644
  1 +# -*- coding: utf-8 -*-
  2 +
  3 +# @Time : 2021/7/19 14:35
  4 +# @Author : Ljq
  5 +# @File : delectReport.py
  6 +# @Software: PyCharm
  7 +
  8 +"""
  9 +用于删除多余的报告文件
  10 +"""
  11 +
  12 +import os,sys
  13 +
  14 +def delReport(path,delNum=5):
  15 + file_list = os.listdir(os.path.abspath(os.path.join(path, "../")) + "/report/")
  16 + if len(file_list) > delNum:
  17 + file_list = file_list[:(0-delNum)]
  18 + for i in file_list:
  19 + if os.path.isfile(os.path.abspath(os.path.join(path, "../")) + "/report/" + i) and ".log" not in i:
  20 + os.remove(os.path.abspath(os.path.join(path, "../")) + "/report/" + i)
  21 + print(f"删除报告 {i} 成功")
  22 + # 文件已删除
  23 + print("多余的报告文件已删除")
  24 + else:
  25 + print("没有需要删除的文件")
0 \ No newline at end of file 26 \ No newline at end of file
@@ -40,7 +40,6 @@ def Run_Testcase(testsuit): @@ -40,7 +40,6 @@ def Run_Testcase(testsuit):
40 report_file = os.path.abspath(os.path.join(path))+ "/report/" + now + "_result.html" 40 report_file = os.path.abspath(os.path.join(path))+ "/report/" + now + "_result.html"
41 # 创建报告文件 41 # 创建报告文件
42 fp = open(report_file, 'wb') 42 fp = open(report_file, 'wb')
43 -  
44 runner = HTMLTestRunner_cn.HTMLTestRunner( 43 runner = HTMLTestRunner_cn.HTMLTestRunner(
45 stream=fp, 44 stream=fp,
46 title=u'重构项目接口测试报告', 45 title=u'重构项目接口测试报告',
@@ -50,6 +49,7 @@ def Run_Testcase(testsuit): @@ -50,6 +49,7 @@ def Run_Testcase(testsuit):
50 runner.run(testsuit) 49 runner.run(testsuit)
51 # 关闭文件 50 # 关闭文件
52 fp.close() 51 fp.close()
  52 + delReport.delReport(path)
53 return report_file 53 return report_file
54 54
55 55
report/2021-07-16 16_00_29_result.html deleted 100644 → 0
1 -<?xml version="1.0" encoding="UTF-8"?>  
2 -<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">  
3 -<html xmlns="http://www.w3.org/1999/xhtml">  
4 -<head>  
5 - <title>重构项目接口测试报告</title>  
6 - <meta name="generator" content="HTMLTestRunner 0.8.3"/>  
7 - <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>  
8 -  
9 -<style type="text/css" media="screen">  
10 -body { font-family: verdana, arial, helvetica, sans-serif; font-size: 80%; }  
11 -table { font-size: 100%; }  
12 -pre {  
13 - white-space: pre-wrap;  
14 - word-wrap: break-word;  
15 -}  
16 -  
17 -/* -- heading ---------------------------------------------------------------------- */  
18 -h1 {  
19 - font-size: 16pt;  
20 - color: gray;  
21 -}  
22 -.heading {  
23 - float:left;  
24 - width:30%;  
25 - margin-top: 0ex;  
26 - margin-bottom: 1ex;  
27 -}  
28 -  
29 -.heading .attribute {  
30 - margin-top: 1ex;  
31 - margin-bottom: 0;  
32 -}  
33 -  
34 -.heading .description {  
35 - margin-top: 4ex;  
36 - margin-bottom: 6ex;  
37 -}  
38 -  
39 -/* -- css div popup ------------------------------------------------------------------------ */  
40 -a.popup_link {  
41 -}  
42 -  
43 -a.popup_link:hover {  
44 - color: red;  
45 -}  
46 -.img{  
47 - height: 100%;  
48 - border-collapse: collapse;  
49 - border: 2px solid #777;  
50 -}  
51 -  
52 -.screenshots {  
53 - z-index: 100;  
54 - position:fixed;  
55 - height: 80%;  
56 - left: 50%;  
57 - top: 50%;  
58 - transform: translate(-50%,-50%);  
59 - display: none;  
60 -}  
61 -  
62 -.imgyuan{  
63 - height: 20px;  
64 - border-radius: 12px;  
65 - background-color: red;  
66 - padding-left: 13px;  
67 - margin: 0 auto;  
68 - position: relative;  
69 - top: -40px;  
70 - background-color: rgba(1, 150, 0, 0.3);  
71 -}  
72 -.imgyuan font{  
73 - border:1px solid white;  
74 - width:11px;  
75 - height:11px;  
76 - border-radius:50%;  
77 - margin-right: 9px;  
78 - margin-top: 4px;  
79 - display: block;  
80 - float: left;  
81 - background-color: white;  
82 -}  
83 -.close_shots {  
84 - background-image: url();  
85 - background-size: 22px 22px;  
86 - -moz-background-size: 22px 22px;  
87 - background-repeat: no-repeat;  
88 - position: absolute;  
89 - top: 5px;  
90 - right: 5px;  
91 - height: 22px;  
92 - z-index: 99;  
93 - width: 22px;  
94 -}  
95 -.popup_window {  
96 - display: none;  
97 - position: relative;  
98 - left: 0px;  
99 - top: 0px;  
100 - padding: 10px;  
101 - background-color: #E6E6D6;  
102 - font-family: "Lucida Console", "Courier New", Courier, monospace;  
103 - text-align: left;  
104 - font-size: 8pt;  
105 -}  
106 -  
107 -}  
108 -/* -- report ------------------------------------------------------------------------ */  
109 -#show_detail_line {  
110 - float:left;  
111 - width:100%;  
112 - margin-top: 3ex;  
113 - margin-bottom: 1ex;  
114 -}  
115 -  
116 -#result_table {  
117 - margin: 1em 0;  
118 - width: 100%;  
119 - overflow: hidden;  
120 - background: #FFF;  
121 - color: #024457;  
122 - border-radius: 10px;  
123 - border: 1px solid #167F92;  
124 -}  
125 -#result_table th {  
126 - border: 1px solid #FFFFFF;  
127 - background-color: #167F92;  
128 - color: #FFF;  
129 - padding: 0.5em;  
130 - &:first-child {  
131 - display: table-cell;  
132 - text-align: center;  
133 - }  
134 - &:nth-child(2) {  
135 - display: table-cell;  
136 - span {display:none;}  
137 - &:after {content:attr(data-th);}  
138 - }  
139 - @media (min-width: 480px) {  
140 - &:nth-child(2) {  
141 - span {display: block;}  
142 - &:after {display: none;}  
143 - }  
144 - }  
145 - }  
146 -#result_table td {  
147 - word-wrap: break-word;  
148 - max-width: 7em;  
149 - padding: 0.3em;  
150 - &:first-child {  
151 - display: table-cell;  
152 - text-align: center;  
153 - }  
154 - @media (min-width: 400px) {  
155 - border: 1px solid #D9E4E6;  
156 - }  
157 - }  
158 -  
159 -#result_table th, td {  
160 - margin: .5em 1em;  
161 - @media (min-width: 400px) {  
162 - display: table-cell;  
163 - padding: 1em;  
164 - }  
165 - }  
166 -  
167 -#total_row { font-weight: bold; }  
168 -.passClass { background-color: #6c6; !important ;}  
169 -.failClass { background-color: #c60; !important ;}  
170 -.errorClass { background-color: #c00; !important ; }  
171 -.passCase { color: #6c6; }  
172 -.failCase { color: #c60; font-weight: bold; }  
173 -.errorCase { color: #c00; font-weight: bold; }  
174 -.skipCase { color:#908e8e; font-weight: bold; }  
175 -tr[id^=pt] td { background-color: rgba(73,204,144,.3) !important ; }  
176 -tr[id^=ft] td { background-color: rgba(252,161,48,.3) !important; }  
177 -tr[id^=et] td { background-color: rgba(249,62,62,.3) !important ; }  
178 -tr[id^=st] td { background-color: #6f6f6fa1 !important ; }  
179 -.hiddenRow { display: none; }  
180 -.testcase { margin-left: 2em; }  
181 -  
182 -/* -- ending ---------------------------------------------------------------------- */  
183 -#ending {  
184 -}  
185 -  
186 -.detail_button {  
187 - width: 130px;  
188 - text-decoration: none;  
189 - line-height: 38px;  
190 - text-align: center;  
191 - font-weight: bold;  
192 - color: #ffff;  
193 - border-radius: 6px;  
194 - padding: 5px 10px 5px 10px;  
195 - position: relative;  
196 - overflow: hidden;  
197 -}  
198 -.detail_button.abstract{background-color: #4dbee8;}  
199 -.detail_button.passed{ background-color: #66cc66;}  
200 -.detail_button.failed{ background-color: #cc6600;}  
201 -.detail_button.errored{ background-color: #f54f4f;}  
202 -.detail_button.skiped{ background-color: gray;}  
203 -.detail_button.all{ background-color: blue;}  
204 -.piechart{  
205 - width: 200px;  
206 - float: left;  
207 - display: inline;  
208 -}  
209 -  
210 -  
211 -</style>  
212 -  
213 -</head>  
214 -<body>  
215 -<script language="javascript" type="text/javascript">  
216 -output_list = Array();  
217 -  
218 -/* level - 0:Summary; 1:Passed; 2:Failed; 3:Errored; 4:Skiped; 5:All */  
219 -function showCase(level,channel) {  
220 - trs = document.getElementsByTagName("tr");  
221 - for (var i = 0; i < trs.length; i++) {  
222 - tr = trs[i];  
223 - id = tr.id;  
224 - if (["ft","pt","et","st"].indexOf(id.substr(0,2))!=-1){  
225 - if ( level ==0 && id.substr(2,1)==channel ) {  
226 - tr.className = 'hiddenRow';  
227 - }  
228 - }  
229 -  
230 - if (id.substr(0,3) == 'pt'+channel) {  
231 - if ( level==1){  
232 - tr.className = '';  
233 - }  
234 - else if (level>4 && id.substr(2,1)==channel ){  
235 - tr.className = '';  
236 - }  
237 - else {  
238 - tr.className = 'hiddenRow';  
239 - }  
240 - }  
241 - if (id.substr(0,3) == 'ft'+channel) {  
242 - if (level ==2) {  
243 - tr.className = '';  
244 - }  
245 - else if (level>4 && id.substr(2,1)==channel ){  
246 - tr.className = '';  
247 - }  
248 - else {  
249 - tr.className = 'hiddenRow';  
250 - }  
251 - }  
252 - if (id.substr(0,3) == 'et'+channel) {  
253 - if (level ==3) {  
254 - tr.className = '';  
255 - }  
256 - else if (level>4 && id.substr(2,1)==channel ){  
257 - tr.className = '';  
258 - }  
259 - else {  
260 - tr.className = 'hiddenRow';  
261 - }  
262 - }  
263 - if (id.substr(0,3) == 'st'+channel) {  
264 - if (level ==4) {  
265 - tr.className = '';  
266 - }  
267 - else if (level>4 && id.substr(2,1)==channel ){  
268 - tr.className = '';  
269 - }  
270 - else {  
271 - tr.className = 'hiddenRow';  
272 - }  
273 - }  
274 -  
275 - }  
276 -}  
277 -  
278 -  
279 -function showClassDetail(cid, count) {  
280 - var id_list = Array(count);  
281 - var toHide = 1;  
282 - for (var i = 0; i < count; i++) {  
283 - tid0 = 't' + cid.substr(1) + '.' + (i+1);  
284 - tid = 'f' + tid0;  
285 - tr = document.getElementById(tid);  
286 - if (!tr) {  
287 - tid = 'p' + tid0;  
288 - tr = document.getElementById(tid);  
289 - }  
290 - if (!tr) {  
291 - tid = 'e' + tid0;  
292 - tr = document.getElementById(tid);  
293 - }  
294 - if (!tr) {  
295 - tid = 's' + tid0;  
296 - tr = document.getElementById(tid);  
297 - }  
298 - id_list[i] = tid;  
299 - if (tr.className) {  
300 - toHide = 0;  
301 - }  
302 - }  
303 - for (var i = 0; i < count; i++) {  
304 - tid = id_list[i];  
305 - if (toHide) {  
306 - document.getElementById(tid).className = 'hiddenRow';  
307 - }  
308 - else {  
309 - document.getElementById(tid).className = '';  
310 - }  
311 - }  
312 -}  
313 -  
314 -  
315 -function showTestDetail(div_id){  
316 - var details_div = document.getElementById(div_id)  
317 - var displayState = details_div.style.display  
318 - // alert(displayState)  
319 - if (displayState != 'block' ) {  
320 - displayState = 'block'  
321 - details_div.style.display = 'block'  
322 - }  
323 - else {  
324 - details_div.style.display = 'none'  
325 - }  
326 -}  
327 -  
328 -  
329 -function html_escape(s) {  
330 - s = s.replace(/&/g,'&amp;');  
331 - s = s.replace(/</g,'&lt;');  
332 - s = s.replace(/>/g,'&gt;');  
333 - return s;  
334 -}  
335 -  
336 -function drawCircle(circle,pass, fail, error){  
337 - var color = ["#6c6","#c60","#c00"];  
338 - var data = [pass,fail,error];  
339 - var text_arr = ["Pass", "Fail", "Error"];  
340 -  
341 - var canvas = document.getElementById(circle);  
342 - var ctx = canvas.getContext("2d");  
343 - var startPoint=0;  
344 - var width = 20, height = 10;  
345 - var posX = 112 * 2 + 20, posY = 30;  
346 - var textX = posX + width + 5, textY = posY + 10;  
347 - for(var i=0;i<data.length;i++){  
348 - ctx.fillStyle = color[i];  
349 - ctx.beginPath();  
350 - ctx.moveTo(112,84);  
351 - ctx.arc(112,84,84,startPoint,startPoint+Math.PI*2*(data[i]/(data[0]+data[1]+data[2])),false);  
352 - ctx.fill();  
353 - startPoint += Math.PI*2*(data[i]/(data[0]+data[1]+data[2]));  
354 - ctx.fillStyle = color[i];  
355 - ctx.fillRect(posX, posY + 20 * i, width, height);  
356 - ctx.moveTo(posX, posY + 20 * i);  
357 - ctx.font = 'bold 14px';  
358 - ctx.fillStyle = color[i];  
359 - var percent = text_arr[i] + ":"+data[i];  
360 - ctx.fillText(percent, textX, textY + 20 * i);  
361 -  
362 - }  
363 -}  
364 -  
365 -  
366 -function show_img(obj) {  
367 - var obj1 = obj.nextElementSibling  
368 - obj1.style.display='block'  
369 - var index = 0;//每张图片的下标,  
370 - var len = obj1.getElementsByTagName('img').length;  
371 - var imgyuan = obj1.getElementsByClassName('imgyuan')[0]  
372 - //var start=setInterval(autoPlay,500);  
373 - obj1.onmouseover=function(){//当鼠标光标停在图片上,则停止轮播  
374 - clearInterval(start);  
375 - }  
376 - obj1.onmouseout=function(){//当鼠标光标停在图片上,则开始轮播  
377 - start=setInterval(autoPlay,1000);  
378 - }  
379 - for (var i = 0; i < len; i++) {  
380 - var font = document.createElement('font')  
381 - imgyuan.appendChild(font)  
382 - }  
383 - var lis = obj1.getElementsByTagName('font');//得到所有圆圈  
384 - changeImg(0)  
385 - var funny = function (i) {  
386 - lis[i].onmouseover = function () {  
387 - index=i  
388 - changeImg(i)  
389 - }  
390 - }  
391 - for (var i = 0; i < lis.length; i++) {  
392 - funny(i);  
393 - }  
394 -  
395 - function autoPlay(){  
396 - if(index>len-1){  
397 - index=0;  
398 - clearInterval(start); //运行一轮后停止  
399 - }  
400 - changeImg(index++);  
401 - }  
402 - imgyuan.style.width= 25*len +"px";  
403 - //对应圆圈和图片同步  
404 - function changeImg(index) {  
405 - var list = obj1.getElementsByTagName('img');  
406 - var list1 = obj1.getElementsByTagName('font');  
407 - for (i = 0; i < list.length; i++) {  
408 - list[i].style.display = 'none';  
409 - list1[i].style.backgroundColor = 'white';  
410 - }  
411 - list[index].style.display = 'block';  
412 - list1[index].style.backgroundColor = 'blue';  
413 - }  
414 -  
415 -}  
416 -function hide_img(obj){  
417 - obj.parentElement.style.display = "none";  
418 - obj.parentElement.getElementsByClassName('imgyuan')[0].innerHTML = "";  
419 -}  
420 -</script>  
421 -<div class='heading'>  
422 -<h1>重构项目接口测试报告</h1>  
423 -<p class='attribute'><strong>开始时间:</strong> 2021-07-16 16:00:29</p>  
424 -<p class='attribute'><strong>耗时:</strong> 0:00:25.265336</p>  
425 -<p class='attribute'><strong>状态:</strong> <span class="tj passCase">Pass</span>:10 <span class="tj">通过率</span>:100.0%</p>  
426 -  
427 -<p class='description'>用例简要执行情况如下:(注:报告详细信息需要下载report.html并用浏览器打开)</p>  
428 -</div>  
429 -  
430 -  
431 -<div class="piechart">  
432 - <div>  
433 - <canvas id="circle1" width="350" height="168" </canvas>  
434 - </div>  
435 -</div>  
436 -  
437 -<div id='show_detail_line' style=" float: left; width: 100%;">  
438 -<a class="abstract detail_button" href='javascript:showCase(0,1)'>概要[100.00%]</a>  
439 -<a class="passed detail_button" href='javascript:showCase(1,1)'>通过[10]</a>  
440 -<a class="failed detail_button" href='javascript:showCase(2,1)'>失败[0]</a>  
441 -<a class="errored detail_button" href='javascript:showCase(3,1)'>错误[0]</a>  
442 -<a class="skiped detail_button" href='javascript:showCase(4,1)'>跳过[0]</a>  
443 -<a class="all detail_button" href='javascript:showCase(5,1)'>所有[10]</a>  
444 -</div>  
445 -  
446 -<table id='result_table'>  
447 -<colgroup>  
448 -<col align='left' />  
449 -<col align='right' />  
450 -<col align='right' />  
451 -<col align='right' />  
452 -<col align='right' />  
453 -<col align='right' />  
454 -<col align='right' />  
455 -</colgroup>  
456 -<tr id='header_row'>  
457 - <th>测试组/测试用例</th>  
458 - <th>总数</th>  
459 - <th>通过</th>  
460 - <th>失败</th>  
461 - <th>错误</th>  
462 - <th>视图</th>  
463 - <th>错误截图</th>  
464 -</tr>  
465 -  
466 -<tr class='passClass'>  
467 - <td>test_addCard.test_addCard</td>  
468 - <td>10</td>  
469 - <td>10</td>  
470 - <td>0</td>  
471 - <td>0</td>  
472 - <td><a href="javascript:showClassDetail('c1.1',10)">详情</a></td>  
473 - <td>&nbsp;</td>  
474 -</tr>  
475 -  
476 -<tr id='pt1.1.1' class='hiddenRow'>  
477 - <td ><div class='testcase'>test_addMasterCard:  
478 - 添加主卡  
479 - :return:  
480 - </div></td>  
481 - <td colspan='5' align='center'>  
482 -  
483 - <!--css div popup start-->  
484 - <span class='status passCase'>  
485 - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_pt1.1.1')" >  
486 - 通过</a></span>  
487 -  
488 - <div id='div_pt1.1.1' class="popup_window">  
489 - <div style='text-align: right; color:red;cursor:pointer'>  
490 - <a onfocus='this.blur();' onclick="document.getElementById('div_pt1.1.1').style.display = 'none' " >  
491 - [x]</a>  
492 - </div>  
493 - <pre>  
494 -  
495 -pt1.1.1: savaCard data ----&gt; {'cardType': '10', 'cardFace': 'seller', 'startCardNo': '210716160031', 'endCardNo': '210716160032', 'amount': 2}  
496 -  
497 -  
498 - </pre>  
499 - </div>  
500 - <!--css div popup end-->  
501 -  
502 - </td>  
503 - <td>无截图</td>  
504 -</tr>  
505 -  
506 -<tr id='pt1.1.2' class='hiddenRow'>  
507 - <td ><div class='testcase'>test_addSlaveCard:  
508 - 添加副卡  
509 - :return:  
510 - </div></td>  
511 - <td colspan='5' align='center'>  
512 -  
513 - <!--css div popup start-->  
514 - <span class='status passCase'>  
515 - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_pt1.1.2')" >  
516 - 通过</a></span>  
517 -  
518 - <div id='div_pt1.1.2' class="popup_window">  
519 - <div style='text-align: right; color:red;cursor:pointer'>  
520 - <a onfocus='this.blur();' onclick="document.getElementById('div_pt1.1.2').style.display = 'none' " >  
521 - [x]</a>  
522 - </div>  
523 - <pre>  
524 -  
525 -pt1.1.2: savaCard data ----&gt; {'cardType': '20', 'startCardNo': '210716160033', 'endCardNo': '210716160034', 'amount': 2}  
526 -{'code': '200', 'message': 'OK', 'result': 'OK', 'success': True}  
527 -  
528 -  
529 - </pre>  
530 - </div>  
531 - <!--css div popup end-->  
532 -  
533 - </td>  
534 - <td>无截图</td>  
535 -</tr>  
536 -  
537 -<tr id='pt1.1.3' class='hiddenRow'>  
538 - <td ><div class='testcase'>test_cardFaceCheck:  
539 - 市场卡面信息校验  
540 - :return:  
541 - </div></td>  
542 - <td colspan='5' align='center'>  
543 -  
544 - <!--css div popup start-->  
545 - <span class='status passCase'>  
546 - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_pt1.1.3')" >  
547 - 通过</a></span>  
548 -  
549 - <div id='div_pt1.1.3' class="popup_window">  
550 - <div style='text-align: right; color:red;cursor:pointer'>  
551 - <a onfocus='this.blur();' onclick="document.getElementById('div_pt1.1.3').style.display = 'none' " >  
552 - [x]</a>  
553 - </div>  
554 - <pre>  
555 -  
556 -pt1.1.3: [{'text': '-- 请选择 --', 'value': ''}, {'text': '买方卡', 'value': 'buyer'}, {'text': 'VIP买方卡', 'value': 'buyer_vip'}, {'text': '卖方卡', 'value': 'seller'}, {'text': '司机卡', 'value': 'driver'}]  
557 -  
558 -  
559 - </pre>  
560 - </div>  
561 - <!--css div popup end-->  
562 -  
563 - </td>  
564 - <td>无截图</td>  
565 -</tr>  
566 -  
567 -<tr id='pt1.1.4' class='hiddenRow'>  
568 - <td><div class='testcase'>test_cardType:  
569 - 卡类型校验  
570 - :return:  
571 - </div></td>  
572 - <td colspan='5' align='center'><span class='status passCase'>通过</span></td>  
573 - <td>无截图</td>  
574 -</tr>  
575 -  
576 -<tr id='pt1.1.5' class='hiddenRow'>  
577 - <td ><div class='testcase'>test_delStorageInRecord:  
578 - 正常删除卡片记录  
579 - :return:  
580 - </div></td>  
581 - <td colspan='5' align='center'>  
582 -  
583 - <!--css div popup start-->  
584 - <span class='status passCase'>  
585 - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_pt1.1.5')" >  
586 - 通过</a></span>  
587 -  
588 - <div id='div_pt1.1.5' class="popup_window">  
589 - <div style='text-align: right; color:red;cursor:pointer'>  
590 - <a onfocus='this.blur();' onclick="document.getElementById('div_pt1.1.5').style.display = 'none' " >  
591 - [x]</a>  
592 - </div>  
593 - <pre>  
594 -  
595 -pt1.1.5: savaCard data ----&gt; {'cardType': '10', 'cardFace': 'seller', 'startCardNo': '210716160040', 'endCardNo': '210716160041', 'amount': 2}  
596 -3324 ---------------- 3323  
597 -  
598 -  
599 - </pre>  
600 - </div>  
601 - <!--css div popup end-->  
602 -  
603 - </td>  
604 - <td>无截图</td>  
605 -</tr>  
606 -  
607 -<tr id='pt1.1.6' class='hiddenRow'>  
608 - <td ><div class='testcase'>test_delStorageInRecordFail_cardOut:  
609 - 存在出库卡片的入库记录,不能进行删除  
610 - :return:  
611 - </div></td>  
612 - <td colspan='5' align='center'>  
613 -  
614 - <!--css div popup start-->  
615 - <span class='status passCase'>  
616 - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_pt1.1.6')" >  
617 - 通过</a></span>  
618 -  
619 - <div id='div_pt1.1.6' class="popup_window">  
620 - <div style='text-align: right; color:red;cursor:pointer'>  
621 - <a onfocus='this.blur();' onclick="document.getElementById('div_pt1.1.6').style.display = 'none' " >  
622 - [x]</a>  
623 - </div>  
624 - <pre>  
625 -  
626 -pt1.1.6: savaCard data ----&gt; {'cardType': '10', 'cardFace': 'seller', 'startCardNo': '210716160043', 'endCardNo': '210716160044', 'amount': 2}  
627 -  
628 -  
629 - </pre>  
630 - </div>  
631 - <!--css div popup end-->  
632 -  
633 - </td>  
634 - <td>无截图</td>  
635 -</tr>  
636 -  
637 -<tr id='pt1.1.7' class='hiddenRow'>  
638 - <td ><div class='testcase'>test_delStorageInRecordFail_delCard:  
639 - 已作废的卡片不能被删除  
640 - :return:  
641 - </div></td>  
642 - <td colspan='5' align='center'>  
643 -  
644 - <!--css div popup start-->  
645 - <span class='status passCase'>  
646 - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_pt1.1.7')" >  
647 - 通过</a></span>  
648 -  
649 - <div id='div_pt1.1.7' class="popup_window">  
650 - <div style='text-align: right; color:red;cursor:pointer'>  
651 - <a onfocus='this.blur();' onclick="document.getElementById('div_pt1.1.7').style.display = 'none' " >  
652 - [x]</a>  
653 - </div>  
654 - <pre>  
655 -  
656 -pt1.1.7: savaCard data ----&gt; {'cardType': '10', 'cardFace': 'seller', 'startCardNo': '210716160045', 'endCardNo': '210716160046', 'amount': 2}  
657 -{'code': '10000', 'message': '有部分卡片已出库或作废,删除失败', 'result': '有部分卡片已出库或作废,删除失败', 'success': False}  
658 -  
659 -  
660 - </pre>  
661 - </div>  
662 - <!--css div popup end-->  
663 -  
664 - </td>  
665 - <td>无截图</td>  
666 -</tr>  
667 -  
668 -<tr id='pt1.1.8' class='hiddenRow'>  
669 - <td ><div class='testcase'>test_doCardStorageIn:  
670 - 卡片入库测试,新添加的卡片能正常的入库  
671 - :return:  
672 - </div></td>  
673 - <td colspan='5' align='center'>  
674 -  
675 - <!--css div popup start-->  
676 - <span class='status passCase'>  
677 - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_pt1.1.8')" >  
678 - 通过</a></span>  
679 -  
680 - <div id='div_pt1.1.8' class="popup_window">  
681 - <div style='text-align: right; color:red;cursor:pointer'>  
682 - <a onfocus='this.blur();' onclick="document.getElementById('div_pt1.1.8').style.display = 'none' " >  
683 - [x]</a>  
684 - </div>  
685 - <pre>  
686 -  
687 -pt1.1.8: savaCard data ----&gt; {'cardType': '10', 'cardFace': 'seller', 'startCardNo': '210716160048', 'endCardNo': '210716160049', 'amount': 2}  
688 -  
689 -  
690 - </pre>  
691 - </div>  
692 - <!--css div popup end-->  
693 -  
694 - </td>  
695 - <td>无截图</td>  
696 -</tr>  
697 -  
698 -<tr id='pt1.1.9' class='hiddenRow'>  
699 - <td ><div class='testcase'>test_duplicateStorageIn:  
700 - 测试卡片不能被重复入库  
701 - :return:  
702 - </div></td>  
703 - <td colspan='5' align='center'>  
704 -  
705 - <!--css div popup start-->  
706 - <span class='status passCase'>  
707 - <a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_pt1.1.9')" >  
708 - 通过</a></span>  
709 -  
710 - <div id='div_pt1.1.9' class="popup_window">  
711 - <div style='text-align: right; color:red;cursor:pointer'>  
712 - <a onfocus='this.blur();' onclick="document.getElementById('div_pt1.1.9').style.display = 'none' " >  
713 - [x]</a>  
714 - </div>  
715 - <pre>  
716 -  
717 -pt1.1.9: savaCard data ----&gt; {'cardType': '10', 'cardFace': 'seller', 'startCardNo': '210716160051', 'endCardNo': '210716160052', 'amount': 2}  
718 -savaCard data ----&gt; {'cardType': '10', 'cardFace': 'seller', 'startCardNo': '210716160051', 'endCardNo': '210716160052', 'amount': 2}  
719 -  
720 -  
721 - </pre>  
722 - </div>  
723 - <!--css div popup end-->  
724 -  
725 - </td>  
726 - <td>无截图</td>  
727 -</tr>  
728 -  
729 -<tr id='pt1.1.10' class='hiddenRow'>  
730 - <td><div class='testcase'>test_openCardStorageIn:  
731 - 入库列表查询测试  
732 - :return:  
733 - </div></td>  
734 - <td colspan='5' align='center'><span class='status passCase'>通过</span></td>  
735 - <td>无截图</td>  
736 -</tr>  
737 -  
738 -<tr id='total_row'>  
739 - <th>统计</th>  
740 - <th>10</th>  
741 - <th>10</th>  
742 - <th>0</th>  
743 - <th>0</th>  
744 - <th>&nbsp;</th>  
745 - <th>&nbsp;</th>  
746 -</tr>  
747 -</table>  
748 -<script>  
749 - showCase(0,1);  
750 - drawCircle('circle1',10, 0, 0);  
751 -</script>  
752 -  
753 -<div id='ending'>&nbsp;</div>  
754 -  
755 -</body>  
756 -</html>  
report/__init__.py deleted 100644 → 0
1 -# -*- coding: utf-8 -*-  
2 -  
3 -# @Time : 2021/7/16 14:09  
4 -# @Author : Ljq  
5 -# @File : __init__.py.py  
6 -# @Software: PyCharm  
7 -  
8 -"""  
9 -  
10 -"""  
report/test.log
1 -[2021-07-19 11:09:31] [INFO] : 发送邮件  
2 -[2021-07-19 11:09:33] [INFO] : 邮件发送完毕 1 +[2021-07-19 14:41:22] [INFO] : 发送邮件
  2 +[2021-07-19 14:41:25] [INFO] : 邮件发送完毕
testCase/main.py
@@ -19,6 +19,7 @@ from discover import DiscoveringTestLoader @@ -19,6 +19,7 @@ from discover import DiscoveringTestLoader
19 from commons import SendEmail as em 19 from commons import SendEmail as em
20 from commons import common as com 20 from commons import common as com
21 from commons.MySession import my 21 from commons.MySession import my
  22 +from commons.scripts import delReport
22 23
23 24
24 def Create_Testcase_suite(): 25 def Create_Testcase_suite():
@@ -40,7 +41,6 @@ def Run_Testcase(testsuit): @@ -40,7 +41,6 @@ def Run_Testcase(testsuit):
40 report_file = os.path.abspath(os.path.join(path, "../"))+ "/report/" + now + "_result.html" 41 report_file = os.path.abspath(os.path.join(path, "../"))+ "/report/" + now + "_result.html"
41 # 创建报告文件 42 # 创建报告文件
42 fp = open(report_file, 'wb') 43 fp = open(report_file, 'wb')
43 -  
44 runner = HTMLTestRunner_cn.HTMLTestRunner( 44 runner = HTMLTestRunner_cn.HTMLTestRunner(
45 stream=fp, 45 stream=fp,
46 title=u'重构项目接口测试报告', 46 title=u'重构项目接口测试报告',
@@ -50,6 +50,7 @@ def Run_Testcase(testsuit): @@ -50,6 +50,7 @@ def Run_Testcase(testsuit):
50 runner.run(testsuit) 50 runner.run(testsuit)
51 # 关闭文件 51 # 关闭文件
52 fp.close() 52 fp.close()
  53 + delReport.delReport(path)
53 return report_file 54 return report_file
54 55
55 56