Python单元测试框架之pytest -- 生成测试报告

简介:

继续pytest单元测试框架的学习,pytest可以生成多种类型的测试报告。这一节就来学习pytest如何生成测试报告。

  创建test_calss.py 测试用例文件,这里以测试该文件为例。

复制代码
#coding=utf-8

class TestClass:

    def test_one(self):
        x = "this"
        assert "h" in x

    def test_two(self):
        x = "hello"
        assert x == "hi"
复制代码

 

 

生成resultlog文件                                                         

 创建普通的结果文件:

> py.test test_class.py  --resultlog=./log.txt

  指定当前路径下生成log.txt文件,打开文件,内容如下:

复制代码
. test_class.py::TestClass::()::test_one
F test_class.py::TestClass::()::test_two
 self = <test_class.TestClass instance at 0x000000000307C788>
 
     def test_two(self):
             x = "hello"
 >           assert x == "hi"
 E           assert 'hello' == 'hi'
 E             - hello
 E             + hi
 
 test_class.py:11: AssertionError
复制代码

 

 

生成JunitXML文件                        

> py.test test_class.py  --junitxml=./log.xml

  同样指定在当前目录下生成log.xml文件,打开文件内容如下:

复制代码
<?xml version="1.0" encoding="utf-8"?>
<testsuite errors="0" failures="1" name="pytest" skips="0" tests="2" time="0.015">
    <testcase classname="test_class.TestClass" name="test_one" time="0.0"/>
    <testcase classname="test_class.TestClass" name="test_two" time="0.00300002098083">
        <failure message="assert &apos;hello&apos; == &apos;hi&apos;
        - hello
          + hi">self = &lt;test_class.TestClass instance at 0x000000000309C948&gt;

            def test_two(self):
                    x = &quot;hello&quot;
        &gt;           assert x == &quot;hi&quot;
        E           assert &apos;hello&apos; == &apos;hi&apos;
        E             - hello
        E             + hi

        test_class.py:11: AssertionError
        </failure>
    </testcase>
</testsuite>
复制代码

  创建这样的XML文件有有什么用? 主要是为了方便Jenkin或其它的持续集成工具俱读取。

 

 

创建测试用例的URL                                                

> py.test test_class.py  --pastebin=all

复制打印结果最后生成的session-log测试报告链接到浏览器:

https://bpaste.net/show/4815ce13c164

这样的结果展示将非常友好。

 

当然,你也可以只选择展示faile的测试用例

> py.test test_class.py  --pastebin=failed

 

 

生成html测试报告                              

  当然,更多时候,我们希望pytest能生成漂亮的测试报告。这需要安装pytest的扩展--pytest-html

> pip install pytest-html     # 通过pip安装pytest-html

 

cmd命令提示符下执行测试文件:

>py.test test_class.py --html=./report.html

指定在当前目录下生成report.html文件,打开测试文件:

 

目录
相关文章
|
20天前
|
SQL JavaScript 前端开发
基于Python访问Hive的pytest测试代码实现
根据《用Java、Python来开发Hive应用》一文,建立了使用Python、来开发Hive应用的方法,产生的代码如下
49 6
基于Python访问Hive的pytest测试代码实现
|
4天前
|
JSON 测试技术 数据库
|
8天前
|
开发框架 JSON 缓存
震撼发布!Python Web开发框架下的RESTful API设计全攻略,让数据交互更自由!
在数字化浪潮推动下,RESTful API成为Web开发中不可或缺的部分。本文详细介绍了在Python环境下如何设计并实现高效、可扩展的RESTful API,涵盖框架选择、资源定义、HTTP方法应用及响应格式设计等内容,并提供了基于Flask的示例代码。此外,还讨论了版本控制、文档化、安全性和性能优化等最佳实践,帮助开发者实现更流畅的数据交互体验。
25 1
|
15天前
|
JSON 测试技术 数据库
Python的Flask框架
Python的Flask框架
|
28天前
|
JSON 测试技术 数据库
Python的Flask框架
Python的Flask框架
|
2月前
|
Java 测试技术 开发者
在软件开发中,测试至关重要,尤以单元测试和集成测试为然
在软件开发中,测试至关重要,尤以单元测试和集成测试为然。单元测试聚焦于Java中的类或方法等最小单元,确保其独立功能正确无误,及早发现问题。集成测试则着眼于模块间的交互,验证整体协作效能。为实现高效测试,需编写可测性强的代码,并选用JUnit等合适框架。同时,合理规划测试场景与利用Spring等工具也必不可少。遵循最佳实践,可提升测试质量,保障Java应用稳健前行。
38 1
|
2月前
|
JSON Dubbo 测试技术
单元测试问题之增加JCode5插件生成的测试代码的可信度如何解决
单元测试问题之增加JCode5插件生成的测试代码的可信度如何解决
47 2
单元测试问题之增加JCode5插件生成的测试代码的可信度如何解决
|
1月前
|
IDE 测试技术 持续交付
Python自动化测试与单元测试框架:提升代码质量与效率
【9月更文挑战第3天】随着软件行业的迅速发展,代码质量和开发效率变得至关重要。本文探讨了Python在自动化及单元测试中的应用,介绍了Selenium、Appium、pytest等自动化测试框架,以及Python标准库中的unittest单元测试框架。通过详细阐述各框架的特点与使用方法,本文旨在帮助开发者掌握编写高效测试用例的技巧,提升代码质量与开发效率。同时,文章还提出了制定测试计划、持续集成与测试等实践建议,助力项目成功。
53 5
|
2月前
|
JSON 测试技术 数据格式
单元测试问题之使用JCode5插件生成测试类如何解决
单元测试问题之使用JCode5插件生成测试类如何解决
68 3
|
2月前
|
测试技术
单元测试问题之使用TestMe时利用JUnit 5的参数化测试特性如何解决
单元测试问题之使用TestMe时利用JUnit 5的参数化测试特性如何解决
27 2
下一篇
无影云桌面