网易首页 > 网易号 > 正文 申请入驻

Python任务自动化工具tox教程

0
分享至

  在我刚翻译完的 Python 打包中,作者提到了一个神奇的测试工具 tox,而且他本人就是 tox 的维护者之一。趁着话题的相关性,本文将对它做简单的介绍,说不定大家在开发项目时能够用得上。

Command line driven CI frontend and development task automation tool 命令行驱动的 CI 前端和开发任务自动化工具

  tox 的项目地址是:https://github.com/tox-dev/tox

  其核心作用是支持创建隔离的 Python 环境,在里面可以安装不同版本的 Python 解释器与各种依赖库,以此方便开发者做自动化测试、打包、持续集成等事情。

  简单来说,tox 是一个管理测试虚拟环境的命令行工具。它已存在多年且广被开发者们使用,例如,著名的云计算平台 OpenStack 也采用了它,作为最基础的测试工具之一。

  1、tox 能做什么? 细分的用途包括:

  创建开发环境

  运行静态代码分析与测试工具

  自动化构建包

  针对 tox 构建的软件包运行测试

  检查软件包是否能在不同的 Python 版本/解释器中顺利安装

  统一持续集成(CI)和基于命令行的测试

  创建和部署项目文档

  将软件包发布到 PyPI 或任何其它平台

  tox 官方文档中列出了 40 余种使用场景的示例,详细的列表可查看:https://tox.readthedocs.io/en/latest/examples.html

