前置条件:是在执行某个测试用例之前必须要满足的一些条件,例如预先输入一些数据,配置一些环境等。如果前置条件不正确,测试用例可能不能执行。最简单的例子例如对数据库进行操作
后置条件:在执行某个测试用例之后的一些操作例如清理测试用例等,如果后置条件没有被这行的话,可能会影响后续的测试用例的执行
装饰器:用于修改函数或者类的行为,在不改变类或者函数的定义的情况下进行扩展,实现代码的复用。
装饰器本质上是一个函数,接受一个函数或者类作为参数,然后返回一个新的函数或者类
本次用的装饰器就是fixture
@pytest.fixture(scope="function",autouse=True)
def excut_sql():
print("打开数据库")
@pytest.fixture(scope="作用范围",autouse="是否自动调用",params=“参数化”,ids=“参数别名”,
name=“固件别名”)
params传递参数主要针对场景:对某一个用例进行数据库连接,并且数据库里的数据在用例里面
进行遍历
(使用数据驱动同样可以实现)
name:一般用于简化固件的名字
scope:function 按函数执行
scope:class 按类执行
scope:module 按照模块执行
scope:session 按照每一个会话执行
ps:如果前置条件作用在函数上并且自动开启,那么需要前置条件的函数多传入一个参数
如下例就是test_user_login(self,excut_sql):
@pytest.fixture(scope="function",autouse=False)
def excut_sql():
print("打开数据库")
#Personal API
class Test_API:
#测试登录用户信息接口
access_token=''
sess=requests.session()
@pytest.mark.smoke
def test_user_login(self,excut_sql):
url='http://localhost:8080/api/v1/user/login'
data={
"loginName": "18922301826",
"passwordMd5": "e10adc3949ba59abbe56e057f20f883e"
}
#res=requests.post(url,json=data)
res=Test_API.sess.request(method='post',url=url,json=data)
reslut=res.json()
print(res.json())
Test_API.access_token=jsonpath.jsonpath(reslut,"$.data")[0]
print(Test_API.access_token)
注意:在一个文件中设置的固件,只能在当前文件起作用
比如只在test——phpwind文件写了固件,那么test_api文件是不会执行前置条件无论修改什么样的参数。
如果需要对所有的py文件起作用,需要结合conftest文件
好处:分层前后置
分模块管理前置条件
比如所有模块都先需要“登录”,其中有些模块需要“进入xxx框架”
最外层的conftest先执行,其次才是内部的conftest执行
使用extract.yaml文件保存中间变量
1.读取 2.写入 3.清空
原因:
1.类变量不可以跨py文件使用
2.统一的管理中间变量
在什么时候选择清空yaml文件之中保存的中间变量?(前置条件)
在请求之前清空yaml文件内容
如果在请求之后清空会发生看不到中间变量的现象
assert断言(判断结果是否正确)
每一个测试用例的断言都不一样
requirments.txt 中base_url这个参数当作一个需要手动调用的固件使用(基础路径)
例如:test_user_login(self,base_url);