当前位置: 首页 > news >正文

pytest中文使用文档----6临时目录和文件

  • 1. 相关的fixture
    • 1.1. tmp_path
    • 1.2. tmp_path_factory
    • 1.3. tmpdir
    • 1.4. tmpdir_factory
    • 1.5. 区别
  • 2. 默认的基本临时目录

1. 相关的fixture

1.1. tmp_path

tmp_path是一个用例级别的fixture,其作用是返回一个唯一的临时目录对象(pathlib.Path);

我们看下面的例子:

# src/chapter-6/test_tmp_path.pyCONTENT = "content"def test_create_file(tmp_path):d = tmp_path / "sub"  d.mkdir()  # 创建一个子目录p = d / "hello.txt"p.write_text(CONTENT)assert p.read_text() == CONTENTassert len(list(tmp_path.iterdir())) == 1  # iterdir() 迭代目录,返回迭代器assert 0  # 为了展示,强制置为失败

执行:

λ pytest -q -s src/chapter-6/test_tmp_path.py
F
==================================== FAILURES =====================================
________________________________ test_create_file _________________________________tmp_path = WindowsPath('C:/Users/luyao/AppData/Local/Temp/pytest-of-luyao/pytest-4/test_create_file0')def test_create_file(tmp_path):d = tmp_path / "sub"d.mkdir()  # 创建一个子目录p = d / "hello.txt"p.write_text(CONTENT)assert p.read_text() == CONTENTassert len(list(tmp_path.iterdir())) == 1  # iterdir() 迭代目录,返回迭代器
>       assert 0  # 为了展示,强制置为失败
E       assert 0src\chapter-6\test_tmp_path.py:32: AssertionError
1 failed in 0.06s

可以看出:

  • tmp_path在不同的操作系统中,返回的是不同类型的pathlib.Path对象,这里Windows系统下返回的是WindowsPath对象,它是Path的子类对象;
  • Path对象可以使用/操作符代替常用的os.path.join()的方法;更多关于pathlib的使用方法可以查看:https://docs.python.org/3.7/library/pathlib.html

1.2. tmp_path_factory

tmp_path_factory是一个会话级别的fixture,其作用是在其它fixture或者用例中创建任意的临时目录;

查看上一章tmp_path fixture的源码,我们能够看到tmp_path就是使用tmp_path_factory的一个例子:

# _pytest.tmpdir@pytest.fixture
def tmp_path(request, tmp_path_factory):"""Return a temporary directory path objectwhich is unique to each test function invocation,created as a sub directory of the base temporarydirectory.  The returned object is a :class:`pathlib.Path`object... note::in python < 3.6 this is a pathlib2.Path"""return _mk_tmp(request, tmp_path_factory)@pytest.fixture(scope="session")
def tmp_path_factory(request):"""Return a :class:`_pytest.tmpdir.TempPathFactory` instance for the test session."""return request.config._tmp_path_factory

可以看出:

  • tmp_path调用了tmp_path_factory

  • tmp_path_factory返回一个_pytest.tmpdir.TempPathFactory对象;

  • 进一步查看_mk_tmp的源码:

    def _mk_tmp(request, factory):name = request.node.namename = re.sub(r"[\W]", "_", name)MAXVAL = 30name = name[:MAXVAL]return factory.mktemp(name, numbered=True)
    

    可以看出,tmp_path最终调用了TempPathFactory.mktemp()方法,它返回的是一个pathlib.Path对象;

1.3. tmpdir

tmp_path是一个用例级别的fixture,其作用是返回一个唯一的临时目录对象(py.path.local),它提供os.path的方法;

上面的例子也可以修改成如下这样:

# src/chapter-6/test_tmpdir.pyCONTENT = "content"def test_create_file(tmpdir):p = tmpdir.mkdir("sub").join("hello.txt")  # 创建子文件夹,并新建文件p.write(CONTENT)assert p.read() == CONTENTassert len(tmpdir.listdir()) == 1  # iterdir() 迭代目录,返回列表assert 0  # 为了展示,强制置为失败

执行:

λ pytest -q -s src/chapter-6/test_tmpdir.py
F
==================================== FAILURES =====================================
________________________________ test_create_file _________________________________
tmpdir = local('C:\\Users\\luyao\\AppData\\Local\\Temp\\pytest-of-luyao\\pytest-6\\test_create_file0')def test_create_file(tmpdir):p = tmpdir.mkdir("sub").join("hello.txt")  # 创建子文件夹,并新建文件p.write(CONTENT)assert p.read() == CONTENTassert len(tmpdir.listdir()) == 1  # iterdir() 迭代目录,返回列表
>       assert 0  # 为了展示,强制置为失败
E       assert 0src\chapter-6\test_tmpdir.py:30: AssertionError
1 failed in 0.06s

