6874ba23ff
* Import original unmodified upstream version This is another attempt to get the xml module upstream. https://github.com/cmprescott/ansible-xml/ This is the original file from upstream, without commit 1e7a3f6b6e2bc01aa9cebfd80ac5cd4555032774 * Add additional changes required for upstreaming This PR includes the following changes: - Clean up of DOCUMENTATION - Rename "ensure" parameter to "state" parameter (kept alias) - Added EXAMPLES - Remove explicit type-case using str() for formatting - Clean up AnsibleModule parameter handling - Retained Python 2.4 compatibility - PEP8 compliancy - Various fixes as suggested by abadger during first review This fixes cmprescott/ansible-xml#108 * Added original integration tests There is some room for improvement wrt. idempotency and check-mode testing. * Some tests depend on lxml v3.0alpha1 or higher We are now expecting lxml v2.3.0 or higher. We skips tests if lxml is too old. Plus small fix. * Relicense to GPLv3+ header All past contributors have agreed to relicense this module to GPLv2+, and GPLv3 specifically. See: https://github.com/cmprescott/ansible-xml/issues/113 This fixes cmprescott/ansible-xml#73 * Fix small typo in integration tests * Python 3 support This PR also includes: - Python 3 support - Documentation fixes - Check-mode fixes and improvements - Bugfix in check-mode support - Always return xmlstring, even if there's no change - Check for lxml 2.3.0 or newer * Add return values * Various fixes after review
22 lines
828 B
YAML
22 lines
828 B
YAML
---
|
|
- name: Setup test fixture
|
|
copy:
|
|
src: '{{ role_path }}/fixtures/ansible-xml-beers.xml'
|
|
dest: /tmp/ansible-xml-beers.xml
|
|
|
|
- name: Add child element
|
|
xml:
|
|
path: /tmp/ansible-xml-beers.xml
|
|
xpath: /business/beers
|
|
add_children:
|
|
- beer:
|
|
name: Ansible Brew
|
|
type: light
|
|
|
|
# NOTE: This test may fail if lxml does not support predictable element attribute order
|
|
# So we filter the failure out for these platforms (e.g. CentOS 6)
|
|
# The module still works fine, we simply are not comparing as smart as we should.
|
|
- name: Test expected result
|
|
command: diff -u {{ role_path }}/results/test-add-children-with-attributes.xml /tmp/ansible-xml-beers.xml
|
|
register: diff
|
|
failed_when: diff.rc != 0 and lxml_predictable_attribute_order
|