pytest测试框架之fixture固件

一。fixture固件

部分用例之前或之后执行,部分类之前或之后之前

fixture完整方法如下:

@pytest.fixture(scope="作用域",params="数据驱动",autouse="是否自动执行",ids="改变参数名",nsme="改变固件名称")

作用域:

function(默认),class,module,package/session

@pytest.fixture(scope="function",autouse="True")

def excute_sql():

print("打开数据库连接")

yield

print("关闭数据库")

---return:返回函数的结果,return之后的代码不会执行

---yield:带yield函数叫生成器,yield之后的代码会执行

@pytest.fixture(scope="class")

def excute_1():

print("固定类")

class TestApi:

def test_01_jiaoyu(self,excute_sql):

print("测试"+excute_sql)

@pytest.mark.usefixtures("execute_1")

class TestMs:

def test_bili(self)

print("bili")

3.scope作用域是module或者package/session,那么需要结果conftest.py执行

(1)conftest.py专门用例存放固件fixture的没在文件,名称是固定的,不能更改的

(2)在conftest.py文件中的fixture在调用的时候不需要导包

(3)conftest.py可以有多个并且多个fixture之间没有冲突

(4)模块和session级别一般自动执行

-----------------------

params用于数据驱动

def read_data():

return['a','b','c']

@pytest.fixture(sco[e="function",params=read_data(),ids=['bd','ee','rr')

def product_sql(request):

        print("product固件")        

        yield request.param

        print("test")

特别注意:Params传参时会把每一次读取的值传给request.param,写法和取值方式是固定的

ids不能单独使用,必须和pamas一起使用你,给参数起别名

name给固件起别名

name起别名后,原来的名就失效了

pytest的执行顺序:

1.查找当前目录的下conftest.py

2.查尊当前目录下pytest.ini 找到查找测试用例

3.查找用例是是否有setup() teardown(),setup_class(),teardown_class()

4.执行测试用例

二,pytest的基础路径设置

[pytest]

....

base_url = http://10.2.3.30

---

def test_01_api()

        request.get(url=base_url+"/phpwind")

直接像调用function级别的固件一样调用base_url

场景:一个项目中有多个模块,每个模块都有一个基础路径

插件pytest-base-url

三。pytest断言

使用原生的assert

四,pytest结合allure-pytest生成allure测试报告

1.安装allure-pytest

2.官网下载allure包解压allure包到非中文目录并设置环境变量到path

E:\allure-2.13.7\bin

验证:需要在dos和pycharm中使用如下命令

allure --version

如果pyharm没有验证成功需要重启pycharm

[pytest]

addopts= -vs --alluredir=./temps --clean-alluredir

...

--alluredir=./temps 生成报告

--clean-alluredir 清除临时报告

if __name__=='__main__'

pytest.main()

time.sleep(3)

os.system("allure generate ./temps -o ./reports   --clean")

allure generate构建allure报告

./temps 根据临时json报告构建

-o 输出output

./reports  报告路径

--clean清除报告

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值