日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > HTML >内容正文

HTML

HTMLTestRunner文件

發布時間:2023/12/10 HTML 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 HTMLTestRunner文件 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?HTMLTestRunner文件,copy直接使用

#-*- coding: utf-8 -*- """ A TestRunner for use with the Python unit testing framework. It generates a HTML report to show the result at a glance.The simplest way to use this is to invoke its main method. E.g.import unittestimport HTMLTestRunner... define your tests ...if __name__ == '__main__':HTMLTestRunner.main()For more customization options, instantiates a HTMLTestRunner object. HTMLTestRunner is a counterpart to unittest's TextTestRunner. E.g.# output to a filefp = file('my_report.html', 'wb')runner = HTMLTestRunner.HTMLTestRunner(stream=fp,title='My unit test',description='This demonstrates the report output by HTMLTestRunner.')# Use an external stylesheet.# See the Template_mixin class for more customizable optionsrunner.STYLESHEET_TMPL = '<link rel="stylesheet" href="my_stylesheet.css" type="text/css">'# run the testrunner.run(my_test_suite)------------------------------------------------------------------------ Copyright (c) 2004-2007, Wai Yip Tung All rights reserved.Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:* Redistributions of source code must retain the above copyright notice,this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyrightnotice, this list of conditions and the following disclaimer in thedocumentation and/or other materials provided with the distribution. * Neither the name Wai Yip Tung nor the names of its contributors may beused to endorse or promote products derived from this software withoutspecific prior written permission.THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. """# URL: http://tungwaiyip.info/software/HTMLTestRunner.html__author__ = "Wai Yip Tung" __version__ = "0.8.3"""" Change History Version 0.8.4 by GoverSky * Add sopport for 3.x * Add piechart for resultpiechart * Add Screenshot for selenium_case test * Add Retry on failedVersion 0.8.3 * Prevent crash on class or module-level exceptions (Darren Wurf).Version 0.8.2 * Show output inline instead of popup window (Viorel Lupu).Version in 0.8.1 * Validated XHTML (Wolfgang Borgert). * Added description of test classes and test cases.Version in 0.8.0 * Define Template_mixin class for customization. * Workaround a IE 6 bug that it does not treat <script> block as CDATA.Version in 0.7.1 * Back port to Python 2.3 (Frank Horowitz). * Fix missing scroll bars in detail log (Podi). """# TODO: color stderr # TODO: simplify javascript using ,ore than 1 class in the class attribute? import datetimeimport sys import unittest from xml.sax import saxutilsPY3K = (sys.version_info[0] > 2) if PY3K:import io as StringIO else:import StringIO import copy# ------------------------------------------------------------------------ # The redirectors below are used to capture output during testing. Output # sent to sys.stdout and sys.stderr are automatically captured. However # in some cases sys.stdout is already cached before HTMLTestRunner is # invoked (e.g. calling logging_demo.basicConfig). In order to capture those # output, use the redirectors for the cached stream. # # e.g. # >>> logging_demo.basicConfig(stream=HTMLTestRunner.stdout_redirector) # >>>class OutputRedirector(object):""" Wrapper to redirect stdout or stderr """def __init__(self, fp):self.fp = fpdef write(self, s):self.fp.write(s)def writelines(self, lines):self.fp.writelines(lines)def flush(self):self.fp.flush()stdout_redirector = OutputRedirector(sys.stdout) stderr_redirector = OutputRedirector(sys.stderr)# ---------------------------------------------------------------------- # Templateclass Template_mixin(object):"""Define a HTML template for report customerization and generation.Overall structure of an HTML reportHTML+------------------------+|<html> || <head> || || STYLESHEET || +----------------+ || | | || +----------------+ || || </head> || || <body> || || HEADING || +----------------+ || | | || +----------------+ || || REPORT || +----------------+ || | | || +----------------+ || || ENDING || +----------------+ || | | || +----------------+ || || </body> ||</html> |+------------------------+"""STATUS = {0: u'通過',1: u'失敗',2: u'錯誤',}DEFAULT_TITLE = 'Unit Test Report'DEFAULT_DESCRIPTION = ''# ------------------------------------------------------------------------# HTML TemplateHTML_TMPL = r"""<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head><title>%(title)s</title><meta name="generator" content="%(generator)s"/><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>%(stylesheet)s </head> <body> <script language="javascript" type="text/javascript"> output_list = Array();/* level - 0:Summary; 1:Failed; 2:All */ function showCase(level) {trs = document.getElementsByTagName("tr");for (var i = 0; i < trs.length; i++) {tr = trs[i];id = tr.id;if (id.substr(0,2) == 'ft') {if (level < 1) {tr.className = 'hiddenRow';}else {tr.className = '';}}if (id.substr(0,2) == 'pt') {if (level > 1) {tr.className = '';}else {tr.className = 'hiddenRow';}}} }function showClassDetail(cid, count) {var id_list = Array(count);var toHide = 1;for (var i = 0; i < count; i++) {tid0 = 't' + cid.substr(1) + '.' + (i+1);tid = 'f' + tid0;tr = document.getElementById(tid);if (!tr) {tid = 'p' + tid0;tr = document.getElementById(tid);}id_list[i] = tid;if (tr.className) {toHide = 0;}}for (var i = 0; i < count; i++) {tid = id_list[i];if (toHide) {document.getElementById(tid).className = 'hiddenRow';}else {document.getElementById(tid).className = '';}} }function showTestDetail(div_id){var details_div = document.getElementById(div_id)var displayState = details_div.style.display// alert(displayState)if (displayState != 'block' ) {displayState = 'block'details_div.style.display = 'block'}else {details_div.style.display = 'none'} }function html_escape(s) {s = s.replace(/&/g,'&amp;');s = s.replace(/</g,'&lt;');s = s.replace(/>/g,'&gt;');return s; }function drawCircle(pass, fail, error){var color = ["#6c6","#c60","#c00"];var data = [pass,fail,error];var text_arr = ["pass", "fail", "error"];var canvas = document.getElementById("circle");var ctx = canvas.getContext("2d");var startPoint=0;var width = 20, height = 10;var posX = 112 * 2 + 20, posY = 30;var textX = posX + width + 5, textY = posY + 10;for(var i=0;i<data.length;i++){ctx.fillStyle = color[i];ctx.beginPath();ctx.moveTo(112,84);ctx.arc(112,84,84,startPoint,startPoint+Math.PI*2*(data[i]/(data[0]+data[1]+data[2])),false);ctx.fill();startPoint += Math.PI*2*(data[i]/(data[0]+data[1]+data[2]));ctx.fillStyle = color[i];ctx.fillRect(posX, posY + 20 * i, width, height);ctx.moveTo(posX, posY + 20 * i);ctx.font = 'bold 14px';ctx.fillStyle = color[i];var percent = text_arr[i] + ":"+data[i];ctx.fillText(percent, textX, textY + 20 * i);} }function show_img(obj) {var obj1 = obj.nextElementSiblingobj1.style.display='block'var index = 0;//每張圖片的下標,var len = obj1.getElementsByTagName('img').length;var imgyuan = obj1.getElementsByClassName('imgyuan')[0]//var start=setInterval(autoPlay,500);obj1.onmouseover=function(){//當鼠標光標停在圖片上,則停止輪播clearInterval(start);}obj1.onmouseout=function(){//當鼠標光標停在圖片上,則開始輪播start=setInterval(autoPlay,1000);}for (var i = 0; i < len; i++) {var font = document.createElement('font')imgyuan.appendChild(font)}var lis = obj1.getElementsByTagName('font');//得到所有圓圈changeImg(0)var funny = function (i) {lis[i].onmouseover = function () {index=ichangeImg(i)}}for (var i = 0; i < lis.length; i++) {funny(i);}function autoPlay(){if(index>len-1){index=0;clearInterval(start); //運行一輪后停止}changeImg(index++);}imgyuan.style.width= 25*len +"px";//對應圓圈和圖片同步function changeImg(index) {var list = obj1.getElementsByTagName('img');var list1 = obj1.getElementsByTagName('font');for (i = 0; i < list.length; i++) {list[i].style.display = 'none';list1[i].style.backgroundColor = 'white';}list[index].style.display = 'block';list1[index].style.backgroundColor = 'blue';}} function hide_img(obj){obj.parentElement.style.display = "none";obj.parentElement.getElementsByClassName('imgyuan')[0].innerHTML = ""; } </script> <div class="piechart"><div><canvas id="circle" width="350" height="168" </canvas></div> </div> %(heading)s %(report)s %(ending)s</body> </html> """# variables: (title, generator, stylesheet, heading, report, ending)# ------------------------------------------------------------------------# Stylesheet## alternatively use a <link> for external style sheet, e.g.# <link rel="stylesheet" href="$url" type="text/css">STYLESHEET_TMPL = """ <style type="text/css" media="screen"> body { font-family: verdana, arial, helvetica, sans-serif; font-size: 80%; } table { font-size: 100%; } pre {white-space: pre-wrap;word-wrap: break-word; }/* -- heading ---------------------------------------------------------------------- */ h1 {font-size: 16pt;color: gray; } .heading {margin-top: 0ex;margin-bottom: 1ex; }.heading .attribute {margin-top: 1ex;margin-bottom: 0; }.heading .description {margin-top: 4ex;margin-bottom: 6ex; }/* -- css div popup ------------------------------------------------------------------------ */ a.popup_link { }a.popup_link:hover {color: red; } .img{height: 100%;border-collapse: collapse;border: 2px solid #777; }.screenshots {z-index: 100;position:absolute;height: 80%;left: 50%;top: 50%;transform: translate(-50%,-50%);display: none; }.imgyuan{height: 20px;border-radius: 12px;background-color: red;padding-left: 13px;margin: 0 auto;position: relative;top: -40px;background-color: rgba(1, 150, 0, 0.3); } .imgyuan font{border:1px solid white;width:11px;height:11px;border-radius:50%;margin-right: 9px;margin-top: 4px;display: block;float: left;background-color: white; } .close_shots {background-image: url();background-size: 22px 22px;-moz-background-size: 22px 22px;background-repeat: no-repeat;position: absolute;top: 5px;right: 5px;height: 22px;z-index: 99;width: 22px; } .popup_window {display: none;position: relative;left: 0px;top: 0px;padding: 10px;background-color: #E6E6D6;font-family: "Lucida Console", "Courier New", Courier, monospace;text-align: left;font-size: 8pt; }} /* -- report ------------------------------------------------------------------------ */ #show_detail_line {margin-top: 3ex;margin-bottom: 1ex; }#result_table {margin: 1em 0;width: 100%;overflow: hidden;background: #FFF;color: #024457;border-radius: 10px;border: 1px solid #167F92; } #result_table th {border: 1px solid #FFFFFF;background-color: #167F92;color: #FFF;padding: 0.5em;&:first-child {display: table-cell;text-align: center;}&:nth-child(2) {display: table-cell;span {display:none;}&:after {content:attr(data-th);}}@media (min-width: 480px) {&:nth-child(2) {span {display: block;}&:after {display: none;}}}} #result_table td {word-wrap: break-word;max-width: 7em;padding: 0.3em;&:first-child {display: table-cell;text-align: center;}@media (min-width: 400px) {border: 1px solid #D9E4E6;}}#result_table th, td {margin: .5em 1em;@media (min-width: 400px) {display: table-cell;padding: 1em;}}#total_row { font-weight: bold; } .passClass { background-color: #6c6; !important ;} .failClass { background-color: #c60; !important ;} .errorClass { background-color: #c00; !important ; } .passCase { color: #6c6; } .failCase { color: #c60; font-weight: bold; } .errorCase { color: #c00; font-weight: bold; } tr[id^=pt] td { background-color: rgba(73,204,144,.3) !important ; } tr[id^=ft] td { background-color: rgba(252,161,48,.3) !important; } tr[id^=et] td { background-color: rgba(249,62,62,.3) !important ; } .hiddenRow { display: none; } .testcase { margin-left: 2em; }/* -- ending ---------------------------------------------------------------------- */ #ending { }.piechart{position:absolute; ;top:20px;left:300px;width: 200px;float: left;display: inline; }</style> """# ------------------------------------------------------------------------# Heading#HEADING_TMPL = """<div class='heading'> <h1>%(title)s</h1> %(parameters)s <p class='description'>%(description)s</p> </div>""" # variables: (title, parameters, description)HEADING_ATTRIBUTE_TMPL = """<p class='attribute'><strong>%(name)s:</strong> %(value)s</p> """ # variables: (name, value)# ------------------------------------------------------------------------# Report#REPORT_TMPL = """ <p id='show_detail_line'>顯示 <a href='javascript:showCase(0)'>概要</a> <a href='javascript:showCase(1)'>失敗</a> <a href='javascript:showCase(2)'>所有</a> </p><table id='result_table'> <colgroup> <col align='left' /> <col align='right' /> <col align='right' /> <col align='right' /> <col align='right' /> <col align='right' /> <col align='right' /> </colgroup> <tr id='header_row'><th>測試組/測試用例</th><th>總數</th><th>通過</th><th>失敗</th><th>錯誤</th><th>視圖</th><th>錯誤截圖</th> </tr> %(test_list)s <tr id='total_row'><th>統計</th><th>%(count)s</th><th>%(Pass)s</th><th>%(fail)s</th><th>%(error)s</th><th>&nbsp;</th><th>&nbsp;</th> </tr> </table> <script>showCase(1);drawCircle(%(Pass)s, %(fail)s, %(error)s); </script> """# variables: (test_list, count, Pass, fail, error)REPORT_CLASS_TMPL = r""" <tr class='%(style)s'><td>%(desc)s</td><td>%(count)s</td><td>%(Pass)s</td><td>%(fail)s</td><td>%(error)s</td><td><a href="javascript:showClassDetail('%(cid)s',%(count)s)">詳情</a></td><td>&nbsp;</td> </tr> """ # variables: (style, desc, count, Pass, fail, error, cid)REPORT_TEST_WITH_OUTPUT_TMPL = r""" <tr id='%(tid)s' class='%(Class)s'><td ><div class='testcase'>%(desc)s</div></td><td colspan='5' align='center'><!--css div popup start--><span class='status %(style)s'><a class="popup_link" onfocus='this.blur();' href="javascript:showTestDetail('div_%(tid)s')" >%(status)s</a></span><div id='div_%(tid)s' class="popup_window"><div style='text-align: right; color:red;cursor:pointer'><a onfocus='this.blur();' onclick="document.getElementById('div_%(tid)s').style.display = 'none' " >[x]</a></div><pre>%(script)s</pre></div><!--css div popup end--></td><td>%(img)s</td> </tr> """ # variables: (tid, Class, style, desc, status,img)REPORT_TEST_NO_OUTPUT_TMPL = r""" <tr id='%(tid)s' class='%(Class)s'><td><div class='testcase'>%(desc)s</div></td><td colspan='5' align='center'><span class='status %(style)s'>%(status)s</span></td><td>%(img)s</td> </tr> """ # variables: (tid, Class, style, desc, status,img)REPORT_TEST_OUTPUT_TMPL = r""" %(id)s: %(output)s """ # variables: (id, output)IMG_TMPL = r"""<a href="#" onclick="show_img(this)">顯示截圖</a><div align="center" class="screenshots" style="display:none"><a class="close_shots" href="#" onclick="hide_img(this)"></a>%(imgs)s<div class="imgyuan"></div></div>"""# ------------------------------------------------------------------------# ENDING#ENDING_TMPL = """<div id='ending'>&nbsp;</div>"""# -------------------- The end of the Template class -------------------def __getattribute__(self, item):value = object.__getattribute__(self, item)if PY3K:return valueelse:if isinstance(value, str):return value.decode("utf-8")else:return valueTestResult = unittest.TestResultclass _TestResult(TestResult):# note: _TestResult is a pure representation of results.# It lacks the output and reporting ability compares to unittest._TextTestResult.def __init__(self, verbosity=1, retry=0,save_last_try=True):TestResult.__init__(self)self.stdout0 = Noneself.stderr0 = Noneself.success_count = 0self.failure_count = 0self.error_count = 0self.verbosity = verbosity# result is a list of result in 4 tuple# (# result code (0: success; 1: fail; 2: error),# TestCase object,# Test output (byte string),# stack trace,# )self.result = []self.retry = retryself.trys = 0self.status = 0self.save_last_try = save_last_tryself.outputBuffer = StringIO.StringIO()def startTest(self, test):test.imgs = []# test.imgs = getattr(test, "imgs", [])TestResult.startTest(self, test)self.outputBuffer.seek(0)self.outputBuffer.truncate()stdout_redirector.fp = self.outputBufferstderr_redirector.fp = self.outputBufferself.stdout0 = sys.stdoutself.stderr0 = sys.stderrsys.stdout = stdout_redirectorsys.stderr = stderr_redirectordef complete_output(self):"""Disconnect output redirection and return buffer.Safe to call multiple times."""if self.stdout0:sys.stdout = self.stdout0sys.stderr = self.stderr0self.stdout0 = Noneself.stderr0 = Nonereturn self.outputBuffer.getvalue()def stopTest(self, test):# Usually one of addSuccess, addError or addFailure would have been called.# But there are some path in unittest that would bypass this.# We must disconnect stdout in stopTest(), which is guaranteed to be called.if self.retry:if self.status == 1:self.trys += 1if self.trys <= self.retry:if self.save_last_try:t = self.result.pop(-1)if t[0]==1:self.failure_count-=1else:self.error_count -= 1test=copy.copy(test)sys.stderr.write("Retesting... ")sys.stderr.write(str(test))sys.stderr.write('..%d \n' % self.trys)doc = test._testMethodDoc or ''if doc.find('_retry')!=-1:doc = doc[:doc.find('_retry')]desc ="%s_retry:%d" %(doc, self.trys)if not PY3K:if isinstance(desc, str):desc = desc.decode("utf-8")test._testMethodDoc = desctest(self)else:self.status = 0self.trys = 0self.complete_output()def addSuccess(self, test):self.success_count += 1self.status = 0TestResult.addSuccess(self, test)output = self.complete_output()self.result.append((0, test, output, ''))if self.verbosity > 1:sys.stderr.write('ok ')sys.stderr.write(str(test))sys.stderr.write('\n')else:sys.stderr.write('.')def addError(self, test, err):self.error_count += 1self.status = 1TestResult.addError(self, test, err)_, _exc_str = self.errors[-1]output = self.complete_output()self.result.append((2, test, output, _exc_str))if not getattr(test, "driver",""):passelse:try:driver = getattr(test, "driver")test.imgs.append(driver.get_screenshot_as_base64())except Exception:passif self.verbosity > 1:sys.stderr.write('E ')sys.stderr.write(str(test))sys.stderr.write('\n')else:sys.stderr.write('E')def addFailure(self, test, err):self.failure_count += 1self.status = 1TestResult.addFailure(self, test, err)_, _exc_str = self.failures[-1]output = self.complete_output()self.result.append((1, test, output, _exc_str))if not getattr(test, "driver",""):passelse:try:driver = getattr(test, "driver")test.imgs.append(driver.get_screenshot_as_base64())except Exception as e:passif self.verbosity > 1:sys.stderr.write('F ')sys.stderr.write(str(test))sys.stderr.write('\n')else:sys.stderr.write('F')class HTMLTestRunner(Template_mixin):def __init__(self, stream=sys.stdout, verbosity=2, title=None, description=None, retry=0,save_last_try=False):self.stream = streamself.retry = retryself.save_last_try=save_last_tryself.verbosity = verbosityif title is None:self.title = self.DEFAULT_TITLEelse:self.title = titleif description is None:self.description = self.DEFAULT_DESCRIPTIONelse:self.description = descriptionself.startTime = datetime.datetime.now()def run(self, test):"Run the given test case or test suite."result = _TestResult(self.verbosity, self.retry, self.save_last_try)test(result)self.stopTime = datetime.datetime.now()self.generateReport(test, result)if PY3K:# for python3# print('\nTime Elapsed: %s' % (self.stopTime - self.startTime),file=sys.stderr)output = '\nTime Elapsed: %s' % (self.stopTime - self.startTime)sys.stderr.write(output)else:print >> sys.stderr, '\nTime Elapsed: %s' % (self.stopTime - self.startTime)return resultdef sortResult(self, result_list):# unittest does not seems to run in any particular order.# Here at least we want to group them together by class.rmap = {}classes = []for n, t, o, e in result_list:cls = t.__class__if not cls in rmap:rmap[cls] = []classes.append(cls)rmap[cls].append((n, t, o, e))r = [(cls, rmap[cls]) for cls in classes]return rdef getReportAttributes(self, result):"""Return report attributes as a list of (name, value).Override this to add custom attributes."""startTime = str(self.startTime)[:19]duration = str(self.stopTime - self.startTime)status = []if result.success_count:status.append(u'<span class="tj passCase">Pass</span>%s' % result.success_count)if result.failure_count:status.append(u'<span class="tj failCase">Failure</span>%s' % result.failure_count)if result.error_count:status.append(u'<span class="tj errorCase">Error</span>%s' % result.error_count)if status:status = ' '.join(status)else:status = 'none'return [(u'開始時間', startTime),(u'耗時', duration),(u'狀態', status),]def generateReport(self, test, result):report_attrs = self.getReportAttributes(result)generator = 'HTMLTestRunner %s' % __version__stylesheet = self._generate_stylesheet()heading = self._generate_heading(report_attrs)report = self._generate_report(result)ending = self._generate_ending()output = self.HTML_TMPL % dict(title=saxutils.escape(self.title),generator=generator,stylesheet=stylesheet,heading=heading,report=report,ending=ending,)if PY3K:self.stream.write(output.encode())else:self.stream.write(output.encode('utf8'))def _generate_stylesheet(self):return self.STYLESHEET_TMPLdef _generate_heading(self, report_attrs):a_lines = []for name, value in report_attrs:line = self.HEADING_ATTRIBUTE_TMPL % dict(name=name,value=value,)a_lines.append(line)heading = self.HEADING_TMPL % dict(title=saxutils.escape(self.title),parameters=''.join(a_lines),description=saxutils.escape(self.description),)return headingdef _generate_report(self, result):rows = []sortedResult = self.sortResult(result.result)for cid, (cls, cls_results) in enumerate(sortedResult):# subtotal for a classnp = nf = ne = 0for n, t, o, e in cls_results:if n == 0:np += 1elif n == 1:nf += 1else:ne += 1# format class descriptionif cls.__module__ == "__main__":name = cls.__name__else:name = "%s.%s" % (cls.__module__, cls.__name__)doc = cls.__doc__ and cls.__doc__.split("\n")[0] or ""desc = doc and '%s: %s' % (name, doc) or nameif not PY3K:if isinstance(desc, str):desc = desc.decode("utf-8")row = self.REPORT_CLASS_TMPL % dict(style=ne > 0 and 'errorClass' or nf > 0 and 'failClass' or 'passClass',desc=desc,count=np + nf + ne,Pass=np,fail=nf,error=ne,cid='c%s' % (cid + 1),)rows.append(row)for tid, (n, t, o, e) in enumerate(cls_results):self._generate_report_test(rows, cid, tid, n, t, o, e)report = self.REPORT_TMPL % dict(test_list=u''.join(rows),count=str(result.success_count + result.failure_count + result.error_count),Pass=str(result.success_count),fail=str(result.failure_count),error=str(result.error_count),)return reportdef _generate_report_test(self, rows, cid, tid, n, t, o, e):# e.g. 'pt1.1', 'ft1.1', etchas_output = bool(o or e)tid = (n == 0 and 'p' or 'f') + 't%s.%s' % (cid + 1, tid + 1)name = t.id().split('.')[-1]if self.verbosity > 1:doc = t._testMethodDoc or ''else:doc = ""desc = doc and ('%s: %s' % (name, doc)) or nameif not PY3K:if isinstance(desc, str):desc = desc.decode("utf-8")tmpl = has_output and self.REPORT_TEST_WITH_OUTPUT_TMPL or self.REPORT_TEST_NO_OUTPUT_TMPL# o and e should be byte string because they are collected from stdout and stderr?if isinstance(o, str):# uo = unicode(o.encode('string_escape'))if PY3K:uo = oelse:uo = o.decode('utf-8', 'ignore')else:uo = oif isinstance(e, str):# ue = unicode(e.encode('string_escape'))if PY3K:ue = eelif e.find("Error") != -1 or e.find("Exception") != -1:es = e.decode('utf-8', 'ignore').split('\n')es[-2] = es[-2].decode('unicode_escape')ue = u"\n".join(es)else:ue = e.decode('utf-8', 'ignore')else:ue = escript = self.REPORT_TEST_OUTPUT_TMPL % dict(id=tid,output=saxutils.escape(uo + ue),)if getattr(t,'imgs',[]):# 判斷截圖列表,如果有則追加tmp = u""for i, img in enumerate(t.imgs):if i==0:tmp+=""" <img src="https://img-blog.csdnimg.cn/2022010623342852517.jpg" style="display: block;" class="img"/>\n""" % imgelse:tmp+=""" <img src="https://img-blog.csdnimg.cn/2022010623342852517.jpg" style="display: none;" class="img"/>\n""" % imgimgs = self.IMG_TMPL % dict(imgs=tmp)else:imgs = u"""無截圖"""row = tmpl % dict(tid=tid,Class=(n == 0 and 'hiddenRow' or 'none'),style=n == 2 and 'errorCase' or (n == 1 and 'failCase' or 'passCase'),desc=desc,script=script,status=self.STATUS[n],img=imgs,)rows.append(row)if not has_output:returndef _generate_ending(self):return self.ENDING_TMPL############################################################################## # Facilities for running tests from the command line ############################################################################### Note: Reuse unittest.TestProgram to launch test. In the future we may # build our own launcher to support more specific command line # parameters like test title, CSS, etc. class TestProgram(unittest.TestProgram):"""A variation of the unittest.TestProgram. Please refer to the baseclass for command line parameters."""def runTests(self):# Pick HTMLTestRunner as the default test runner.# base class's testRunner parameter is not useful because it means# we have to instantiate HTMLTestRunner before we know self.verbosity.if self.testRunner is None:self.testRunner = HTMLTestRunner(verbosity=self.verbosity)unittest.TestProgram.runTests(self)main = TestProgram############################################################################## # Executing this module from the command line ##############################################################################if __name__ == "__main__":main(module=None)