2、tox 怎么配置?

  关于它的用法:使用pip install tox安装,使用tox运行全部测试环境,和tox -e envname运行指定的环境。还有不少的命令行参数,通过tox -h查看。

  tox 的行为由其配置文件控制,当前它支持 3 种配置文件:

  pyproject.toml

  tox.ini

  setup.cfg

  以 tox 项目自己的 tox.ini 配置内容为例,可以看到它是这样配置的(https://github.com/tox-dev/tox/blob/master/tox.ini):

  每个[xxx]及其下方内容组成一个章节(section),每个章节间使用空行作间隔。

  [tox]下面是全局性的配置项,envlist 字段定义了 tox 去操作的环境。[xxx]下面是 xxx 虚拟环境的配置项,[xxx:yyy]继承 xxx 的配置,同时其自身配置项的优先级更高。

  对于每个虚拟环境,可用的配置项很多,例如常用的有:description(描述信息)、basepython(Python解释器版本)、deps(环境依赖项)、commands(命令语句)等等。

  tox 还支持作变量替换,它提供了一些内置的基础变量(全局的或对于虚拟环境的):{toxinidir}、{homedir}、{envname}、{envdir}等等。

  除了基础性的变量替换,它还支持这些高级用法:

  取操作系统的环境变量:{env:KEY},效果等同于os.environ['KEY']。可以变化成:{env:KEY:DEFAULTVALUE},在取不到环境变量时则使用默认值;{env:KEY:{env:DEFAULT_OF_KEY}},达到 if-else 的取值效果

  传递命令行参数:{posargs:DEFAULTS},当没有命令行参数时,使用 DEFAULTS 值。使用方式:tox arg1 arg2传两个参,或者tox -- --opt1 arg1将“-- opt1 arg1”作为整体传入。

  章节间传值:{[sectionname]valuename},不同章节的内容可以传递使用。

  交互式控制台注入:{tty:ON_VALUE:OFF_VALUE},当交互式 shell 控制台开启时,使用第一个值,否则使用第二个。pytest 在使用“--pdb”时,是这样的例子。

  花括号“{}”除了可以做变量替换使用,它还可以作为“或关系”判断的取值。直接看下面的例子:

  [tox]
envlist = {py27,py36}-django{15,16}

  {py27,py36}-django{15,16} 的 2 组花括号内各有 2 个值,它们实际可以组合成 4 个环境:py27-django15、py27-django16、py36-django15、py36-django16。

  关于 tox 有哪些配置项、使用条件、什么含义、高级用法等等内容,可在官方文档中查看:https://tox.readthedocs.io/en/latest/config.html

  3、tox 的插件化

  除了自身强大的可配置性,tox 还具有很强的可扩展性,它是可插拔的(pluggable),围绕它产生了一个极为丰富的插件生态。

  使用pip search tox,可以看到数量众多的“tox-”开头的库,它们都是 tox 的插件包。其中不乏 setuptools、pipenv、conda、travis、pytest、docker 等被大家熟知的名字。

  tox 开放了挺多的 API 接口,方便其他人定制开发插件。

4、tox 的工作流程

  接下来看看 tox 是怎么运作的:

其工作流程中主要的环节有:

  配置(从figuration):加载配置文件(如 tox.ini),解析命令行参数,读取系统环境变量等

  打包(packaging):可选的,对于带有 setup.py 文件的项目,可以在这步去生成它的源发行版

  创建虚拟环境:默认使用 virtualenv 来创建虚拟环境,并根据配置项中的“deps”安装所需的依赖项,然后执行配置好的命令(commands)

  报告(report):汇总所有虚拟环境的运行结果并罗列出来

  5、小结

  tox 本身定位是一个测试工具,它试图令 Pytho 测试工作变得自动化、标准化与流程化。但跟 unittest 和 pytest 这些测试框架不同,它作用的是代码层面之外的事情,是一种项目级的工具。因此,它需要跟这些测试框架相结合,或者同时处理多种自动化任务(如跑 pep8、测代码覆盖率、生成文档等等),这样才能更好地发挥它的价值。

  它的一大特色在于创建/管理虚拟环境,但这只是为了方便测试而使用的手段,因此相比其它可管理虚拟环境的工具,如 Virtualenvwrapper、conda、pipenv、poetry,它在某些方面就存在着不足。

  tox 还有强大的可配置性与丰富的插件支持,这使得它在运用上具有很大的可能性与自由度。因此,不少忠实开发者仍在持续地在使用它,比如,我刚翻译好的的作者就是它的维护者之一。

最后还需补充一点,tox 使用配置文件作驱动,但配置文件还是挺繁琐的,因此有人开发了一个跟 tox 相似的nox,使用 Python 文件来做配置。这个项目也很受欢迎,吸引了很多项目投入其门下,例如 pipx、urllib3、Salt 等等。对该项目感兴趣的话,请查看:https://nox.thea.codes/en/stable作者简介:豌豆花下猫,生于广东毕业于武大,现为苏漂程序员,有一些极客思维,也有一些人文情怀,有一些温度,还有一些态度。

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
胡适评价毛主席写的词,“没有一句通的”,那么胡适的水平如何?

胡适评价毛主席写的词,“没有一句通的”,那么胡适的水平如何?

芊芊之言
2025-11-04 00:10:09
收钱只收现金、借消费贷装穷!95后国企总经理真会装——

收钱只收现金、借消费贷装穷!95后国企总经理真会装——

运营商段子手
2025-11-06 13:33:53
中国首例五胞胎终于长大了,父亲因劳累去世,母亲直言后悔生下他们

中国首例五胞胎终于长大了,父亲因劳累去世,母亲直言后悔生下他们

等风来育儿联盟
2025-08-01 12:21:35
“继承权”不用争了!2026年新规下:父母的房子全部将这样处理

“继承权”不用争了!2026年新规下:父母的房子全部将这样处理

白马惊天剑
2025-11-06 21:00:49
内蒙古满洲里警方通报一起刑事案件:1死1伤,嫌犯已被刑拘

内蒙古满洲里警方通报一起刑事案件:1死1伤,嫌犯已被刑拘

界面新闻
2025-11-07 15:18:55
中国最神秘的笔名,写下一本人尽皆知的奇书,作者是谁却至今未知

中国最神秘的笔名,写下一本人尽皆知的奇书,作者是谁却至今未知

大千世界观
2025-10-28 14:55:18
陈可辛与吴君如的19岁女儿身穿深V礼服,绽放巴黎名媛舞会?

陈可辛与吴君如的19岁女儿身穿深V礼服,绽放巴黎名媛舞会?

娱乐领航家
2025-11-04 22:00:03
一个会打扮的女人不管走到哪里都像是一幅美丽的画

一个会打扮的女人不管走到哪里都像是一幅美丽的画

牛弹琴123456
2025-11-06 21:15:04
70岁前必去的10个人间仙境,我有幸去过5个,去了就不想回家!

70岁前必去的10个人间仙境,我有幸去过5个,去了就不想回家!

赏玩夜忘归
2025-10-31 17:53:50
国家终于不再原谅王濛,77枚金牌不是万能,狂妄自大只会被抛弃

国家终于不再原谅王濛,77枚金牌不是万能,狂妄自大只会被抛弃

凡知
2025-07-29 02:12:19
49年红军军长被处决,解放后被追认为烈士,13年后烈士称号被取消

49年红军军长被处决,解放后被追认为烈士,13年后烈士称号被取消

咸説历史
2025-11-08 01:11:50
歼-10 CE战机能卖给巴基斯坦,但绝不能卖给朝鲜!为什么这么说?

歼-10 CE战机能卖给巴基斯坦,但绝不能卖给朝鲜!为什么这么说?

百科密码
2025-11-07 16:55:30
湖南省怀化市人大常委会原副主任杨一中被公诉,曾被通报私德败坏、玩忽职守

湖南省怀化市人大常委会原副主任杨一中被公诉,曾被通报私德败坏、玩忽职守

正义网新闻
2025-11-07 17:03:07
炸裂!妻子KTV找男模有偿“打枪”,花光丈夫200万,聊天记录曝光

炸裂!妻子KTV找男模有偿“打枪”,花光丈夫200万,聊天记录曝光

梦史
2025-11-06 20:21:17
貂皮大衣退货后续,宝妈已社死,老板报警因祸得福,网友争相要买

貂皮大衣退货后续,宝妈已社死,老板报警因祸得福,网友争相要买

观察鉴娱
2025-11-07 10:28:09
就在今天!11月8日,篮球传来徐杰、胡明轩、杜锋消息

就在今天!11月8日,篮球传来徐杰、胡明轩、杜锋消息

皮皮观天下
2025-11-08 05:19:37
张嘉倪已复婚!买超微博仍是张嘉倪老公,疑似张嘉倪为热度假离婚

张嘉倪已复婚!买超微博仍是张嘉倪老公,疑似张嘉倪为热度假离婚

八星人
2025-11-06 11:59:24
学医后才明白,稳定血糖最好的运动,不是快走慢跑,而是这个

学医后才明白,稳定血糖最好的运动,不是快走慢跑,而是这个

华庭讲美食
2025-11-07 15:04:42
9人变8人!火箭队轮换阵容缩水?底薪3老将被忽略,急需新援复出

9人变8人!火箭队轮换阵容缩水?底薪3老将被忽略,急需新援复出

熊哥爱篮球
2025-11-07 11:03:30
张靓颖“零透光”裙惊爆热搜,性感曲线令全场屏息,时尚女王?

张靓颖“零透光”裙惊爆热搜,性感曲线令全场屏息,时尚女王?

娱乐领航家
2025-10-28 22:00:07
2025-11-08 06:28:49
Python猫 incentive-icons
Python猫
人生苦短,我用Python。博客:https://pythoncat.top
727文章数 8121关注度
往期回顾 全部

科技要闻

75%赞成!特斯拉股东同意马斯克天价薪酬

头条要闻

奥巴马意外现身 庆祝胜利

头条要闻

奥巴马意外现身 庆祝胜利

体育要闻

是天才更是强者,18岁的全红婵迈过三道坎

娱乐要闻

王家卫的“看人下菜碟”?

财经要闻

荷兰政府:安世中国将很快恢复芯片供应

汽车要闻

美式豪华就是舒适省心 林肯航海家场地试驾

态度原创

旅游
房产
本地
公开课
军事航空

旅游要闻

稻城亚丁冲古寺看仙乃日雪山的最佳角度在哪? 看完这篇你就明白了

房产要闻

全国2025唯一“开盘即百亿”在广州诞生

本地新闻

这届干饭人,已经把博物馆吃成了食堂

公开课

李玫瑾:为什么性格比能力更重要?

军事要闻

中国第三艘航空母舰福建舰入列

无障碍浏览 进入关怀版