Fix encrypt files stat validation
The input to encrypt files may be a list of paths so our validation has to evaluate and state each list entry separately. Without this we fail beacuse the list of paths is treated like a single path and that does not stat resulting in early failure. Change-Id: Ibe3f6b162c3adad928708464ea03ddded2f4c683
This commit is contained in:
parent
e88f592c4d
commit
21341d2d47
@ -1,7 +1,18 @@
|
|||||||
|
- name: Stat input file
|
||||||
|
stat:
|
||||||
|
path: '{{ zj_encrypt_file }}'
|
||||||
|
loop: '{{ [ encrypt_file ] if encrypt_file is string else encrypt_file }}'
|
||||||
|
loop_control:
|
||||||
|
loop_var: zj_encrypt_file
|
||||||
|
register: _stat_result
|
||||||
|
|
||||||
- name: Validate input file
|
- name: Validate input file
|
||||||
fail:
|
fail:
|
||||||
msg: 'Must define "encrypt_file"'
|
msg: '{{ zj_stat_result.stat.path }} : file does not exist'
|
||||||
when: encrypt_file is undefined
|
when: not zj_stat_result.stat.exists
|
||||||
|
loop: '{{ _stat_result.results }}'
|
||||||
|
loop_control:
|
||||||
|
loop_var: zj_stat_result
|
||||||
|
|
||||||
- name: Ensure gpg2 installed
|
- name: Ensure gpg2 installed
|
||||||
package:
|
package:
|
||||||
|
@ -130,12 +130,25 @@
|
|||||||
path: '{{ _tempfile.path }}.gpg'
|
path: '{{ _tempfile.path }}.gpg'
|
||||||
state: absent
|
state: absent
|
||||||
|
|
||||||
# Do it again to exercise already imported keys path
|
- name: Make a second fake file
|
||||||
|
tempfile:
|
||||||
|
state: file
|
||||||
|
register: _tempfile2
|
||||||
|
|
||||||
|
- name: Add some data to second fake file
|
||||||
|
copy:
|
||||||
|
content: 'Hello, I am encrypted. This is the second file.'
|
||||||
|
dest: '{{ _tempfile2.path }}'
|
||||||
|
|
||||||
|
# Do it again to exercise already imported keys path and check we can
|
||||||
|
# encrypt multiple files.
|
||||||
- name: Encrypt file
|
- name: Encrypt file
|
||||||
include_role:
|
include_role:
|
||||||
name: encrypt-file
|
name: encrypt-file
|
||||||
vars:
|
vars:
|
||||||
encrypt_file: '{{ _tempfile.path }}'
|
encrypt_file:
|
||||||
|
- '{{ _tempfile.path }}'
|
||||||
|
- '{{ _tempfile2.path }}'
|
||||||
encrypt_file_recipients:
|
encrypt_file_recipients:
|
||||||
- zuul-jobs-test-2
|
- zuul-jobs-test-2
|
||||||
- zuul-jobs-test-3
|
- zuul-jobs-test-3
|
||||||
@ -151,3 +164,14 @@
|
|||||||
file:
|
file:
|
||||||
path: '{{ _tempfile.path }}.gpg'
|
path: '{{ _tempfile.path }}.gpg'
|
||||||
state: absent
|
state: absent
|
||||||
|
|
||||||
|
- name: Remove second temporary file
|
||||||
|
file:
|
||||||
|
path: '{{ _tempfile2.path }}'
|
||||||
|
state: absent
|
||||||
|
when: _tempfile2.path is defined
|
||||||
|
|
||||||
|
- name: Remove second encrypted output file
|
||||||
|
file:
|
||||||
|
path: '{{ _tempfile2.path }}.gpg'
|
||||||
|
state: absent
|
||||||
|
Loading…
x
Reference in New Issue
Block a user