diff options
author | Sam Doran <sdoran@redhat.com> | 2021-06-16 19:51:07 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-06-16 19:51:07 +0200 |
commit | be0cdc0ea28cdfd0ba4fb448fe66b4dde2aedcb6 (patch) | |
tree | db2c49b93ddacb2c5f44fec97f23798dfc8686ad /test/integration/targets/fetch/test_unreadable_with_stat.yml | |
parent | Added FAQ entry for complex validation needs (#74707) (diff) | |
download | ansible-be0cdc0ea28cdfd0ba4fb448fe66b4dde2aedcb6.tar.xz ansible-be0cdc0ea28cdfd0ba4fb448fe66b4dde2aedcb6.zip |
deprecate `_remote_checksum()` and remove use in fetch (#74848)
* Remove use of _remote_checksum from fetch module
* Add deprecation message displayed during runtime
* Increase test coverage for fetch
* Add tests covering the use of stat from the fetch module
This required creating an unpriveleged user account and connecting as that user remotely since
it is not possible to create a file that the root user cannot stat.
* Use fact caching to persist remote tmp dir across playbook runs
* Add variables to setup_remote_tmp test role to allow caching of the remote temp dir fact
and preventing removal of the remote_tmp_dir
Diffstat (limited to 'test/integration/targets/fetch/test_unreadable_with_stat.yml')
-rw-r--r-- | test/integration/targets/fetch/test_unreadable_with_stat.yml | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/test/integration/targets/fetch/test_unreadable_with_stat.yml b/test/integration/targets/fetch/test_unreadable_with_stat.yml new file mode 100644 index 0000000000..e00026bc6f --- /dev/null +++ b/test/integration/targets/fetch/test_unreadable_with_stat.yml @@ -0,0 +1,27 @@ +# This playbook needs to be run as a non-root user without become. Under +# those circumstances, the fetch module uses stat and not slurp. + +- name: Test unreadable file using stat + hosts: testhost + gather_facts: no + + tasks: + - name: Try to fetch a file inside an inaccessible directory + fetch: + src: "{{ remote_tmp_dir }}/noaccess/file1" + dest: "{{ output_dir }}" + register: failed_fetch_no_access + ignore_errors: yes + + - name: Try to fetch a file inside an inaccessible directory without fail_on_missing + fetch: + src: "{{ remote_tmp_dir }}/noaccess/file1" + dest: "{{ output_dir }}" + fail_on_missing: no + register: failed_fetch_no_access_fail_on_missing + + - assert: + that: + - failed_fetch_no_access is failed + - failed_fetch_no_access.msg is search('Permission denied') + - failed_fetch_no_access_fail_on_missing.msg is search(', ignored') |