summaryrefslogtreecommitdiffstats
path: root/test/integration/targets/fetch/test_unreadable_with_stat.yml
diff options
context:
space:
mode:
authorSam Doran <sdoran@redhat.com>2021-06-16 19:51:07 +0200
committerGitHub <noreply@github.com>2021-06-16 19:51:07 +0200
commitbe0cdc0ea28cdfd0ba4fb448fe66b4dde2aedcb6 (patch)
treedb2c49b93ddacb2c5f44fec97f23798dfc8686ad /test/integration/targets/fetch/test_unreadable_with_stat.yml
parentAdded FAQ entry for complex validation needs (#74707) (diff)
downloadansible-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.yml27
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')