博客
关于我
pytest文档65-内置 request 读取项目的根目录 rootdir
阅读量:465 次
发布时间:2019-03-06

本文共 3757 字,大约阅读时间需要 12 分钟。

前言

写自动化测试项目的时候,经常要用到配置文件,比如读取数据库相关的配置,希望单独放到 config 配置文件,方便维护。

pytest 的内置 fixture 可以获取到配置相关的信息,request.config.rootdir 用于获取项目的跟目录。

config 配置文件

再项目下新建一个 config 文件,相关配置信息用 yaml 文件维护数据

在conftest.py 下写读取配置文件的 fixture, 这里我设置为 autouse=True 主要是为了查看打印读取到的目录

import pytestimport osimport yaml# 作者-上海悠悠 QQ交流群:717225969# blog地址 https://www.cnblogs.com/yoyoketang/@pytest.fixture(scope="session", autouse=True)def dbinfo(request):    dbfile = os.path.join(request.config.rootdir,                        "config",                        "dbenv.yml")    print("dbinfo file path :%s" % dbfile)    with open(dbfile) as f:        dbenv_config = yaml.load(f.read(), Loader=yaml.SafeLoader)    print(dbenv_config)    return dbenv_config

rootdir 读取

打开 cmd 命令行,在项目的跟目录运行用例

pytest -s

D:\wangyiyun\webauto>pytest -s================================================= test session starts =================================================platform win32 -- Python 3.6.6, pytest-4.5.0, py-1.9.0, pluggy-0.13.1rootdir: D:\wangyiyun\webautoplugins: allure-pytest-2.8.6collected 5 itemscase\test_1.py dbinfo file path :D:\wangyiyun\webauto\config\dbenv.yml{'host': '47.104.x.x', 'port': 3306, 'user': 'root', 'passwd': 123456, 'db': 'test'}test xxx.case\test_x1.py test 111111.test 22222222.test 3333333.test 444444444.=================

这时候可以看到读取到的配置文件地址:D:\wangyiyun\webauto\config\dbenv.yml

在项目根目录运行用例是标准的运行姿势,但是有些小伙伴会 cd 到 case 目录,运行单个用例

D:\wangyiyun\webauto>cd caseD:\wangyiyun\webauto\case>pytest test_1.py================================================= test session starts =================================================platform win32 -- Python 3.6.6, pytest-4.5.0, py-1.9.0, pluggy-0.13.1rootdir: D:\wangyiyun\webauto\caseplugins: allure-pytest-2.8.6collected 1 itemtest_1.py E                                                                                                      [100%]======================================================= ERRORS ========================================================______________________________________________ ERROR at setup of test_x _______________________________________________request = 
> @pytest.fixture(scope="session", autouse=True) def dbinfo(request): dbfile = os.path.join(request.config.rootdir, "config", "dbenv.yml") print("dbinfo file path :%s" % dbfile)> with open(dbfile) as f:E FileNotFoundError: [Errno 2] No such file or directory: 'D:\\wangyiyun\\webauto\\case\\config\\dbenv.yml'..\conftest.py:14: FileNotFoundError------------------------------------------------ Captured stdout setup ------------------------------------------------dbinfo file path :D:\wangyiyun\webauto\case\config\dbenv.yml=============================================== 1 error in 0.08 seconds ===============================================

这个时候就会出现报错:No such file or directory: 'D:\wangyiyun\webauto\case\config\dbenv.yml'

因为此时的项目跟目录就变成了 rootdir: D:\wangyiyun\webauto\case
接下来我们需要解决的问题时,不管在哪个目录运行,它的项目跟目录应该都是我们的工程目录 D:\wangyiyun\webauto

pytest.ini

pytest 运行用例的时候项目的 rootdir 当没有 pytest.ini 配置文件的时候会根据 conftest.py 找到它的跟目录。

由于前面没有用到pytest.ini 配置文件,导致不同目录运行用例的 rootdir 不一样。

当项目下存在 pytest.ini 配置文件的时候,会认为 pytest.ini 所在的目录是 rootdir 目录, 所以我们一般会把 pytest.ini 配置文件放到项目的跟目录。

如果里面没有内容,放个空的也行

这时候不管在哪个目录运行用例都不会有问题了

D:\wangyiyun\webauto\case>pytest test_1.py======================== test session starts ==============platform win32 -- Python 3.6.6, pytest-4.5.0, py-1.9.0, pluggy-0.13.1rootdir: D:\wangyiyun\webauto, inifile: pytest.iniplugins: allure-pytest-2.8.6collected 1 itemtest_1.py .                                            [100%]========================1 passed in 0.03 seconds =============

pytest的配置文件除了 pytest.ini,还有 tox.ini 和 setup.cfg 也可以当配置文件

你可能感兴趣的文章
mysql第一天~mysql基础【主要是DDL、DML、DQL语句,以及重点掌握存存引擎、查询(模糊查询)】
查看>>
mysql第二天~mysql基础【查询排序、分页查询、多表查询、数据备份与恢复等】
查看>>
MySQL简介和安装
查看>>
MySQL简单查询
查看>>
MySQL管理利器 MySQL Utilities 安装
查看>>
MySQL篇(管理工具)
查看>>
mysql类型转换函数convert与cast的用法
查看>>
mysql系列一
查看>>
MySQL系列之数据授权(安全)
查看>>
MySQL系列之数据类型(Date&Time)
查看>>
MySQL系列之数据类型(Date&Time)
查看>>
Mysql系列之锁机制
查看>>
Mysql系列九:使用zookeeper管理远程Mycat配置文件、Mycat监控、Mycat数据迁移(扩容)...
查看>>
MySql系列:[4200][1140]In aggregated query without GROUP BY, expression #2 of SELECT list contains nona
查看>>
MySQL索引
查看>>
Mysql索引
查看>>
mysql索引
查看>>
mysql索引
查看>>
Mysql索引,索引的优化,如何避免索引失效案例
查看>>
Mysql索引、命令重点介绍
查看>>