英文 |Command-line usagehtml
出处 | nox 官方文档python
译者 | 豌豆花下猫@Python猫git
Github地址:https://github.com/chinesehuazhou/noxdoccngithub
声明:本翻译基于CC BY-NC-SA 4.0受权协议,内容略有改动,转载请保留原文出处,请勿用于商业或非法用途。shell
接上篇《Python 任务自动化工具:nox 的配置与 API》django
nox 一般是在命令行上被调用的:json
nox复制代码
你还能够经过 Python 解释器调用 nox:windows
python3 -m nox复制代码
列出全部可用的会话,包括参数化的会话:缓存
nox -l
nox --list
nox --list-sessions复制代码
你能够不带任何参数地执行 nox 来运行每一个会话:
bash
nox复制代码
会话被执行的顺序是它们在 noxfile 中出现的顺序。
默认状况下,nox 将运行在 noxfile 中定义的全部会话。可是,你能够选择使用--session
、-s
或-e
运行特定的一组:
nox --session tests
nox -s lint tests
nox -e lint复制代码
你还可使用NOXSESSION
环境变量:
NOXSESSION=lint nox
NOXSESSION=lint,tests nox复制代码
nox 将按照指定的顺序运行这些会话。
你还可使用pytest-风格的关键字来过滤测试会话:
nox -k "not lint"
nox -k "tests and not lint"复制代码
若是你有参数化的会话,例如:
@nox.parametrize('django', ['1.9', '2.0'])
def tests(session, django):
...复制代码
那么运行nox --session tests
,实际上将运行该会话的全部参数化版本。若是你要使用一组特定的参数化参数运行会话,则可使用会话名称来指定它们:
nox --session "tests(django='1.9')"
nox --session "tests(django='2.0')"复制代码
默认状况下,nox 在每次运行时都会删除并从新建立虚拟环境(virtualenv)。一般,对于大多数项目和持续集成环境而言,这都是很好的,由于pip的缓存使得从新安装至关快。可是,在某些状况下,在两次运行之间重用虚拟环境是更有利的。使用-r
或--reuse-existing-virtualenvs
:
nox -r
nox --reuse-existing-virtualenvs复制代码
若是 noxfile 设置了nox.options.reuse_existing_virtualenvn
,你能够在命令行使用--no-reuse-existing-virtualenvs
覆盖 noxfile 的设置。
默认状况下,即便一个会话失败,nox 也将继续运行全部会话。一旦第一个会话失败,你可使用--stop-on-first-error
来使 nox 停止:
nox --stop-on-first-error复制代码
若是 noxfile 设置了nox.options.stop_on_first_error
,你能够在命令行中使用--no-stop-on-first-error
覆盖 noxfile 的设置。
默认状况下,nox 将跳过找不到 Python 解释器的会话。若是你但愿 nox 将这些会话标记为失败,你可使用--error-on-missing-interpreters
:
nox --error-on-missing-interpreters复制代码
若是 noxfile 设置了nox.options.error_on_missing_interpreters
,你能够在命令行中使用--no-error-on-missing-interpreters
覆盖 noxfile 设置。
默认状况下,对于未在会话的虚拟环境中安装的程序,nox 会发出警告,但最终会容许你运行它。若是 nox 在非显式将external = True
传递给session.run
的状况下,还使用任意外部程序,则你可使用--error-on-external-run
来使它失败:
nox --error-on-external-run复制代码
若是 noxfile 设置了nox.options.error_on_external_run
,你能够在命令行中使用--no-error-on-external-run
覆盖 noxfile 设置。
若是因为某种缘由你的 noxfile 没有命名为 noxfile.py ,你可使用--noxfile
或-f
:
nox --noxfile something.py
nox -f something.py复制代码
默认状况下,nox 将虚拟环境存储在./.nox
中,可是,你可使用--envdir
进行更改:
nox --envdir /tmp/envs复制代码
在不少状况下,仅须要 nox 运行安装命令,例如准备环境做离线测试,或者从新建立用于测试的虚拟环境。你可使用--install-only
跳过 run 命令。
例如,给定这个 noxfile:
@nox.session
def tests(session):
session.install("pytest")
session.install(".")
session.run("pytest")复制代码
运行:
nox --install-only复制代码
将同时运行两个 install 命令,但跳过 run 命令:
nox > Running session tests
nox > Creating virtualenv using python3.7 in ./.nox/tests
nox > pip install pytest
nox > pip install .
nox > Skipping pytest run, as --install-only is set.
nox > Session tests was successful.复制代码
session.interactive可用于判断 nox 是在交互式终端(例如一个实际的人在其计算机上运行它)仍是在非交互式终端(例如一个连续集成系统)中运行。
@nox.session
def docs(session):
...
if session.interactive:
nox.run("sphinx-autobuild", ...)
else:
nox.run("sphinx-build", ...)复制代码
有时,须要强制 nox 将会话视为非交互式的。你可使用--non-interactive
参数来执行此操做:
nox --non-interactive复制代码
这会使得session.interactive
始终返回 False 。
默认状况下,若是你在交互式终端中使用,则 nox 将输出彩色的日志。可是,若是要将stderr
重定向到文件,或者不使用交互式终端,或者设置了环境变量NO_COLOR
,则 nox 会以纯文本格式输出。
你可使用--nocolor
和--forcecolor
标志来手动控制 nox 的输出。
例如,这将始终输出彩色日志:
nox --forcecolor复制代码
可是,这将永远不会输出彩色日志:
nox --nocolor复制代码
默认状况下,nox 仅显示失败的命令的输出,当给命令传递了silent = False
时,没有输出。经过将--verbose
传递给 nox,不管 silent 参数如何,都会显示全部命令的全部输出。
你能够经过指定--report
以json
格式输出报告:
nox --report status.json复制代码
nox 临时性支持在 Windows 上运行。可是,这取决于你的 Windows,Python 和虚拟环境的版本可能会出现问题。有关更多信息,请参见如下内容:
Windows 上的 Python 二进制文件可经过 Windows 的 Python 启动器(py )找到。例如,经过肯定py -3.5
会调用哪一个可执行文件,以此来找到 Python 3.5 。若是一个测试须要使用特定的 Python 的 32 位版本,则应使用X.Y-32
做为版本。
nox 具备将 tox.ini 文件转换为 noxfile.py 文件的实验性支持。它还不支持 tox 的全部功能,仅用于完成过分转换的大部分机械工做,你可能仍须要对转换后的 noxfile.py 做一些修改。
要使用转换器,请在安装 nox 时附上tox_to_nox
:
pip install --upgrade nox[tox_to_nox]复制代码
而后,只需在 tox.ini 所在的目录中运行tox-to-nox
:
tox-to-nox复制代码
这将基于 tox.ini 中的环境建立一个 noxfile.py。一些注意事项:
tox-to-nox
不够聪明,没法将其转换为参数化的会话,可是手动提取通用配置以进行参数化应该很简单。 将适当的命令添加到 shell 的配置文件中,以便在启动时运行。你可能须要重启或从新登陆,才能使自动补齐功能生效。
bash
eval "$(register-python-argcomplete nox)"复制代码
zsh
# To activate completions for zsh you need to have
# bashcompinit enabled in zsh:
autoload -U bashcompinit
bashcompinit
# Afterwards you can enable completion for nox:
eval "$(register-python-argcomplete nox)"复制代码
tcsh
eval `register-python-argcomplete --shell tcsh nox`复制代码
fish
register-python-argcomplete --shell fish nox | .复制代码
公众号【Python猫】, 本号连载优质的系列文章,有喵星哲学猫系列、Python进阶系列、好书推荐系列、技术写做、优质英文推荐与翻译等等,欢迎关注哦。