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 | \ No newline at end of file | 26 | \ No newline at end of file |
main.py
@@ -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,'&'); | ||
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,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 |