进一步学习 nox 教程,轻松掌握命令行用法

英文 |Command-line usagehtml

出处 | nox 官方文档python

译者 | 豌豆花下猫@Python猫git

Github地址:https://github.com/chinesehuazhou/noxdoccngithub

声明:本翻译基于CC BY-NC-SA 4.0受权协议,内容略有改动,转载请保留原文出处,请勿用于商业或非法用途。shell

接上篇《Python 任务自动化工具:nox 的配置与 APIdjango

调用方式

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 参数如何,都会显示全部命令的全部输出。

输出机器可读的报告

你能够经过指定--reportjson格式输出报告:

nox --report status.json复制代码

Windows

nox 临时性支持在 Windows 上运行。可是,这取决于你的 Windows,Python 和虚拟环境的版本可能会出现问题。有关更多信息,请参见如下内容:

Windows 上的 Python 二进制文件可经过 Windows 的 Python 启动器(py )找到。例如,经过肯定py -3.5 会调用哪一个可执行文件,以此来找到 Python 3.5 。若是一个测试须要使用特定的 Python 的 32 位版本,则应使用X.Y-32 做为版本。

从 tox 转化

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不够聪明,没法将其转换为参数化的会话,可是手动提取通用配置以进行参数化应该很简单。
  • 因为 tox 解析其配置的方式,全部替换项 会在转换时被引入。这意味着你须要用适当的变量替换 noxfile.py 中的静态字符串。
  • 几种不经常使用的 tox 选项还没有实现,但有可能实现。若是遇到你认为有用的功能,请提出功能请求(feature request)。

shell 补齐

将适当的命令添加到 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进阶系列、好书推荐系列、技术写做、优质英文推荐与翻译等等,欢迎关注哦。

相关文章
相关标签/搜索