Pytest自动化框架:https://www.bilibili.com/video/BV18K411m7FH/
1、单元测试,是指在软件开发当中,针对软件的最小单位(函数,方法)进行正确性的检查测试。
java:junit、testng
python:unittest,pytest
2、自动化测试框架作用
①提高测试效率,降低维护成本
②减少人工干预,提高测试的准确性,增加代码的重用性
③核心思想是让不懂代码的人能够通过这个框架去实现自动化测试
3、pytest单元测试框架和自动化测试框架的关系:
①单元测试框架是自动化测试框架的组成部分之一;
②pom设计模式、数据驱动、关键字驱动、全局配置文件的封装、日志监控、断言、报告邮件等等
4、pytest简介
①pytest是一个非常成熟的python的单元测试框架,比unittest更灵活,容易上手;
②pytest可以和selenium,requests,appium结合实现web自动化、接口自动化,app自动化;
③pytest可以实现测试用例的跳过以及reruns失败用例重试;
④pytest可以和allure生成非常美观的测试报告;
⑤pytest可以和jenkins持续集成;
⑥支持用简单的assert语句实现丰富的断言;
⑦pytest有很多非常强大的插件,并且这些插件能够实现很多的实用的操作;
插件:
Package | 功能 |
---|---|
pytest-html | 生成html格式的自动化测试报告 |
pytest-xdist | 测试用例分布式执行,多CPU分发 |
pytest-ordering | 用于改变测试用例的执行顺序 |
pytest-rerunfailures | 用例失败后重跑 |
allure-pytest | 用于生成美观的测试报告 |
8、pytest安装:pip install pytest
,验证安装:pytest --version
9、pytest官方文档:https://doc.pytest.org/en/latest/
10、测试用例收集
若未指定任何参数,收集从testpaths(如果已配置,在pytest.ini下定义testpath=xxx)或当前目录及其子目录开始。
11、assert断言
assert ‘xxxx’ == yy [!=, <=, >=, not in, in , 判断是否为true,判断是否不为true]
12、参数化
当一组测试用例有固定的测试数据时,就可以通过参数化的方式简化测试用例的编写。
通过pytest.mark.parametrzie()方法设置参数:
参数名:"user,pw,expected"用来定义参数的名称;
参数值:通过数组定义参数值时,每一个元组都是一条测试用例的数据;
ids参数:默认为none,用来重新定义测试用例的名称;
@pytest.mark.parametrize(
"user,pw,expected",
[("beifan666","123456","beifan666,欢迎来到"),
("beifan666","123456","beifan666,欢迎来到")],
ids=["case1","case2"])
def test_login(user,pw,expected):
driver = webdriver.Chrome()
driver.get('http://xxxxx')
driver.find_element_by_lind_text("登录").click()
driver.find_element_by_xpath("xxxxx").send_keys(user)
driver.find_element_by_xpath("yyyyyy").send_keys(pw)
driver.find_element_by_xpath("zzzzz").click()
welcome = driver.find_element_by_xpath('xxxx').text
assert expected == welcome
13、pytest常用参数
参数 | 含义 | 使用方法 |
---|---|---|
-s | 在终端执行测试时显示打印某些信息,比如print信息 | pytest -s |
-v | 显示详细信息 | pytest -v |
-k | 运行函数名称中包含某个字符串的测试用例,或pytest -k “方法名” | pytest -k “one” |
-q | 执行测例时简化输出信息,比如… | pytest -q |
-x | 如果出现一条测试用例失败,退出测试 | pytest -x |
运行测试目录 | pytest testpath/ | |
运行指定的类或方法,pytest path/test_xxx.py::函数名或类名 | pytest test_abc.py::test_a | |
collect-only | 查看测例数量 | pytest --collect-only |
–maxfail=num | 允许pytest失败几次后再停止 | pytest --maxfail=num |
-m | 使用固定marker来筛选用例 | |
–version | 查看版本 | pytest --version |
–fixtures | 显示可用的内置函数参数 | |
–help | 获取帮助 | |
–maxfail=num | 在第N个用例失败后,结束测试执行 | pytest --maxfail=2,出现2个失败就终止测试 |
pytest-rerunfailures | 重新运行失败用例 | pytest --reruns 3 --reruns-delay=5 |
14、多进程运行用例
安装插件 pytest-xdist:pip install pytest-xdist
运行模式:pytest -n NUMCPUS[调用多个CPU来执行测例]
import pytest
def test_case01():
assert 1==1
def test_case02():
assert 1==2
def test_case03():
assert 1==1
def test_case04():
assert 1==4
def test_case05():
assert 1==1
def test_case06():
assert 1==5
if __name__ == '__main__':
#将测试发送到多个CPU
pytest.main(["-n", "2", "test_many.py"])
#使用与计算机具有的CPU内核一样多的进程来执行测例
pytest.main(["-n", "auto", "test_many.py"])
15、通过标记表达式执行用例
pytest -m slow 【这条命令会执行被装饰器@pytest.mark.slow装饰的所有测试用例】
def test_fail01():
print("第一次失败")
assert 1==2
@pytest.mark.slow
def test_fail02():
print("第二次失败")
assert 2==3
@pytest.markk.slow
def test_hello():
print("第三次执行成功")
assert 1==1
if __name__=='__main__':
pytest.main(["-s", "--maxfail=2", "test_fail2.py"])
#通过标记表达式执行
pytest.main(["-m","slow","test_rail2.py"])
#通过标记表达式执行,not slow
pytest.main(["-m","not slow","test_rail2.py"])
16、pytest的setup/teardown 【类之外定义含义:】
①第一批次:setup_module/teardown_module:在当前文件中,在所有测试用例执行之前与之后执行
②第二批次:setup_function/teardown_function:在每个测试函数之前与之后执行
③第三批次:setup/teardown:在每个测试函数之前与之后执行,这2个方法同样适用于类方法
【在类里的定义含义:】
第一批次:setup_class/teardown_class: 在当前测试类的开始与结束时执行
第二批次:setup_method/teardown_method:在每个测试方法开始与结束时执行
第三批次:setup/teardown:在每个测试方法开始与结束时执行
17、pytest配置函数 pytest.ini
[pytest]
#01 可添加多个命令行参数,用空格分隔
addopts = -s -v
# 02 搜索文件夹,执行指定文件夹里的用例
testpaths = ./scripts
# 03 配置搜索的文件名称,默认时搜索test开头的文件,改成以auto开通,以.py结尾的所有文件
python_files = auto*.py
18、pytest常用插件
①pytest-HTML插件,生成测试报告,安装方式:pip install pytest-html 使用方法:pytest --html=用户路径/report.html
②查看最慢的10个用例 pytest --durations=10
③关闭插件,比如关闭doctest pytest -p no:doctest
19、pytest之fixture
①定义:在测试中,fixture为测试提供了已定义的,可靠和一致的上下文。这可能包括环境(例如,通过已知的参数配置数据库)或内容(例如数据集)
我们可以通过装饰器@pytest.fixture来告诉pytest某个特定函数时一个fixture
【将方法first_fix作为参数传入到测试用例】
import pytest
@pytest.fixture
def first_fix():
return ['a']
def test_str(first_fix):
#测试执行
first_fix.append('b')
#断言
assert first_fix== ["a", "b“】
print(first_fix)
20、conftest.py
conftest.py是pytyest特有的本地测试配置文件,既可以用来设置项目级别的fixture,也可以用来导入外部插件。
conftest.py文件名称是固定的,pytest会自动识别该文件,只作用于它所在的目录及子目录。
下面是我整理的2023年最全的软件测试工程师学习知识架构体系图 |
不论起点如何,只要你迈出坚定的步伐,勇敢面对挑战,每一次奋斗都是向成功迈进的宝贵经验。相信自己的力量,努力拼搏,你的梦想将会绽放辉煌!
成功的路上,有无数辛酸和泪水。要坚持不懈,不怕失败,不畏挫折,才能在人生舞台上创造出属于自己的传奇!
前方或许充满了险阻和挑战,但你只要放手一搏,坚持拼搏,就能披荆斩棘,创造辉煌。相信自己,追逐梦想,努力奋斗,成功将向你招手!