Estou tendo um problema com o Ansible Lint não encontrando community.general
módulos:
> ansible-lint <redacted>.yml
WARNING Listing 1 violation(s) that are fatal
syntax-check[unknown-module]: couldn't resolve module/action 'community.general.locale_gen'. This often indicates a misspelling, missing collection, or incorrect module path.
<readacted>.yml:16:3
Esta ação é:
- name: Set locale
community.general.locale_gen:
name: en_US.UTF-8
Estou no macOS Sonoma 14.4.1 e instalei o Ansible via Homebrew (detalhes da versão no final). Pelo que sei, isso inclui muitos dos módulos da comunidade sem a necessidade de instalá-los via Ansible Galaxy:
> ansible-galaxy collection list | grep community.general
community.general 8.6.0
Portanto, o manual funciona bem, mas ansilbe-lint
não consegue encontrar o módulo.
Eu notei isso no topo de ansible-galaxy collection list
:
# /opt/homebrew/Cellar/ansible/9.5.1/libexec/lib/python3.12/site-packages/ansible_collections
Collection Version
---------------------------------------- -------
Se eu definir ANSIBLE_COLLECTIONS_PATH
esse /opt/homebrew/.../ansible_collections
caminho, então funciona. Mas parece que eu não deveria ter que fazer isso? Se ansible-playbook
consegue encontrá-lo, por que não consegue ansible-lint
? Como posso ansible-lint
procurar automaticamente o caminho da coleção interno?
Informação da versão:
> ansible --version
ansible [core 2.16.6]
config file = /Users/dave/work/ansible/dribin-infra/ansible.cfg
configured module search path = ['/Users/dave/work/ansible/dribin-infra/library']
ansible python module location = /opt/homebrew/Cellar/ansible/9.5.1/libexec/lib/python3.12/site-packages/ansible
ansible collection location = /Users/dave/.ansible/collections:/usr/share/ansible/collections
executable location = /opt/homebrew/bin/ansible
python version = 3.12.3 (main, Apr 9 2024, 08:09:14) [Clang 15.0.0 (clang-1500.3.9.4)] (/opt/homebrew/Cellar/ansible/9.5.1/libexec/bin/python)
jinja version = 3.1.3
libyaml = True
==> ansible: stable 9.5.1 (bottled), HEAD
Automate deployment, configuration, and upgrading
https://www.ansible.com/
Installed
/opt/homebrew/Cellar/ansible/9.5.1 (31,927 files, 365.5MB) *
Poured from bottle using the formulae.brew.sh API on 2024-04-26 at 23:40:10
From: https://github.com/Homebrew/homebrew-core/blob/HEAD/Formula/a/ansible.rb
...
ATUALIZAÇÃO 22/05/2024 : Isso se deve à interação entre a
COLLECTIONS_SCAN_SYS_PATH
configuração do Ansible e o fato de o Homebrew instalar aplicativos Python em seus próprios ambientes virtuais.Quando
COLLECTIONS_SCAN_SYS_PATH
definido comotrue
, que é o padrão, o Ansible procurarásys.path
as coleções instaladas. No entanto, quando o Homebrew instala aplicativos Python, ele normalmente os instala em seu próprio ambiente virtual :Portanto, ao instalar
ansible
eansible-lint
via Homebrew, cada um obtém sua versão isolada dosys.path
, por estar no seu própriovenv
. Isso significaansible
queansible-playbook
podemos encontrar as coleções, masansible-lint
não podemos encontrá-las.Uma solução possível seria configurar
collections_scan_sys_path = false
eansible.cfg
, em seguida, instalar explicitamente todas as coleções de comunidades dependentes.Embora isso pareça mais robusto, e eu possa eventualmente tentar isso, a solução alternativa que usei foi instalar ambos com
pipx
e usar com cuidadopipx inject
.Primeiro, tentei instalar
ansible
separadamenteansible-lint
viapipx
, em vez do Homebrew:Ansible exigiu injeção
passlib
para que opassword_hash
filtro funcionasse:Infelizmente, isso ainda falhou da mesma forma que as instalações do Homebrew, porque estão em ambientes virtuais isolados e separados.
NO ENTANTO, em vez de instalar
ansible-lint
separadamente nopipx
, se também foi injetado noansible
ambiente virtual, então funciona:Observe que isso
--include-apps
é necessário aqui para queasnbile-lint
haja um link simbólico para obin/
diretório.