integration-aliases
集成测试由 ansible-test 执行,并位于 test/integration/targets/ 下的目录中。每个测试都必须有一个 aliases 文件来控制测试执行。
以下章节解释了别名。每个别名都必须在 aliases 文件中单独一行。
分组
必须将测试配置为恰好运行在一个组中。这是通过将相应的组添加到 aliases 文件来完成的。
以下是一些可用组的示例:
shippable/posix/group1shippable/windows/group2shippable/azure/group3shippable/aws/group1shippable/cloud/group1
分组用于在多个 CI 作业中平衡测试,以最大限度地减少测试运行时间。它们还通过使具有相似需求的测试一起运行来提高效率。
为新的测试选择组时,请使用与正在添加的测试类似的现有测试相同的组。如果有多个组可用,则随机选择一个。
设置
别名可用于在运行测试之前执行设置目标
setup/once/TARGET- 在需要它的第一个目标之前运行目标TARGET。setup/always/TARGET- 在需要它的每个目标之前运行目标TARGET。
需求
别名可用于表达一些测试需求
needs/privileged- 使用--docker运行测试时,需要--docker-privileged。needs/root- 需要以root身份运行测试或使用--docker。needs/ssh- 需要无需密码即可连接到本地主机(或使用--docker的测试容器)的 SSH 连接。needs/httptester- 需要使用 http-test-container 来运行测试。
依赖
一些测试依赖项会自动发现
在
meta/main.yml文件中定义的 Ansible 角色依赖项。使用
setup/*别名定义的设置目标。从一个目标到另一个目标中的文件的符号链接。
别名可用于声明未自动处理的依赖项
needs/target/TARGET- 需要使用测试目标TARGET。needs/file/PATH- 需要使用相对于 Git 根目录的文件PATH。
跳过
别名可用于使用以下方法跳过平台
skip/freebsd- 跳过 FreeBSD 上的测试。skip/macos- 跳过 macOS 上的测试。skip/rhel- 跳过 RHEL 上的测试。skip/docker- 在 Docker 容器中运行时跳过测试。
还可以跳过使用 --remote 选项指定的平台版本(删除 /)。
skip/freebsd11.1- 跳过 FreeBSD 11.1 上的测试。skip/rhel7.6- 跳过 RHEL 7.6 上的测试。
还可以跳过使用 --windows 选项指定的 Windows 版本
skip/windows/2016- 跳过 Windows Server 2016 上的测试。skip/windows/2019- 跳过 Windows Server 2019 上的测试。skip/windows/2022- 跳过 Windows Server 2022 上的测试。
别名可用于跳过以下 Python 主版本:
skip/python2- 跳过 Python 2.x 上的测试。skip/python3- 跳过 Python 3.x 上的测试。
要进行更细粒度的跳过,请在集成测试剧本中使用条件语句,例如:
when: ansible_distribution in ('Ubuntu')
其他
还有一些其他可用的别名
destructive- 需要--allow-destructive才能在没有--docker或--remote的情况下运行。hidden- 目标被忽略。可用作依赖项。对于setup_和prepare_前缀的目标自动执行。retry/never- 目标被排除在--retry-on-error选项启用的重试之外。gather_facts/yes- 启用在运行目标之前收集事实(默认选项)。gather_facts/no- 禁用在运行目标之前收集事实。
不稳定
有时会失败的测试应标记为 unstable 别名,直到解决不稳定性为止。这些测试将继续针对修改测试或被测模块的拉取请求运行。
这避免了其他拉取请求以及合并运行和夜间 CI 作业中的不必要的测试失败。
有两种方法可以手动运行不稳定的测试
对
ansible-test使用--allow-unstable选项在将其传递给
ansible-test时,在测试名前加unstable/前缀。
Ansible 核心团队成员会将测试标记为不稳定。将创建 GitHub 问题 来跟踪每个不稳定的测试。
已禁用
总是失败的测试应标记为 disabled 别名,直到可以修复它们为止。
已禁用的测试会自动跳过。
有两种方法可以手动运行已禁用的测试
对
ansible-test使用--allow-disabled选项在将其传递给
ansible-test时,在测试名前加disabled/前缀。
Ansible核心团队成员会将测试标记为已禁用。GitHub 问题 将被创建来跟踪每个禁用的测试。
不支持
无法在CI中运行的测试应使用unsupported别名标记。大多数测试都可以通过使用模拟器和/或云插件来支持。
但是,如果这是不可能的,那么将测试标记为不支持将阻止它在CI中运行。
有两种方法可以手动运行不受支持的测试
对
ansible-test使用--allow-unsupported选项在将测试名称传递给
ansible-test时,在其前面加上unsupported/。
测试将由测试贡献者标记为不支持。
云
针对云服务和其他需要访问外部API的模块的测试通常需要在CI中进行特殊测试支持。
这些需要额外的别名来指示所需的测试插件。
一些可用的别名是
cloud/awscloud/azurecloud/cscloud/digitaloceancloud/openshiftcloud/vcenter
未测试
每个模块和插件都应该有集成测试,即使这些测试无法在CI中运行。
问题
问题
有关集成测试的问题,请通过创建带有ansible-test、testing和其他适当标签的主题,在Ansible论坛上联系社区。