Unittest扩展-自动生成HTML测试报告

Unittest扩展-自动生成HTML测试报告

在脚本运行完成之后,除了在log.txt文件查看到运行日志外,还可以使用HTMLTestRunner生成测试报告。HTMLTestRunner是在Python标准库的unittest单元测试框架下的一个扩展。

1 下载HTMLTestRunner.py

首先要下载HTMLTestRunner.py文件,下载地址如下:
http://tungwaiyip.info/software/HTMLTestRunner.html

HTMLTestRunner.py放置在Python的安装目录Lib路径下。

2 修改HTMLTestRunner.py

HTMLTestRunner.py是基于Python2来写的,若解释器为Python2,则不需要修改;
若解释器为Python3,为了使其支持Python3的环境,则需要针对HTMLTestRunner.py做一些修改。
python3中运行以上脚本报ImportError: No module named ‘StringIO’,因为HTMLTestRunner.py是基于python2开发的,在解决完问题1后,需要通过编辑器修改HTMLTestRunner.py文件如下内容:

  • 第94行,将import StringIO修改成import io

  • 第539行,将self.outputBuffer = StringIO.StringIO()修改成self.outputBuffer =
    io.StringIO()

  • 第642行,将if not rmap.has_key(cls):修改成if not cls in rmap:

  • 第766行,将uo = o.decode(‘latin-1’)修改成uo = e

  • 第775行,将ue = e.decode(‘latin-1’)修改成ue = e

  • 第631行,将print >> sys.stderr, ‘\nTime Elapsed: %s’ %
    (self.stopTime-self.startTime)修改成print(sys.stderr, ‘\nTime Elapsed:
    %s’ % (self.stopTime-self.startTime))

3 生成HTML测试报告案例

简单的以百度搜索功能测试为例:
在这里插入图片描述

生成HTML测试报告案例
简单的以百度搜索功能测试为例:

