- name : Test that retrieving a url works
set_fact :
web_data : "{{ lookup('url', 'https://' ~ httpbin_host ~ '/get?one') }}"
- name : Assert that the url was retrieved
assert :
that :
- "'one' in web_data.args"
- name : Test that retrieving a url with invalid cert fails
set_fact :
web_data : "{{ lookup('url', 'https://' ~ badssl_host ~ '/') }}"
ignore_errors : True
register : url_invalid_cert
- assert :
that :
- "url_invalid_cert.failed"
- "'Error validating the server' in url_invalid_cert.msg or 'Hostname mismatch' in url_invalid_cert.msg or ( url_invalid_cert.msg is search('hostname .* doesn.t match .*'))"
- name : Test that retrieving a url with invalid cert with validate_certs=False works
set_fact :
web_data : "{{ lookup('url', 'https://' ~ badssl_host ~ '/', validate_certs=False) }}"
register : url_no_validate_cert
- assert :
that :
- badssl_host_substring in web_data
- vars :
url : https://{{ httpbin_host }}/get
block :
- name : test good cipher
debug :
msg : '{{ lookup("url", url) }}'
vars :
ansible_lookup_url_ciphers : ECDHE-RSA-AES128-SHA256
register : good_ciphers
- name : test bad cipher
debug :
msg : '{{ lookup("url", url) }}'
vars :
ansible_lookup_url_ciphers : ECDHE-ECDSA-AES128-SHA
ignore_errors : true
register : bad_ciphers
- assert :
that :
- good_ciphers is successful
- bad_ciphers is failed
- name : Test use_netrc=False
import_tasks : use_netrc.yml
- vars :
ansible_lookup_url_agent : ansible-test-lookup-url-agent
block :
- name : Test user agent
set_fact :
web_data : "{{ lookup('url', 'https://' ~ httpbin_host ~ '/user-agent') }}"
- name : Assert that user agent is set
assert :
that :
- ansible_lookup_url_agent in web_data['user-agent']
- vars :
ansible_lookup_url_force_basic_auth : yes
block :
- name : Test force basic auth
set_fact :
web_data : "{{ lookup('url', 'https://' ~ httpbin_host ~ '/headers', username='abc') }}"
- name : Assert that Authorization header is set
assert :
that :
- "'Authorization' in web_data.headers"