yield import pytest @pytest.fixture() def login(): print('打开浏览器,登录成功') yield #yield后边代码是用例执行完成后再执行的,相当于teardown print(‘关闭浏览器’) #使用fixture def test_shopping(login): print('测试购物') ----yield遇到异常 如果其中一条用例出现异常,不影响yield后面teardown执行,运行结果互不影响,并且全部用例执行完之后,yield呼唤teardown操作 addfinalizer 终结函数 yield当用例执行完之后,会执行yield后面的代码,但不能return addfinalizer 这个实现功能跟yield一样,可以return参数,传给后面用例 转链接:https://www.jianshu.com/p/4d59c64a2723
是测试用例的前置固件,也就是相当于“setup”。说到这,细心的你可能想到了,那有没有什么方式可以表示出“teardown”?这就是我们今天学习的yield和addfinalizer。
yield
yield是一个关键字,它不是单独存在的,要写在fixtrue标记的固件中。
吃个小荔枝:我们在声明的固件myfixture中加入yield关键字,在它下面写测试用例执行后想要运行的代码;其他有关于固件的使用没有任何差别。需要说明的一点是我们在pytest主函数中增加了一个参数“–setup-show”,他会显示出固件的执行情况。
#文件名是test_firstFile.py #coding=utf-8 import pytest @pytest.fixture() def myfixture(): print("执行myfixture前半部分") yield print("执行myfixture的后半部分") class Test_firstFile(): def test_one(self,myfixture): print("执行test_one") assert 1+2==3 def test_two(self): print("执行test_two") assert 1==1 def test_three(self): print("执行test_three") assert 1+1==2 if __name__=="__main__": pytest.main(["--setup-show","-s","test_firstFile.py"])
运行结果如下图所示:我们可以清楚的看到,测试代码的执行顺序是 固件中yield前的代码–测试用例中的代码–固件中yield后的代码。
需要注意的是:如果测试用例中的代码出现异常或者断言失败,并不会影响他的固件中yield后的代码执行;但是如果固件中的yield之前的代码也就是相当于setup部分的带代码,出现错误或断言失败,那么yield后的代码将不会再执行,当然测试用例中的代码也不会执行。
addfinalizer函数
我们也可以通过request.addfinalizer()的方式实现“teardown”。它和yield相比不同的是:无论是固件的“setup”部分是否出现异常或断言失败,它都会执行(关于这一点我还没有演示出来,感觉setup中如果有异常addfinalizer依然不会执行,希望大佬指导);此外它还支持传入多个函数。
话不多说,上荔枝:我们在固件中传入request参数;又在固件中定义了一个内置函数;最后将定义的内置函数添加到request的addfinalizer中。
#test_Pytest.py文件 #coding=utf-8 import pytest @pytest.fixture() def myfixture(request): print ("执行固件myfixture的前半部分") def myteardown(): print("执行固件myfture的后半部分") request.addfinalizer(myteardown) class Test_Pytest(): def test_one(self,myfixture): print("test_one方法执行" ) assert 1==1 def test_two(self): print("test_two方法执行" ) assert "o" in "love" def test_three(self): print("test_three方法执行" ) assert 3-2==1 if __name__=="__main__": pytest.main(['--setup-show','-s','test_Pytest.py'])