其实,tmpdir也调用了tmp_path,只是对返回值做了一次py.path.local()封装:

# _pytest.tmpdir@pytest.fixture
def tmpdir(tmp_path):"""Return a temporary directory path objectwhich is unique to each test function invocation,created as a sub directory of the base temporarydirectory.  The returned object is a `py.path.local`_path object... _`py.path.local`: https://py.readthedocs.io/en/latest/path.html"""return py.path.local(tmp_path)

1.4. tmpdir_factory

tmpdir_factory是一个会话级别的fixture,其作用是在其它fixture或者用例中创建任意的临时目录;

假设,一个测试会话需要使用到一个很大的由程序生成的图像文件,相比于每个测试用例生成一次文件,更好的做法是每个会话只生成一次:

import pytest@pytest.fixture(scope="session")
def image_file(tmpdir_factory):img = compute_expensive_image()fn = tmpdir_factory.mktemp("data").join("img.png")img.save(str(fn))return fndef test_histogram(image_file):img = load_image(image_file)# compute and test histogram

1.5. 区别

fixture作用域返回值类型
tmp_path用例级别(function)pathlib.Path
tmp_path_factory会话级别(session)TempPathFactory
tmpdir用例级别(function)py.local.path
tmpdir_factory会话级别(session)TempDirFactory

2. 默认的基本临时目录

上述fixture在创建临时目录时,都是创建在系统默认的临时目录(例如:Windows系统的%temp%目录)下;你可以通过指定--basetemp=mydir选项自定义默认的基本临时目录;

λ pytest -q -s --basetemp="/d/temp" src/chapter-6/test_tmpdir.py
F
==================================== FAILURES =====================================
________________________________ test_create_file _________________________________
tmpdir = local('D:\\temp\\test_create_file0')def test_create_file(tmpdir):p = tmpdir.mkdir("sub").join("hello.txt")  # 创建子文件夹,并新建文件p.write(CONTENT)assert p.read() == CONTENTassert len(tmpdir.listdir()) == 1  # iterdir() 迭代目录,返回列表
>       assert 0  # 为了展示,强制置为失败
E       assert 0src\chapter-6\test_tmpdir.py:30: AssertionError
1 failed in 0.04s
http://www.lryc.cn/news/328732.html

相关文章:

  • 从0开始搭建基于VUE的前端项目
  • elementUI this.$msgbox msgBox自定义 样式自定义 富文本
  • Lua与Python区别
  • Python学习(二)
  • 管理阿里云服务器ECS -- 网站选型和搭建
  • WPF中继承ItemsControl子类控件数据模板获取选中属性
  • Android卡顿掉帧问题分析之实战篇
  • OpenKylin安装Kafka
  • 嵌入式硬件中常见的面试问题与实现
  • 【Node.JS】koa
  • 工作日志- 不定期更新
  • Qt使用opencv打开摄像头
  • Redis的Hash数据结构中100万对field和value,field是自增时如何优化?优化Hash结构。
  • 二十四种设计模式与六大设计原则(一):【策略模式、代理模式、单例模式、多例模式、工厂方法模式、抽象工厂模式】的定义、举例说明、核心思想、适用场景和优缺点
  • mac怎么删除python
  • 【笔记】Android U RILJ 中与运营商名称SPN显示相关的日志分析
  • 蓝桥杯【奇怪的捐赠】c语言
  • 【3月比赛合集】5场可报名的「创新应用」、「数据分析」和「程序设计」大奖赛,任君挑选!
  • vue3 视频播放功能整体复盘梳理
  • vue-ueditor-wrap上传图片报错:后端配置项没有正常加载,上传插件不能正常使用
  • 数据仓库的发展历程
  • MySQL开窗函数
  • Java学习笔记(23)
  • nodejs下载安装以及npm、yarn安装及配置教程
  • Playwright库page.evaluate()方法执行JavaScript 表达式
  • 【微服务】OpenFeign+Sentinel集中处理远程调用异常
  • 集合嵌套,Collections,斗地主案例,日志框架
  • maven pom relativePath属性的作用
  • 【STM32 HAL库SPI/QSPI协议学习,基于外部Flash读取。】
  • Nginx入门--初识Nginx的架构