Selenium基本使用(十二)测试报告生成
报告目录结构
Reporter根目录
|
|-------------LOGS
| |
| 2017-09-21_12-34-39 每次按日期时间动态生成报告目录
| |
| Image 用于存储每个功能点,验证截图,这个会显示在报告上
|
|--- LOG.XSLT #报告样式及格式
1、使用xslt,来设定样式
- <?xml version="1.0" encoding="utf-8"?>
- <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
- <xsl:template match="/">
- <html>
- <Head>
- <style type="text/css">
- body {
- background:#fff;
- margin:0;
- padding:40px 20px;
- font-family: "Arial", Arial, Sans-serif;
- font-size: 16px;
- color:#000;
- }
- table {
- margin:5px 5px 0;
- border:0px solid #222;
- font-size: 0.8em;
- }
- td {
- margin:5px 5px 0;
- padding:10px 10px 10px 10px;
- vertical-align:text-top;
- border:1px solid #222;
- border-width:1px 1px 1px 1px;
- }
- td.light {
- border:0px solid #222;
- }
- td.number {
- text-align:right;
- }
- td.status {
- text-align:right;
- vertical-align:text-bottom;
- }
- </style>
- </Head>
- <body>
- <!--OVER RESULT -->
- <xsl:variable name="OVER_STATUS" select="REPORT/OVER_STATUS"/>
- <xsl:variable name="STATUS" select="REPORT/LOG_ENTRY/STATUS"/>
- <h2>自动化测试执行报告</h2>
- <!--table -->
- <table border="1">
- <!--all result value-->
- <tr bgcolor="white" height = "35">
- <td>Overall Test Result</td>
- <td><xsl:value-of select="$OVER_STATUS"/></td>
- <td colspan="8"> </td>
- </tr>
- <tr bgcolor="#D8BFD9" height = "35">
- <th>Step</th>
- <th>Execute Time</th>
- <th>Step Result</th>
- <th>Description</th>
- <th>Step Description</th>
- <th>Action</th>
- <th>Index</th>
- <th>Element</th>
- <th>Value</th>
- <th>Expected Results </th>
- </tr>
- <!--select font color -->
- <xsl:variable name="fontColor">
- <xsl:choose>
- <xsl:when test="$STATUS = FAILED or $STATUS = PASSED">
- <xsl:text>white</xsl:text>
- </xsl:when>
- <xsl:otherwise>black</xsl:otherwise>
- </xsl:choose>
- </xsl:variable>
- <!-- Compute the background color according to the overall test result -->
- <xsl:variable name="StatusBackgroundColor">
- <xsl:choose>
- <xsl:when test="$STATUS = 'FAILED'">
- <!--<xsl:text>rgb(158, 48, 57)</xsl:text> -->
- <xsl:text>rgb(255, 40, 38)</xsl:text>
- </xsl:when>
- <xsl:when test="$STATUS = 'WARNING'">
- <xsl:text>rgb(132, 76, 84)</xsl:text>
- </xsl:when>
- <xsl:when test="$STATUS = 'PASSED'">
- <xsl:text>rgb(121, 180, 112)</xsl:text>
- </xsl:when>
- <xsl:when test="$STATUS = 'DONE'">
- <xsl:text>white</xsl:text>
- </xsl:when>
- <xsl:when test="$STATUS = 'INFO'">
- <xsl:text>white</xsl:text>
- </xsl:when>
- <xsl:otherwise>
- <xsl:text>white</xsl:text>
- </xsl:otherwise>
- </xsl:choose>
- </xsl:variable>
- <!--log entry-->
- <xsl:for-each select = "REPORT/LOG_ENTRY">
- <tr>
- <td><xsl:value-of select="STEP"/></td>
- <td><xsl:value-of select="EXECUTION_TIME"/></td>
- <td bgcolor="{$StatusBackgroundColor}"><xsl:value-of select="STEP_RESULT"/></td>
- <td><xsl:value-of select="DESCRIPTION"/></td>
- <td><xsl:value-of select="STEP_DESCRIPTION"/></td>
- <td><xsl:value-of select="ACTION"/></td>
- <td><xsl:value-of select="INDEX"/></td>
- <td><xsl:value-of select="ELEMENT"/></td>
- <td><xsl:value-of select="VALUE"/></td>
- <td><xsl:value-of select="EXPECTED_RESULTS"/></td>
- </tr>
- <!-- Store image path -->
- <xsl:variable name="Image">
- <xsl:value-of select="IMAGE_PATH"/>
- </xsl:variable>
- <!-- If XML contains an image path then display it according to the following -->
- <xsl:choose>
- <xsl:when test="normalize-space($Image)!=''">
- <!-- Comment the Next line to Stop showing embedded image in log and change the width number to make image size change-->
- <tr>
- <td colspan="10">
- <a href="{$Image}" target="_blank" >
- <img src="{$Image}" width="300"></img>
- </a>
- </td>
- </tr>
- </xsl:when>
- </xsl:choose>
- </xsl:for-each>
- <tr bgcolor="white">
- <font color="{$fontColor}">
- <td colspan="10">Overall Test Result: <xsl:value-of select="$OVER_STATUS"/></td>
- </font>
- </tr>
- </table>
- </body>
- </html>
- </xsl:template>
- </xsl:stylesheet>
2、生成xml报告(python代码会自动生成)
- <?xml version="1.0" encoding="utf-8"?>
- <?xml-stylesheet href="../../LOG.XSLT" type="text/xsl"?>
- <REPORT>
- <OVER_STATUS>PASSED</OVER_STATUS>
- <LOG_ENTRY>
- <STATUS>PASSED</STATUS>
- <STEP>2</STEP>
- <EXECUTION_TIME>2017-09-21_12-34-47</EXECUTION_TIME>
- <STEP_RESULT>PASSED</STEP_RESULT>
- <DESCRIPTION>普惠家登录</DESCRIPTION>
- <STEP_DESCRIPTION>输入'用户名'</STEP_DESCRIPTION>
- <ACTION>input</ACTION>
- <INDEX>By.XPATH</INDEX>
- <ELEMENT>//Input[@id='userName']</ELEMENT>
- <VALUE>msh195</VALUE>
- <EXPECTED_RESULTS></EXPECTED_RESULTS>
- <IMAGE_PATH></IMAGE_PATH>
- </LOG_ENTRY>
- <LOG_ENTRY>
- <STATUS>PASSED</STATUS>
- <STEP>3</STEP>
- <EXECUTION_TIME>2017-09-21_12-34-48</EXECUTION_TIME>
- <STEP_RESULT>PASSED</STEP_RESULT>
- <DESCRIPTION></DESCRIPTION>
- <STEP_DESCRIPTION>输入'密码'</STEP_DESCRIPTION>
- <ACTION>input</ACTION>
- <INDEX>By.XPATH</INDEX>
- <ELEMENT>//Input[@id='password']</ELEMENT>
- <VALUE>112233</VALUE>
- <EXPECTED_RESULTS></EXPECTED_RESULTS>
- <IMAGE_PATH></IMAGE_PATH>
- </LOG_ENTRY>
- <LOG_ENTRY>
- <STATUS>PASSED</STATUS>
- <STEP>4</STEP>
- <EXECUTION_TIME>2017-09-21_12-34-56</EXECUTION_TIME>
- <STEP_RESULT>PASSED</STEP_RESULT>
- <DESCRIPTION></DESCRIPTION>
- <STEP_DESCRIPTION>单击'立即登录'</STEP_DESCRIPTION>
- <ACTION>click</ACTION>
- <INDEX>By.LINK_TEXT</INDEX>
- <ELEMENT>立即登录</ELEMENT>
- <VALUE></VALUE>
- <EXPECTED_RESULTS></EXPECTED_RESULTS>
- <IMAGE_PATH></IMAGE_PATH>
- </LOG_ENTRY>
- <LOG_ENTRY>
- <STATUS>PASSED</STATUS>
- <STEP>5</STEP>
- <EXECUTION_TIME>2017-09-21_12-34-56</EXECUTION_TIME>
- <STEP_RESULT>PASSED</STEP_RESULT>
- <DESCRIPTION></DESCRIPTION>
- <STEP_DESCRIPTION>‘我的帐户’是否存在</STEP_DESCRIPTION>
- <ACTION>verify</ACTION>
- <INDEX>By.LINK_TEXT</INDEX>
- <ELEMENT>我的账户</ELEMENT>
- <VALUE></VALUE>
- <EXPECTED_RESULTS>登录成功,显示登录后页面</EXPECTED_RESULTS>
- <IMAGE_PATH>D:\PHJ\Reporter\LOGS\2017-09-21_12-34-39\Image\image_2017-09-21_12-34-56.png</IMAGE_PATH>
- </LOG_ENTRY>
- <LOG_ENTRY>
- <STATUS>PASSED</STATUS>
- <STEP>6</STEP>
- <EXECUTION_TIME>2017-09-21_12-34-59</EXECUTION_TIME>
- <STEP_RESULT>PASSED</STEP_RESULT>
- <DESCRIPTION>正常充值</DESCRIPTION>
- <STEP_DESCRIPTION>单击'充值'</STEP_DESCRIPTION>
- <ACTION>click</ACTION>
- <INDEX>By.XPATH</INDEX>
- <ELEMENT>//div[@class='account_center_tips_div_4 fl']/input</ELEMENT>
- <VALUE></VALUE>
- <EXPECTED_RESULTS></EXPECTED_RESULTS>
- <IMAGE_PATH></IMAGE_PATH>
- </LOG_ENTRY>
- <LOG_ENTRY>
- <STATUS>PASSED</STATUS>
- <STEP>7</STEP>
- <EXECUTION_TIME>2017-09-21_12-34-59</EXECUTION_TIME>
- <STEP_RESULT>PASSED</STEP_RESULT>
- <DESCRIPTION></DESCRIPTION>
- <STEP_DESCRIPTION>‘充值记录’是否存在</STEP_DESCRIPTION>
- <ACTION>verify</ACTION>
- <INDEX>By.LINK_TEXT</INDEX>
- <ELEMENT>充值记录</ELEMENT>
- <VALUE></VALUE>
- <EXPECTED_RESULTS>进入'充值页面',存在充值记录链接</EXPECTED_RESULTS>
- <IMAGE_PATH>D:\PHJ\Reporter\LOGS\2017-09-21_12-34-39\Image\image_2017-09-21_12-34-59.png</IMAGE_PATH>
- </LOG_ENTRY>
- <LOG_ENTRY>
- <STATUS>PASSED</STATUS>
- <STEP>8</STEP>
- <EXECUTION_TIME>2017-09-21_12-35-00</EXECUTION_TIME>
- <STEP_RESULT>PASSED</STEP_RESULT>
- <DESCRIPTION></DESCRIPTION>
- <STEP_DESCRIPTION>选择‘充值方式'绑定支付</STEP_DESCRIPTION>
- <ACTION>click</ACTION>
- <INDEX>By.ID</INDEX>
- <ELEMENT>rapid</ELEMENT>
- <VALUE></VALUE>
- <EXPECTED_RESULTS></EXPECTED_RESULTS>
- <IMAGE_PATH></IMAGE_PATH>
- </LOG_ENTRY>
- <LOG_ENTRY>
- <STATUS>PASSED</STATUS>
- <STEP>9</STEP>
- <EXECUTION_TIME>2017-09-21_12-35-02</EXECUTION_TIME>
- <STEP_RESULT>PASSED</STEP_RESULT>
- <DESCRIPTION></DESCRIPTION>
- <STEP_DESCRIPTION>输入‘金额’</STEP_DESCRIPTION>
- <ACTION>input</ACTION>
- <INDEX>By.ID</INDEX>
- <ELEMENT>recharge_money</ELEMENT>
- <VALUE>100</VALUE>
- <EXPECTED_RESULTS></EXPECTED_RESULTS>
- <IMAGE_PATH></IMAGE_PATH>
- </LOG_ENTRY>
- <LOG_ENTRY>
- <STATUS>PASSED</STATUS>
- <STEP>10</STEP>
- <EXECUTION_TIME>2017-09-21_12-35-03</EXECUTION_TIME>
- <STEP_RESULT>PASSED</STEP_RESULT>
- <DESCRIPTION></DESCRIPTION>
- <STEP_DESCRIPTION>单击‘确认充值’</STEP_DESCRIPTION>
- <ACTION>click</ACTION>
- <INDEX>By.LINK_TEXT</INDEX>
- <ELEMENT>确认充值</ELEMENT>
- <VALUE></VALUE>
- <EXPECTED_RESULTS></EXPECTED_RESULTS>
- <IMAGE_PATH></IMAGE_PATH>
- </LOG_ENTRY>
- <LOG_ENTRY>
- <STATUS>PASSED</STATUS>
- <STEP>11</STEP>
- <EXECUTION_TIME>2017-09-21_12-35-05</EXECUTION_TIME>
- <STEP_RESULT>PASSED</STEP_RESULT>
- <DESCRIPTION></DESCRIPTION>
- <STEP_DESCRIPTION>充值结果'对话框是否存在</STEP_DESCRIPTION>
- <ACTION>verify</ACTION>
- <INDEX>By.LINK_TEXT</INDEX>
- <ELEMENT>充值完成</ELEMENT>
- <VALUE></VALUE>
- <EXPECTED_RESULTS>弹出'充值结果'对话框,存在充值完成链接</EXPECTED_RESULTS>
- <IMAGE_PATH>D:\PHJ\Reporter\LOGS\2017-09-21_12-34-39\Image\image_2017-09-21_12-35-05.png</IMAGE_PATH>
- </LOG_ENTRY>
- </REPORT>
3、python生成报告代码
- #*_*coding:utf-8*_*
- import xml.dom.minidom as xmlDoc
- import os
- import gl
- import sys
- import time
- class cREPORTXML(object):
- def __init__(self):
- self.__struct = self.createReportNode()
- #创建report节点
- def createReportNode(self):
- try:
- xmlD = xmlDoc.Document()
- #xml样式
- xlstNode = xmlD.createProcessingInstruction("xml-stylesheet","href=\"../../LOG.XSLT\" type=\"text/xsl\"")
- xmlD.appendChild(xlstNode)
- report = xmlD.createElement('REPORT')
- xmlD.appendChild(report)
- overStatus = xmlD.createElement('OVER_STATUS')
- overStatus.appendChild(xmlD.createTextNode('PASSED'))
- report.appendChild(overStatus)
- returnResult = []
- returnResult.append(xmlD)
- returnResult.append(report)
- returnResult.append(overStatus)
- except Exception,ex:
- return ex.message
- return returnResult
- def writeOverStatus(self,overStatus = 'PASSED'):
- self.__struct[2]._get_childNodes().item(0).nodeValue = overStatus
- def writeReport(self,dict,xmlPath):
- #reportNodeList = self.createReportNode()
- entry = self.createLogEntry(self.__struct[0],dict)
- self.__struct[1].appendChild(entry)
- self.writeXml(self.__struct[0],xmlPath + r'\reportLog.xml')
- #self.writeXml(self.__struct[0],gl.reporterPath+'reportxml_%s.xml'%(gl.curTimeStr))
- #-------------创建xml格式-有多个相同的节点,并且该节点下有4个名称相同的子节点----------------
- #createLogEntry(self,docObj,executeTime,stepResult,description,stepDiscription,action,index,element,value,expectResult):
- def createLogEntry(self,docObj,dict):
- entry = docObj.createElement("LOG_ENTRY")
- status = docObj.createElement("STATUS")
- nodeStep = docObj.createElement("STEP")
- nodeExecuteTime = docObj.createElement("EXECUTION_TIME")
- nodeStepResult = docObj.createElement("STEP_RESULT")
- nodeComponentName = docObj.createElement("DESCRIPTION")
- nodeStepDiscription = docObj.createElement("STEP_DESCRIPTION")
- nodeActin = docObj.createElement("ACTION")
- nodeIndex = docObj.createElement("INDEX")
- nodeElement = docObj.createElement("ELEMENT")
- nodeValue = docObj.createElement("VALUE")
- nodeExpectResult = docObj.createElement("EXPECTED_RESULTS")
- nodeimagePath = docObj.createElement('IMAGE_PATH')
- status.appendChild(docObj.createTextNode(dict['stepResult']))
- nodeStep.appendChild(docObj.createTextNode(str(dict['Step'])))
- nodeExecuteTime.appendChild(docObj.createTextNode(dict['executeTime']))
- nodeStepResult.appendChild(docObj.createTextNode(dict['stepResult']))
- nodeComponentName.appendChild(docObj.createTextNode(dict['description']))
- nodeStepDiscription.appendChild(docObj.createTextNode(dict['stepDiscription']))
- nodeActin.appendChild(docObj.createTextNode(dict['action']))
- nodeIndex.appendChild(docObj.createTextNode(dict['index']))
- nodeElement.appendChild(docObj.createTextNode(dict['element']))
- nodeValue.appendChild(docObj.createTextNode(dict['value']))
- nodeExpectResult.appendChild(docObj.createTextNode(dict['expectResult']))
- nodeimagePath.appendChild(docObj.createTextNode(dict['ImagePath']))
- entry.appendChild(status)
- entry.appendChild(nodeStep)
- entry.appendChild(nodeExecuteTime)
- entry.appendChild(nodeStepResult)
- entry.appendChild(nodeComponentName)
- entry.appendChild(nodeStepDiscription)
- entry.appendChild(nodeActin)
- entry.appendChild(nodeIndex)
- entry.appendChild(nodeElement)
- entry.appendChild(nodeValue)
- entry.appendChild(nodeExpectResult)
- entry.appendChild(nodeimagePath)
- return entry
- #参数,xml对象,准备存储xml文件路径,文件模式:读 and 写 (r and w)
- def writeXml(self,xmlDoc,xmlPath):
- f = open(xmlPath,"w")
- xmlDoc.writexml(f,indent='\t', addindent='\t', newl='\n', encoding="utf-8")
- f.close()
4、生成效果(报告内显示图片,点击会显示大图)
Selenium基本使用(十二)测试报告生成的更多相关文章
- selenium python (十二)下拉框的处理
#!/usr/bin/python# -*- coding: utf-8 -*-__author__ = 'zuoanvip' #下拉框在web页面上非常常见,对于下拉框的处理采用二次定位的方法进行元 ...
- Python+Selenium笔记(十二):数据驱动测试
(一) 前言 通过使用数据驱动测试,实现对输入值和预期结果的参数化.(例如:输入数据和预期结果可以直接读取Excel文档的数据) (二) ddt 使用ddt执行数据驱动测试,ddt库可以将测试 ...
- Pytest学习(十二)-生成HTML报告插件之pytest-html的使用
环境前提 Python3.6+ 安装插件 pip3 install pytest-html -i http://pypi.douban.com/simple/ --trusted-host pypi. ...
- TensorFlow从1到2(十二)生成对抗网络GAN和图片自动生成
生成对抗网络的概念 上一篇中介绍的VAE自动编码器具备了一定程度的创造特征,能够"无中生有"的由一组随机数向量生成手写字符的图片. 这个"创造能力"我们在模型中 ...
- Selenium系列(十二) - 自动化必备知识之CSS选择器的详细使用
如果你还想从头学起Selenium,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1680176.html 其次,如果你不懂前端基础知识, ...
- selenium 自动化测试 测试报告 生成
https://www.cnblogs.com/yoyoketang/p/6140439.html https://www.cnblogs.com/testyao/p/5658200.html 一.下 ...
- 如何一步一步用DDD设计一个电商网站(十二)—— 提交并生成订单
阅读目录 前言 解决数据一致性的方案 回到DDD 设计 实现 结语 一.前言 之前的十一篇把用户购买商品并提交订单整个流程上的中间环节都过了一遍.现在来到了这最后一个环节,提交订单.单从业务上看,这个 ...
- Java进阶(五十二)利用LOG4J生成服务日志
Java进阶(五十二)利用LOG4J生成服务日志 前言 由于论文写作需求,需要进行流程挖掘.前提是需要有真实的事件日志数据.真实的事件日志数据可以用来发现.监控和提升业务流程. 为了获得真实的事件日志 ...
- 爬虫系列(十二) selenium的基本使用
一.selenium 简介 随着网络技术的发展,目前大部分网站都采用动态加载技术,常见的有 JavaScript 动态渲染和 Ajax 动态加载 对于爬取这些网站,一般有两种思路: 分析 Ajax 请 ...
随机推荐
- {前端CSS} 语法 Css的几种引入方式 css选择器 选择器的优先级 CSS属性相关 背景属性 边框 CSS盒子模型 清除浮动 overflow溢出属性 定位(position)z-index
前端CSS CSS介绍 CSS(Cascading Style Sheet,层叠样式表)定义如何显示HTML元素,给HTML设置样式,让它更加美观. 当浏览器读到一个样式表,它就会按照这个样式表来对文 ...
- [No0000100]正则表达式匹配解析过程分析(正则表达式匹配原理)&regexbuddy使用&正则优化
常见正则表达式引擎引擎决定了正则表达式匹配方法及内部搜索过程,了解它至关重要的.目前主要流行引擎有:DFA,NFA两种引擎. 引擎 区别点 DFA Deterministic finite autom ...
- [No0000C2]WPF 数据绑定的调试
)DataBinding的表达式无效时,跟踪Debug的输出信息来查找原因(2)DataBinding的表达式有效,但是数据和期望值不同,此时可以在Converter中断点调试 :在VS输出窗口跟踪信 ...
- en-zh(科学技术)science and technology
S Korea to roll out 5G韩国正式推5G商用服务 South Korea will become the first country to commercially launch f ...
- [yum] yum使用光盘安装或更新软件
https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/7/html/system_administrators_ ...
- 将DOS格式的shell脚本转为UNIX格式
shell脚本是UNIX格式,在修改其中内容时,务必保持UNIX格式.UE编辑器打开时,会询问是否转为DOS格式,请点否.如果修改完成后,不能确认是否为DOS格式,可以使用UE文件菜单下的Conver ...
- 《Redis 主从复制》
万念俱灰,说的就是我现在的心情...... 周六下午写了一下午的读书笔记,由于我的 MAC 有点问题,重启了一下...... 灰飞烟灭...... 读 第八章<集群> 总结 1:如何开启主 ...
- AES加解密所遇问题
AES加解密后解密数据末尾携带多余空格,经查看是由于加密时数据不足16个字节自动补齐导致 解决办法:记录加密数据长度,解密后根据数据长度读取解密数据. 另外加密数据中可能存在0等数据,所以拷贝内容时最 ...
- Log4j与Logback
一.Log4j简介: 1.Log4j(log for java) 01.是apache的一个开源项目 02.是使用java语言编写的一个日志框架 03.用于记录程序中的日志信息 04.可以将日志信息输 ...
- vim常用指令整理小结
启动Vim后,默认是在 Normal 模式下,但是我们有时不知道是在编辑模式还是normal模式,按ESC键就可以返回normal模式.因为所有的命令都需要在Normal模式下使用,所以建议多按几下E ...