#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""=================================================
@Project -> File   :Auto_Test_First -> testBaidu.py
@IDE    :PyCharm
@Author :Mr.
@Date   :2019/11/26 19:36
@Desc   :百度搜索功能测试,生成测试报告
=================================================="""

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support.ui import Select
from selenium.common.exceptions import NoSuchElementException
from selenium.common.exceptions import NoAlertPresentException
import unittest, time, re
from HTMLTestRunner import HTMLTestRunner

class BaiduIde(unittest.TestCase):
    """百度测试类"""

    def setUp(self):
        self.driver = webdriver.Firefox()
        self.driver.implicitly_wait(20)
        self.base_url = "https://www.baidu.com/"
        self.verificationErrors = []
        self.accept_next_alert = True

    def test_baidu(self):
        """搜索关键词"""
        driver = self.driver
        driver.get(self.base_url + "/")
        driver.find_element_by_id("kw").clear()
        driver.find_element_by_id("kw").send_keys("HTMLTestRunner")
        driver.find_element_by_id("su").click()
        try:
            self.assertEqual("HTMLTestRunner_百度搜索", driver.title)
        except AssertionError as e:
            self.verificationErrors.append(str(e))
        driver.find_element_by_id("kw").clear()
        driver.find_element_by_id("kw").send_keys("Python+selenium")
        driver.find_element_by_id("su").click()

    def is_element_present(self, how, what):
        try:
            self.driver.find_element(by = how, value = what)
        except NoSuchElementException as msg:
            return False
        return True

    def is_alert_present(self):
        try:
            self.driver.switch_to_alert()
        except NoAlertPresentException as msg:
            return False
        return True

    def close_alert_and_get_its_text(self):
        try:
            alert = self.driver.switch_to_alert()
            alert_text = alert.text
            if self.accept_next_alert:
                alert.accept()
            else:
                alert.dismiss()
            return alert_text
        finally:
            self.accept_next_alert = True

    def tearDown(self):
        self.driver.quit()
        self.assertEqual([], self.verificationErrors)


if __name__ == "__main__":
    # unittest.main()
    # 构造测试集
    suite = unittest.TestSuite()
    suite.addTest(BaiduIde("test_baidu"))

    # # 方法一:原生的执行测试方法,生成测试日志log.txt
    # runner = unittest.TextTestRunner()
    # runner.run(suite)

    # 方法二:
    # 获取当前时间,目的是为了生成及时报告
    now_time = time.strftime("%Y_%m_%d_%H_%M_%S")
    # 定义报告存放路径
    fp = open("./Report/testReport"+now_time+".html", "wb")
    # 定义测试报告
    runner = HTMLTestRunner(stream=fp,
                            title="百度网搜索功能的测试报告",
                            description="测试用例执行情况:")
    # 运行测试用例
    runner.run(suite)
    # 关闭报告文件
    fp.close()
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: pytest是一种灵活而强大的自动化测试框架,用于编写和执行测试用例。在pytest的面试中,可能会涉及以下问题: 1. 你是如何使用pytest进行测试的? 使用pytest进行测试很简单。首先,安装pytest包。然后,创建一个以test_为前缀的Python文件,并在其中定义测试用例。在测试用例中,可以使用pytest提供的装饰器进行设置和标记。最后,通过运行pytest命令来执行测试。 2. pytest与其他测试框架相比有什么优势? 相比其他测试框架,pytest具有以下优势: - 简单易用:通过使用合适的装饰器和命名约定,pytest能够自动发现和执行测试用例,无需任何额外配置。 - 强大灵活:pytest提供了许多强大且灵活的功能,如参数化测试、测试数据生成、测试维护工具等。 - 易于扩展:使用pytest插件机制,可以通过安装插件来扩展框架的功能,满足各种测试需求。 - 丰富的报告和日志:pytest可以生成易于阅读的测试报告和详细的日志,方便定位和分析问题。 - 完善的社区支持:pytest拥有庞大的用户社区,可以获取到丰富的文档、教程和示例。 3. pytest如何处理测试用例的失败? 当某个测试用例失败时,pytest会自动记录失败的原因,并在测试执行完成后生成一个详细的测试报告。报告中会列出所有失败的测试用例及其失败的原因,方便开发人员进行排查和修复。 4. 如何使用pytest进行参数化测试? 在pytest中,可以使用@pytest.mark.parametrize装饰器来进行参数化测试。通过传入不同的参数组合,可以运行同一个测试用例的多个变种。这样可以有效减少编写重复的测试用例的工作量,提高测试的覆盖率。 5. pytest中的夹具(fixture)是什么?如何使用它? 夹具是pytest中的一个重要概念,它用于在测试用例之前进行一些准备工作,并在测试用例运行完成后进行清理。可以使用@pytest.fixture装饰器来创建夹具。夹具可以在测试函数参数中进行声明,从而在测试用例中直接使用。夹具还可以通过作用域的设置,控制其生命周期。 这些是关于pytest自动化测试的一些面试题及其答案,希望能对你有所帮助。当然,在实际面试中,还可能涉及到更多的问题和深入的理解。 ### 回答2: pytest是一个流行的Python测试框架,用于自动化测试。下面是关于pytest自动化测试的面试题的回答: 1. 为什么要使用pytest进行自动化测试? pytest提供了一种简单而强大的方式来编写自动化测试脚本。它支持丰富的断言,易于阅读的测试报告和灵活的测试组织结构,并且与其他流行的测试工具和框架(如Selenium)集成良好。 2. pytest是如何工作的? pytest基于Python的unittest模块,通过使用装饰器和命名约定来定义测试用例。它可以自动发现和执行测试,生成详细的测试报告,并且具有丰富的插件生态系统,可以扩展其功能。 3. pytestunittest有什么区别? 相比unittest,pytest提供了更简洁、更直观的语法和更丰富的功能。pytest不需要测试类的继承,而是使用函数来定义测试用例。pytest还提供了更多的断言方法和更灵活的测试组织结构,使得编写和维护测试脚本更加容易。 4. pytest如何处理测试用例的数据驱动? pytest支持使用参数化装饰器来实现数据驱动测试。通过在测试用例函数上添加参数化装饰器,可以传递多组参数进行多次测试,从而减少代码重复和维护成本。 5. pytest如何处理夹具(fixtures)? 夹具在pytest中是一个Python函数,用于创建测试环境或者提供测试数据。pytest的夹具功能非常强大,可以通过使用装饰器将夹具与测试函数关联起来,并可以在不同的测试用例之间共享夹具。 6. pytest如何生成测试报告? pytest默认生成详细而易于阅读的测试报告。可以通过使用pytest-html插件生成漂亮的HTML测试报告,或者使用pytest-xdist插件在分布式环境中运行测试。 总之,pytest是一个功能丰富、易于使用和扩展的自动化测试框架。它提供了简洁的语法、强大的断言和灵活的测试组织结构,可以帮助开发人员编写高效而可靠的自动化测试脚本。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值