summaryrefslogtreecommitdiff
path: root/test/integration/targets/fetch/roles/fetch_tests/tasks/main.yml
blob: 267ae0f0cd47f53c1e538c8877476a0858bc66a8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
# test code for the pip module
# (c) 2014, Michael DeHaan <michael.dehaan@gmail.com>

# This file is part of Ansible
#
# Ansible is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Ansible is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Ansible.  If not, see <http://www.gnu.org/licenses/>.

- name: create a file that we can use to fetch
  copy: content="test" dest={{ remote_tmp_dir }}/orig

- name: fetch the test file
  fetch: src={{ remote_tmp_dir }}/orig dest={{ output_dir }}/fetched
  register: fetched

- debug: var=fetched

- name: Assert that we fetched correctly
  assert:
    that:
      - 'fetched["changed"] == True'
      - 'fetched["checksum"] == "a94a8fe5ccb19ba61c4c0873d391e987982fbbd3"'
      - 'fetched["remote_checksum"] == "a94a8fe5ccb19ba61c4c0873d391e987982fbbd3"'
      - 'lookup("file", output_dir + "/fetched/" + inventory_hostname + remote_tmp_dir + "/orig") == "test"'

# TODO: check the become and non-become forms of fetch because in one form we'll do
# the get method of the connection plugin and in the become case we'll use the
# fetch module.

- name: fetch a second time to show idempotence
  fetch: src={{ remote_tmp_dir }}/orig dest={{ output_dir }}/fetched
  register: fetched

- name: Assert that the file was not fetched the second time
  assert:
    that:
      - 'fetched["changed"] == False'
      - 'fetched["checksum"] == "a94a8fe5ccb19ba61c4c0873d391e987982fbbd3"'

- name: attempt to fetch a non-existent file - do not fail on missing
  fetch: src={{ remote_tmp_dir }}/doesnotexist dest={{ output_dir }}/fetched fail_on_missing=False
  register: fetch_missing_nofail

- name: check fetch missing no fail result
  assert:
    that:
      - "fetch_missing_nofail.msg"
      - "fetch_missing_nofail is not changed"

- name: attempt to fetch a non-existent file - fail on missing
  fetch: src={{ remote_tmp_dir }}/doesnotexist dest={{ output_dir }}/fetched fail_on_missing=yes
  register: fetch_missing
  ignore_errors: true

- name: check fetch missing with failure
  assert:
    that:
      - "fetch_missing is failed"
      - "fetch_missing.msg"
      - "fetch_missing is not changed"

- name: attempt to fetch a non-existent file - fail on missing implicit
  fetch: src={{ remote_tmp_dir }}/doesnotexist dest={{ output_dir }}/fetched
  register: fetch_missing_implicit
  ignore_errors: true

- name: check fetch missing with failure with implicit fail
  assert:
    that:
      - "fetch_missing_implicit is failed"
      - "fetch_missing_implicit.msg"
      - "fetch_missing_implicit is not changed"

- name: attempt to fetch a directory - should not fail but return a message
  fetch: src={{ remote_tmp_dir }} dest={{ output_dir }}/somedir fail_on_missing=False
  register: fetch_dir

- name: check fetch directory result
  assert:
    that:
      - "fetch_dir is not changed"
      - "fetch_dir.msg"

- name: attempt to fetch a directory - should fail
  fetch: src={{ remote_tmp_dir }} dest={{ output_dir }}/somedir fail_on_missing=True
  register: failed_fetch_dir
  ignore_errors: true

- name: check fetch directory result
  assert:
    that:
      - "failed_fetch_dir is failed"
      - "fetch_dir.msg"

- name: create symlink to a file that we can fetch
  file:
    path: "{{ remote_tmp_dir }}/link"
    src: "{{ remote_tmp_dir }}/orig"
    state: "link"

- name: fetch the file via a symlink
  fetch: src={{ remote_tmp_dir }}/link dest={{ output_dir }}/fetched-link
  register: fetched

- debug: var=fetched

- name: Assert that we fetched correctly
  assert:
    that:
      - 'fetched["changed"] == True'
      - 'fetched["checksum"] == "a94a8fe5ccb19ba61c4c0873d391e987982fbbd3"'
      - 'fetched["remote_checksum"] == "a94a8fe5ccb19ba61c4c0873d391e987982fbbd3"'
      - 'lookup("file", output_dir + "/fetched-link/" + inventory_hostname + remote_tmp_dir + "/link") == "test"'

# TODO: check the become and non-become forms of fetch because in one form we'll do
# the get method of the connection plugin and in the become case we'll use the
# fetch module.

- name: dest is an existing directory name without trailing slash and flat=yes, should fail
  fetch:
    src: "{{ remote_tmp_dir }}/orig"
    dest: "{{ output_dir }}"
    flat: yes
  register: failed_fetch_dest_dir
  ignore_errors: true

- name: check that it indeed failed
  assert:
    that:
      - "failed_fetch_dest_dir is failed"
      - "failed_fetch_dest_dir.msg"