Моя книга воспроизведения:
- name: JBoss KeyStore and Truststore passwords will be stored in the password vault
#shell: less "{{ vault }}"
shell: cat "{{ vault }}"
register: vault_contents
tags:
- BW.6.1.1.10
with_items:
- "{{ vault }}"
- debug:
msg: "JBoss config filedoes not contains the word vault"
when: vault_contents.stdout.find('$VAULT') == -1
Я пытаюсь прочитать несколько файлов через ansible, используя шаблон Jinga2, проанализировать вывод как стандартный вывод, найти ключевое слово и сообщить о нем.
Этозавершается с ошибкой ниже:
TASK [testing_roles : debug] **************************************************************************. *****************************************************************
fatal: [d84e4fe137f4]: FAILED! => {"failed": true, "msg": "The conditional check 'vault_contents.stdout.find('$VAULT') == -1' failed.
The error was: error while evaluating conditional (vault_contents.stdout.find('$VAULT') == -1): 'dict object' has no attribute 'stdout'\n\nThe error appears to have been in '/Ansible/Ansible/Relearn/testing_roles/roles/testing_roles/tasks/main.yml': line 49, column 5, but may\nbe elsewhere in the file depending on the exact syntax problem.\n\nThe offending line appears to be:\n\n - \"{{ vault }}\"\n - debug:\n ^ here\n"}
to retry, use: --limit @/Ansible/Ansible/Relearn/testing_roles/playbook.retry
Когда я добавляю его с одной записью файла, он работает, как ожидалось, но когда он изменяется на ряд файлов, он завершается ошибкой.
ЭтоПравильный подход для сканирования нескольких файлов в Ansible или должен быть с использованием какого-либо другого модуля или метода.
Любая помощь очень ценится.
В файле Vars он имеет следующее содержание:
vault:
- /jboss-as-7.1.1.Final/standalone/configuration/standalone-full-ha.xml
Спасибо