2

我有一个 requirements.yml 文件,其中列出了 Ansible 角色的依赖项:

---

- src: git@gitrepo:group/dependency1.git
  scm: git
  name: name1

- src: git@gitrepo:group/dependency1.git
  scm: git
  name: name2

这些角色本身没有任何依赖关系,并且由于它们位于私有 SCM 系统上(以及其他原因),它们不需要任何元数据。但是,加载 Ansible 依赖项需要此文件存在。因此,依赖项有一个空白的 meta/main.yml 以启用 ansible-galaxy。

安装依赖项时使用:

ansible-galaxy install --role-file requirements.yml --roles-path foo

安装第一个依赖项后,它会出错:

ERROR! Unexpected Exception: 'NoneType' object has no attribute 'get'

使用非常详细的输出,可以找到错误:

galaxy.py", line 394

在实验之后,多次运行该命令将通过依赖项,一次一个。因此,嵌套依赖项会失败;因为父级会安装然后出错,或者 ansible-galaxy 会认为父级已经安装并跳过依赖项。

问题是:如何阻止此错误的发生并让 ansible-galaxy 正确处理我的依赖项?

4

2 回答 2

4

我刚刚修复了devel这个。应该制作 Ansible 的 2.4 版本。

于 2017-08-31T18:01:38.850 回答
0

事实证明,空白的 meta/main.yml 不足以将角色作为依赖项处理。我的假设是,如果文件为空白,角色对象会在没有元数据字段的情况下初始化,因为详细输出中提到的行是:

role_dependencies = role.metadata.get('dependencies') or []

“角色”在此行之前使用,因此将是一个实例,而这是第一次提到“元数据”。

这部分代码正在处理安装嵌套依赖项,因为上面的行正在检查以确定它是否应该处理嵌套依赖项。

if not no_deps and installed:
  role_dependencies = role.metadata.get('dependencies') or []
  ...

如果此行还检查了元数据的存在,例如:

if not no_deps and installed and metadata:

那么本节将被(正确地)跳过。但是,由于 Ansible 没有进行此检查,元数据是“NoneType”对象,它确实没有“get”属性。

这意味着 meta/main.yml 文件中至少需要一个键才能作为依赖项进行处理。有一个 meta/main.yml 文件:

---

galaxy_info:

足以达到此目的。

于 2017-08-01T08:43:39.247 回答