1、fixture是对测试用例执行的环境准备和清理,相当于unittest中的setUp/tearDown/setUpClass/tearDownClass作用
2、fixture的主要目的
如测试用例运行时都需要进行登录和退出操作时,使用fixture后,可以只进行一次登录和退出操作,不需要每个用例执行时都进行登录和退出
3、如何使用fixture
在函数之前加上@pytest.fixture,表示此函数为测试环境数据准备和清理
那么在一个fixture内部如何区分环境准备和环境清理呢?
(1)、需要在测试用例包下新建一个conftest.py文件,名字不能是其他的
(2)、在该文件中写用例执行的前置条件和后置条件,首先需要声明他是一个fixture,@pytest.fixture
#_-*- coding:utf-8 -*-import pytest
from selenium import webdriver
from PageObject.login_page import LoginPage
from PageObject.index_page import IndexPage
from TestDatas import Common_Datas as CD
from TestDatas import login_datas as LDdriver=None
# 声明一个它是一个fixture
# scope='class'表示access_web的作用域在类上,执行测试用例时,类只执行一次
@pytest.fixture(scope='class')
def access_web():# 前置条件global driver #声明driver为全局变量print("========所有测试用例之前的,整个测试用例只执行一次=========")driver=webdriver.Chrome()driver.maximize_window()driver.get(CD.web_login_url)# 实例化LoginPage类lg=LoginPage(driver)# yield 同时可以返回值(driver,lg),相当于return,在使用返回值的时候直接用函数名yield (driver,lg) #分割线:前面是前置条件、后面是后置条件# 后置条件print("========所有测试用例之后的,整个测试用例只执行一次=========")driver.quit()@pytest.fixture()
# @pytest.fixture()表示函数默认作用域access_web的作用域在函数上,执行测试用例时,每个函数都执行一次
def refresh_page():global driver# 前置操作yield# 后置操作driver.refresh()
(3)、这个是使用unittest的代码
import unittest
from selenium import webdriver
from PageObject.login_page import LoginPage
from PageObject.index_page import IndexPage
from TestDatas import Common_Datas as CD
from TestDatas import login_datas as LD
import ddt
import pytest@ddt.ddt
class TestLogin(unittest.TestCase):def setUp(self):# 前置:访问登录页面self.driver = webdriver.Chrome()self.driver.maximize_window()self.driver.get(CD.web_login_url)self.lg = LoginPage(self.driver)def tearDown(self):#后置,关闭浏览器self.driver.quit()#正常测试用例@pytest.mark.smokedef test_login_success(self):#前置:访问登录页面#步骤:输入用户名、密码、点击self.lg.login(LD.success_data['user'],LD.success_data['passwd'])# 断言:首页当中能否找到“退出”按钮#等待10秒#找元素 //div[@class="navbar-account"]self.assertTrue(IndexPage(self.driver).isExist_logot_ele())#异常用例 :手机号格式不正确(手机号不对有很多种) ddt@ddt.data(*LD.phone_data)def test_login_user_wrongForget(self,data):# 前置:访问登录页面# 步骤:输入错误用户名、正确密码、点击self.lg.login(data['user'],data['passwd'])# 断言:登录页面提示“请输入正确的用户名”#登录页面 获取提示框文本内容# 比对文本内容是否与期望值相等
(3)、这是使用fixture后的测试用例代码,在函数中直接使用就可以,不需要引用py文件
access_web函数名直接接收返回值,使用函数名可以直接使用返回值
import unittest
from selenium import webdriver
from PageObject.login_page import LoginPage
from PageObject.index_page import IndexPage
from TestDatas import Common_Datas as CD
from TestDatas import login_datas as LD
import pytest@pytest.mark.usefixtures("access_web")
@pytest.mark.usefixtures("refresh_page")
class TestLogin:#正常测试用例#fixture的函数名称,用来接收它的返回值def test_login_1_success(self,access_web,refresh_page): #里面放函数名称,可写多个函数名称''':param access_web:使用access_web函数名称来接收conftest中access_web函数的返回值,返回值为元组形式yield (driver,lg),使用返回值直接用函数名和下表 eg:access_web[0],access_web[1],如果access_web函数中没有返回值,则无需传参:return:'''#前置:访问登录页面#步骤:输入用户名、密码、点击# 调用login方法access_web[1].login(LD.success_data['user'],LD.success_data['passwd'])# 断言:首页当中能否找到“退出”按钮#等待10秒#找元素 //div[@class="navbar-account"]assert IndexPage(access_web[0]).isExist_logot_ele() #如果是true,断言成功,如果是false,断言失败
遇到的小插曲:
1、改为使用pytest运行
左上角的File开始
File——>settings…——>Tools——>Diff & Merge——>Python Integrated Tools——>Testing——>Ddfault test runner——>pytest——>OK