ignores

可以跳过单个文件的健全性测试,并且可以忽略特定的错误。

何时忽略错误

健全性测试旨在提高代码质量并识别内容中的常见问题。在开发过程中发现问题时,应纠正这些问题。

随着 Ansible 的不断开发,健全性测试会扩展以检测以前版本无法检测到的问题。为了给现有内容提供时间来更新以通过较新的测试,可以添加忽略条目。新内容不应使用忽略来处理现有的健全性测试。

修复代码以解决健全性测试错误时,还必须删除任何相关的忽略条目。如果未删除忽略条目,则会将其报告为不必要的忽略错误。这旨在防止在修复后由于再次出现相同错误而导致将来的回归。

何时跳过测试

虽然很少见,但有一些原因可以跳过健全性测试,而不是忽略其报告的错误。

如果健全性测试在处理内容时导致回溯,则无法忽略该错误。如果发生这种情况,请为此问题打开一个新的 错误报告,以便可以修复它。如果回溯是由于内容问题导致的,则应修复该问题。如果内容正确,则需要跳过测试,直到修复健全性测试中的错误。

在跳过健全性测试而不是忽略它们时应谨慎使用。由于测试完全跳过,因此不会自动检测到问题的解决。这将防止在问题解决后回归检测正常工作。因此,最好定期手动查看跳过的条目,以验证它们是否是必需的。

忽略文件位置

忽略文件的位置取决于要测试的内容类型。

Ansible 集合

由于健全性测试在 Ansible 版本之间会发生变化,因此每个 Ansible 主要版本都需要单独的忽略文件。

文件名是 tests/sanity/ignore-X.Y.txt,其中 X.Y 是用于测试集合的 Ansible 版本。

为每个 Ansible 版本维护单独的文件允许集合通过多个 Ansible 版本的测试。

Ansible

测试 Ansible 时,所有忽略都放在 test/sanity/ignore.txt 文件中。

只需要一个文件,因为 ansible-test 是作为 Ansible 本身的一部分开发和发布的。

忽略文件格式

忽略文件每行包含一个条目。每行由两列组成,用单个空格分隔。可以在条目的末尾添加注释,以井号 (#) 字符开头,井号字符前面可以有零个或多个空格。不允许有空白行和仅包含注释的行。

第一列指定条目应用的文件的文件路径。文件路径必须相对于正在测试的内容的根目录。这可以是 Ansible 源代码或 Ansible 集合。文件路径不能包含空格或井号 (#) 字符。

第二列指定条目应用的健全性测试。这将是健全性测试的名称。如果健全性测试特定于 Python 版本,则名称将包含破折号 (-) 和相关的 Python 版本。如果命名的测试使用错误代码,则必须将要忽略的错误代码附加到测试的名称,并用冒号 (:) 分隔。

以下是 Ansible 集合的一些忽略条目示例

roles/my_role/files/my_script.sh shellcheck:SC2154 # ignore undefined variable
plugins/modules/my_module.py validate-modules:missing-gplv3-license # ignore license check
plugins/modules/my_module.py import-3.8 # needs update to support collections.abc on Python 3.8+

也可以跳过特定文件的健全性测试。可以通过在第二列的健全性测试名称后添加 !skip 来完成此操作。完成此操作后,即使健全性测试使用错误代码,也不会包含错误代码。

以下是 Ansible 集合的一些跳过条目示例

plugins/module_utils/my_util.py validate-modules!skip # waiting for bug fix in module validator
plugins/lookup/my_plugin.py compile-2.6!skip # Python 2.6 is not supported on the control node

请参阅完整的 健全性测试 列表,其中详细介绍了各种测试以及如何修复已识别的问题。

忽略文件错误

可能会报告忽略文件本身存在各种错误

  • 解析忽略文件的语法错误

  • 引用不存在的文件路径

  • 引用不存在的健全性测试

  • 忽略不会发生的错误

  • 忽略跳过的文件

  • 重复条目