Commit ca46482b3a3a7e968fa6b355b12b3e970d7bc638
1 parent
f1f467ef
更新测试报告删除方法
Showing
6 changed files
with
30 additions
and
770 deletions
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 | 26 | \ No newline at end of file | ... | ... |
main.py
... | ... | @@ -40,7 +40,6 @@ def Run_Testcase(testsuit): |
40 | 40 | report_file = os.path.abspath(os.path.join(path))+ "/report/" + now + "_result.html" |
41 | 41 | # 创建报告文件 |
42 | 42 | fp = open(report_file, 'wb') |
43 | - | |
44 | 43 | runner = HTMLTestRunner_cn.HTMLTestRunner( |
45 | 44 | stream=fp, |
46 | 45 | title=u'重构项目接口测试报告', |
... | ... | @@ -50,6 +49,7 @@ def Run_Testcase(testsuit): |
50 | 49 | runner.run(testsuit) |
51 | 50 | # 关闭文件 |
52 | 51 | fp.close() |
52 | + delReport.delReport(path) | |
53 | 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,'&'); | |
331 | - s = s.replace(/</g,'<'); | |
332 | - s = s.replace(/>/g,'>'); | |
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> </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 ----> {'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 ----> {'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 ----> {'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 ----> {'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 ----> {'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 ----> {'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 ----> {'cardType': '10', 'cardFace': 'seller', 'startCardNo': '210716160051', 'endCardNo': '210716160052', 'amount': 2} | |
718 | -savaCard data ----> {'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> </th> | |
745 | - <th> </th> | |
746 | -</tr> | |
747 | -</table> | |
748 | -<script> | |
749 | - showCase(0,1); | |
750 | - drawCircle('circle1',10, 0, 0); | |
751 | -</script> | |
752 | - | |
753 | -<div id='ending'> </div> | |
754 | - | |
755 | -</body> | |
756 | -</html> |
report/__init__.py deleted
100644 → 0
report/test.log
testCase/main.py
... | ... | @@ -19,6 +19,7 @@ from discover import DiscoveringTestLoader |
19 | 19 | from commons import SendEmail as em |
20 | 20 | from commons import common as com |
21 | 21 | from commons.MySession import my |
22 | +from commons.scripts import delReport | |
22 | 23 | |
23 | 24 | |
24 | 25 | def Create_Testcase_suite(): |
... | ... | @@ -40,7 +41,6 @@ def Run_Testcase(testsuit): |
40 | 41 | report_file = os.path.abspath(os.path.join(path, "../"))+ "/report/" + now + "_result.html" |
41 | 42 | # 创建报告文件 |
42 | 43 | fp = open(report_file, 'wb') |
43 | - | |
44 | 44 | runner = HTMLTestRunner_cn.HTMLTestRunner( |
45 | 45 | stream=fp, |
46 | 46 | title=u'重构项目接口测试报告', |
... | ... | @@ -50,6 +50,7 @@ def Run_Testcase(testsuit): |
50 | 50 | runner.run(testsuit) |
51 | 51 | # 关闭文件 |
52 | 52 | fp.close() |
53 | + delReport.delReport(path) | |
53 | 54 | return report_file |
54 | 55 | |
55 | 56 | ... | ... |