?

總結

以上是生活随笔為你收集整理的HTMLTestRunner文件的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲免费视频一区 | 香蕉视频国产在线观看 | 日韩久草 | 日韩欧美一级二级 | 天天干天天色天天射 | 国产精品一区二区三区免费视频 | 日韩av一区二区三区在线观看 | 日韩永久 | 白峰美羽在线播放 | 综合网五月天 | 欧美三级欧美成人高清 | 噜噜噜久久,亚洲精品国产品 | 久草高清 | 欧美三级韩国三级日本三斤 | 久久精品国产亚洲av高清色欲 | 久久性生活 | 在线观看国产精品视频 | 久久久精品视频免费 | 玖玖精品在线 | 窝窝在线视频 | 亚洲国产精品狼友在线观看 | 成人在线不卡 | 高清视频免费在线观看 | av有声小说一区二区三区 | 黄色免费网站视频 | 国产精品久久久久影院色老大 | 青青草原国产视频 | 亚洲国产成人精品女人久久久 | www黄色com| 天天操天天添 | 蜜桃av乱码一区二区三区 | 国产尤物视频在线 | 青青操视频在线 | 国产91国语对白在线 | 99久久久无码国产精品性波多 | 中文字幕在线资源 | 成年人在线视频网站 | 13日本xxxxxⅹxxx20 | 中国在线观看免费高清视频播放 | 特级西西444www大精品视频 | 欧美不卡 | 天天av网 | 中文字幕一区二区三区人妻电影 | 成年男女免费视频网站 | 国产熟妇与子伦hd | 玩偶游戏在线观看免费 | 狠狠干2023| 日韩欧美在线视频免费观看 | 亚洲免费视频一区二区 | 亚洲国产免费看 | 成人网战| 精品无码国产一区二区三区av | 青青青在线免费 | 亚洲生活片 | 午夜影院在线免费观看 | 久久精品99久久久 | 182av| 中国老头性行为xxxx | 国产电影一区二区三区 | 国产精品1区2区 | 丰满岳跪趴高撅肥臀尤物在线观看 | 欧美午夜视频在线观看 | 在办公室被c到呻吟的动态图 | av黄| 欧美v日韩 | av巨作| 屁屁影院国产第一页 | 人体私拍套图hdxxxx | 久久久久www | 亚洲区小说区图片区 | 日韩avwww | 日本一区二区在线免费 | 亚洲日本va中文字幕 | 国产又大又硬又粗 | 婷婷99| 婷婷六月天 | 欧美一级在线免费观看 | 色爽爽爽爽爽爽爽爽 | 亚洲一区色 | 成年人黄色 | 欧美日韩a | 三级网站免费看 | 欧美又粗又大aaa片 老熟妇仑乱视频一区二区 亚洲妇女体内精汇编 | 国产精品人人爽 | 亚洲欧洲日韩av | 国产精品久久久久久妇女6080 | 欧美另类69xxxx | 你懂的在线观看网站 | 黄色av网站在线观看 | 日本不卡一区二区三区视频 | 凹凸日日摸日日碰夜夜 | 中文字幕一区二区三区人妻四季 | 久久国产精品久久精品国产 | 国产女人18水真多18精品一级做 | 午夜国产福利视频 | 特级西西444www高清大胆免费看 | 九九热在线免费视频 | 欧美xxxxx高潮喷水麻豆 | 久久黄网站|