get_url should accept headers as a dict, instead of only a complicated string (#35470)
* get_url should accept headers as a dict, instead of only a complicated string * update headers description text * Add headers string and dict tests for get_url * Add intg test for string header format parsing error * Adjust deprecation version ahead 1 release, add the version dict format was added in to description
This commit is contained in:
parent
89d6c36584
commit
0507c907a9
2 changed files with 45 additions and 5 deletions
|
@ -114,7 +114,9 @@ options:
|
|||
version_added: '1.8'
|
||||
headers:
|
||||
description:
|
||||
- Add custom HTTP headers to a request in the format "key:value,key:value".
|
||||
- Add custom HTTP headers to a request in hash/dict format. The hash/dict format was added in 2.6.
|
||||
Previous versions used a C("key:value,key:value") string format. The C("key:value,key:value") string
|
||||
format is deprecated and will be removed in version 2.10.
|
||||
version_added: '2.0'
|
||||
url_username:
|
||||
description:
|
||||
|
@ -387,7 +389,7 @@ def main():
|
|||
sha256sum=dict(type='str', default=''),
|
||||
checksum=dict(type='str', default=''),
|
||||
timeout=dict(type='int', default=10),
|
||||
headers=dict(type='str'),
|
||||
headers=dict(type='raw'),
|
||||
tmp_dest=dict(type='path'),
|
||||
)
|
||||
|
||||
|
@ -410,11 +412,14 @@ def main():
|
|||
tmp_dest = module.params['tmp_dest']
|
||||
|
||||
# Parse headers to dict
|
||||
if module.params['headers']:
|
||||
if isinstance(module.params['headers'], dict):
|
||||
headers = module.params['headers']
|
||||
elif module.params['headers']:
|
||||
try:
|
||||
headers = dict(item.split(':', 1) for item in module.params['headers'].split(','))
|
||||
module.deprecate('Supplying `headers` as a string is deprecated. Please use dict/hash format for `headers`', version='2.10')
|
||||
except Exception:
|
||||
module.fail_json(msg="The header parameter requires a key:value,key:value syntax to be properly parsed.")
|
||||
module.fail_json(msg="The string representation for the `headers` parameter requires a key:value,key:value syntax to be properly parsed.")
|
||||
else:
|
||||
headers = None
|
||||
|
||||
|
|
|
@ -234,6 +234,41 @@
|
|||
url: https://{{ httpbin_host }}
|
||||
dest: "{{ output_dir }}"
|
||||
|
||||
- name: Test headers string
|
||||
get_url:
|
||||
url: https://{{ httpbin_host }}/headers
|
||||
headers: Foo:bar,Baz:qux
|
||||
dest: "{{ output_dir }}/headers_string.json"
|
||||
|
||||
- name: Test headers string
|
||||
assert:
|
||||
that:
|
||||
- (lookup('file', output_dir ~ '/headers_string.json')|from_json).headers.get('Foo') == 'bar'
|
||||
- (lookup('file', output_dir ~ '/headers_string.json')|from_json).headers.get('Baz') == 'qux'
|
||||
|
||||
- name: Test headers string invalid format
|
||||
get_url:
|
||||
url: https://{{ httpbin_host }}/headers
|
||||
headers: Foo
|
||||
dest: "{{ output_dir }}/headers_string_invalid.json"
|
||||
register: invalid_string_headers
|
||||
failed_when:
|
||||
- invalid_string_headers is successful
|
||||
- invalid_string_headers.msg != "The string representation for the `headers` parameter requires a key:value,key:value syntax to be properly parsed."
|
||||
|
||||
- name: Test headers dict
|
||||
get_url:
|
||||
url: https://{{ httpbin_host }}/headers
|
||||
headers:
|
||||
Foo: bar
|
||||
Baz: qux
|
||||
dest: "{{ output_dir }}/headers_dict.json"
|
||||
|
||||
- name: Test headers dict
|
||||
assert:
|
||||
that:
|
||||
- (lookup('file', output_dir ~ '/headers_dict.json')|from_json).headers.get('Foo') == 'bar'
|
||||
- (lookup('file', output_dir ~ '/headers_dict.json')|from_json).headers.get('Baz') == 'qux'
|
||||
|
||||
- name: Test client cert auth, with certs
|
||||
get_url:
|
||||
|
|
Loading…
Reference in a new issue