web 自动化之 Unittest 应用:报告&装饰器&断言

文章目录

一、常见的第三方库结合 unittest 生产 html 格式测试报告

1、HtmlTestRunner

官网下载 HtmlTestRunner.py 只能支持 python2 版本,支持 Python3 ,需要做修改

路径:python安装路径/Lib

复制代码
import unittest
from TestReport.testcase_01 import TestCase01
import HTMLTestRunner

# 加载用例
testcases = unittest.TestLoader().loadTestsFromTestCase(TestCase01)
# HTMLTestRunner 生成的测试报告
with open('F:/Pycharm/TestShop/TestReport/html_report.html', 'wb+') as hf:
    HTMLTestRunner.HTMLTestRunner(stream=hf,title="Html 测试报告",description="测试用例执行详情").run(testcases)

HTMLTestRunner 文件内容

2、BeatifulReport

安装三方库:BeatifulReport

复制代码
import unittest
from TestReport.testcase_01 import TestCase01
from BeautifulReport import BeautifulReport

# 加载用例
testcases = unittest.TestLoader().loadTestsFromTestCase(TestCase01)
# BeautifulReport 生成的测试报告
BeautifulReport(testcases).report(description="Html 测试报告",filename="report_bf",report_dir="reports")

企业测试报告的优化及定制 优化测试报告模板 通过 js+html/html5

pytest+allure 生成更加美观的测试报告+优化定制(装饰器)

二、装饰器 @ unittest.skip 强制跳过&条件跳过

复制代码
import unittest
"""
@unittest.skip 强制跳过执行
@unittest.skipIf 符合条件,则跳过执行
@unittest.skipUnless 条件不成立,则跳过执行
"""
# @unittest.skipUnless(False,"装饰器也可以作用于类,整个模块下的用例强制跳过执行")
class TestCase01(unittest.TestCase):
    @unittest.skip("此用例暂时不启用")
    def test_login(self):
        print('test_01')
    @unittest.skipIf(True,"符合条件,则跳过执行")
    def test_select_goods(self):
        print('test_02')
    @unittest.skipUnless(2>3, "不符合条件,则跳过执行")
    def test_put_to_cart(self):
        print('test_03')
    def test_pay_goods(self):
        print('test_04')
if __name__ == '__main__':
    unittest.main()

三、unittest的常用断言方法

复制代码
import unittest
from selenium import webdriver
import time
from selenium.webdriver.common.by import By

'''
二、常用断言方法
1、assertIn(字符1,字符2) 字符1是否包含在字符2
2、self.assertNotIn(字符1,字符2)  字符1不包含包含在字符2
self.assertEqual(参数1,参数2,"断言失败的描述")  参数1等于参数2
self.assertNotEqual(参数1,参数2,"断言失败的描述")参数不等于参数2
self.assertTrue(True)
self.assertFalse(False)
'''
class TestCase02(unittest.TestCase):
    def setUp(self) -> None:
        # 打开浏览器
        self.driver = webdriver.Edge()
        # 加载地址
        self.driver.get("http://116.62.63.211/shop/")

    def test_login(self):
        """
        登录用例
        """
        username = "hc_test"
        password = "hctest123"
        el_login_link = self.driver.find_element(By.LINK_TEXT, "登录")
        # 点击登录
        el_login_link.click()
        time.sleep(1)
        el_login = self.driver.find_element(By.XPATH, '//button[text()="登录"]')
        el_username = self.driver.find_element(By.NAME, "accounts")
        el_password = self.driver.find_element(By.XPATH, '//input[@type="password"]')

        # 输入用户名
        el_username.send_keys(username)
        # 输入密码
        el_password.send_keys(password)
        # 点击登录
        time.sleep(1)
        el_login.click()
        time.sleep(2)
        # 断言  获取账号的名称=username
        el_username = self.driver.find_element(By.XPATH, "//div[@class='menu-hd']/em[2]")
        self.assertIn(username, el_username.text)

    def test_select_goods(self):
        """
        检索商品
        """
        self.driver.get("http://116.62.63.211/shop/")
        select_goods = "手机"
        # 定位搜索输入
        el_select = self.driver.find_element(By.ID, "search-input")
        el_select.send_keys(select_goods)
        el_button = self.driver.find_element(By.ID, "ai-topsearch")
        el_button.click()
        time.sleep(2)
        # 断言:验证测试结果与预期结果是否一致
        # 获取商品列表的标题
        el_goods = self.driver.find_elements(By.XPATH, "//div[@class='items am-padding-bottom-xs']")
        # 判断content是否包含手机字符?
        # 标题是否包含手机
        for el in el_goods:
            self.assertIn(select_goods, el.text, "商品标题中未包含检索内容")
    def tearDown(self) -> None:
        self.driver.close()

if __name__ == '__main__':
    unittest.main()
相关推荐
农夫山泉的小黑14 分钟前
【DeepSeek帮我准备前端面试100问】(十八)Reflect在vue3的使用
前端·面试
Achieve前端实验室20 分钟前
【每日一面】手写防抖函数
前端·面试·node.js
三十_25 分钟前
TypeORM 多对多关联篇:中间表、JoinTable 与复杂关系的建模
前端·后端
用户68833620597026 分钟前
移动端 Web 性能调优:viewport、dvh 与触控优化解析
前端
前端付豪37 分钟前
项目启动:搭建Vue 3工程化项目
前端·javascript·vue.js
Asort39 分钟前
JavaScript设计模式(二十)——状态模式 (State):复杂状态管理的优雅解决方案
前端·javascript·设计模式
minhuan1 小时前
构建AI智能体:七十五、用扣子平台创建工作流:从自动化到智能化的进阶之路
运维·自动化·工作流构建·意图识别工作流
AI小云1 小时前
【Python高级编程】类属性与类方法
人工智能·python
im_AMBER1 小时前
React 07
前端·笔记·学习·react.js·前端框架
Giant1001 小时前
Node.js .env 配置指南:安全管理项目秘钥与多环境适配
前端