From 639751ad00245f4af7f712ef18654486200b2460 Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 14:39:38 +0100 Subject: [PATCH 01/13] Change release to 1.0.0 --- galaxy.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/galaxy.yml b/galaxy.yml index 4bff825..317a806 100644 --- a/galaxy.yml +++ b/galaxy.yml @@ -1,6 +1,6 @@ namespace: community name: libvirt -version: 0.1.0 +version: 1.0.0 readme: README.md authors: - Ansible (https://github.com/ansible) From 50345258e168f8ec1e0b43761d0548239b93ae05 Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 14:42:11 +0100 Subject: [PATCH 02/13] Remove unnecessary test dependencies These are not required and cause test failures often. --- tests/utils/shippable/shippable.sh | 21 --------------------- 1 file changed, 21 deletions(-) diff --git a/tests/utils/shippable/shippable.sh b/tests/utils/shippable/shippable.sh index eb967d8..49ab106 100755 --- a/tests/utils/shippable/shippable.sh +++ b/tests/utils/shippable/shippable.sh @@ -127,27 +127,6 @@ else timeout=45 fi -# STAR: HACK install dependencies - -#ansible-galaxy collection install ansible.windows -p "${COLLECTION_DIR}" -ansible-galaxy collection install ansible.posix -p "${COLLECTION_DIR}" -ansible-galaxy collection install community.crypto -p "${COLLECTION_DIR}" -ansible-galaxy collection install ansible.netcommon -p "${COLLECTION_DIR}" - -# unit tests -ansible-galaxy collection install community.kubernetes -p "${COLLECTION_DIR}" -ansible-galaxy collection install netbox.netbox -p "${COLLECTION_DIR}" -ansible-galaxy collection install netapp.ontap -p "${COLLECTION_DIR}" -ansible-galaxy collection install cisco.meraki -p "${COLLECTION_DIR}" -ansible-galaxy collection install fortinet.fortios -p "${COLLECTION_DIR}" -ansible-galaxy collection install junipernetworks.junos -p "${COLLECTION_DIR}" -ansible-galaxy collection install cisco.aci -p "${COLLECTION_DIR}" -ansible-galaxy collection install google.cloud -p "${COLLECTION_DIR}" -ansible-galaxy collection install community.kubernetes -p "${COLLECTION_DIR}" -ansible-galaxy collection install f5networks.f5_modules -p "${COLLECTION_DIR}" - -# END: HACK - ansible-test env --dump --show --timeout "${timeout}" --color -v "tests/utils/shippable/check_matrix.py" From adc1d50bb7cb11503c00bea8d068a6ded6b8efe8 Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 15:11:55 +0100 Subject: [PATCH 03/13] Add changelog config file --- changelogs/config.yaml | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 changelogs/config.yaml diff --git a/changelogs/config.yaml b/changelogs/config.yaml new file mode 100644 index 0000000..83e48d0 --- /dev/null +++ b/changelogs/config.yaml @@ -0,0 +1,31 @@ +changelog_filename_template: ../CHANGELOG.rst +changelog_filename_version_depth: 0 +changes_file: changelog.yaml +changes_format: combined +ignore_other_fragment_extensions: true +keep_fragments: false +mention_ancestor: true +new_plugins_after_name: removed_features +notesdir: fragments +prelude_section_name: release_summary +prelude_section_title: Release Summary +sections: +- - major_changes + - Major Changes +- - minor_changes + - Minor Changes +- - breaking_changes + - Breaking Changes / Porting Guide +- - deprecated_features + - Deprecated Features +- - removed_features + - Removed Features (previously deprecated) +- - security_fixes + - Security Fixes +- - bugfixes + - Bugfixes +- - known_issues + - Known Issues +title: Community.Libvirt +trivial_section_name: trivial +use_fqcn: true From 18ca828181f11b03d447faa7c961e6f954e42242 Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 15:19:10 +0100 Subject: [PATCH 04/13] Fix test ignores --- tests/sanity/ignore-2.10.txt | 10 +--------- tests/sanity/ignore-2.11.txt | 1 + tests/sanity/ignore.txt | 9 +++++++++ 3 files changed, 11 insertions(+), 9 deletions(-) mode change 100644 => 120000 tests/sanity/ignore-2.10.txt create mode 120000 tests/sanity/ignore-2.11.txt create mode 100644 tests/sanity/ignore.txt diff --git a/tests/sanity/ignore-2.10.txt b/tests/sanity/ignore-2.10.txt deleted file mode 100644 index 8d5eb32..0000000 --- a/tests/sanity/ignore-2.10.txt +++ /dev/null @@ -1,9 +0,0 @@ -tests/unit/mock/path.py future-import-boilerplate -tests/unit/mock/path.py metaclass-boilerplate -tests/unit/mock/yaml_helper.py future-import-boilerplate -tests/unit/mock/yaml_helper.py metaclass-boilerplate -tests/unit/modules/cloud/misc/virt_net/conftest.py future-import-boilerplate -tests/unit/modules/cloud/misc/virt_net/conftest.py metaclass-boilerplate -tests/unit/modules/cloud/misc/virt_net/test_virt_net.py future-import-boilerplate -tests/unit/modules/cloud/misc/virt_net/test_virt_net.py metaclass-boilerplate -tests/utils/shippable/timing.py shebang diff --git a/tests/sanity/ignore-2.10.txt b/tests/sanity/ignore-2.10.txt new file mode 120000 index 0000000..f749b40 --- /dev/null +++ b/tests/sanity/ignore-2.10.txt @@ -0,0 +1 @@ +ignore.txt \ No newline at end of file diff --git a/tests/sanity/ignore-2.11.txt b/tests/sanity/ignore-2.11.txt new file mode 120000 index 0000000..f749b40 --- /dev/null +++ b/tests/sanity/ignore-2.11.txt @@ -0,0 +1 @@ +ignore.txt \ No newline at end of file diff --git a/tests/sanity/ignore.txt b/tests/sanity/ignore.txt new file mode 100644 index 0000000..8d5eb32 --- /dev/null +++ b/tests/sanity/ignore.txt @@ -0,0 +1,9 @@ +tests/unit/mock/path.py future-import-boilerplate +tests/unit/mock/path.py metaclass-boilerplate +tests/unit/mock/yaml_helper.py future-import-boilerplate +tests/unit/mock/yaml_helper.py metaclass-boilerplate +tests/unit/modules/cloud/misc/virt_net/conftest.py future-import-boilerplate +tests/unit/modules/cloud/misc/virt_net/conftest.py metaclass-boilerplate +tests/unit/modules/cloud/misc/virt_net/test_virt_net.py future-import-boilerplate +tests/unit/modules/cloud/misc/virt_net/test_virt_net.py metaclass-boilerplate +tests/utils/shippable/timing.py shebang From 7932d4ee874282275b3f66933c2db6a1fd898799 Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 15:19:59 +0100 Subject: [PATCH 05/13] Add /tests/output/ to .gitignore --- .gitignore | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index 029519e..9803526 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1,6 @@ +# python stuff __pycache__/ -*.py[cod] \ No newline at end of file +*.py[cod] + +# ansible-test stuff +/tests/output/ From 9f50a01c7f4c1e14b5dcff62c7eaea0a6fd3c293 Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 15:26:15 +0100 Subject: [PATCH 06/13] Add meta/runtime.yml Add requirement for the minimum version of Ansible --- meta/runtime.yml | 2 ++ 1 file changed, 2 insertions(+) create mode 100644 meta/runtime.yml diff --git a/meta/runtime.yml b/meta/runtime.yml new file mode 100644 index 0000000..2ee3c9f --- /dev/null +++ b/meta/runtime.yml @@ -0,0 +1,2 @@ +--- +requires_ansible: '>=2.9.10' From e1fec9233b7e2fddc8fddd151fe83832030720e3 Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 15:52:50 +0100 Subject: [PATCH 07/13] [tests] Switch from RHEL 7.6 to RHEL 7.8 --- shippable.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/shippable.yml b/shippable.yml index 3069fc9..4ce56f7 100644 --- a/shippable.yml +++ b/shippable.yml @@ -24,7 +24,7 @@ matrix: # - env: T=aix/7.2/1 # - env: T=osx/10.11/1 - - env: T=rhel/7.6/1 + - env: T=rhel/7.8/1 - env: T=rhel/8.1/1 - env: T=freebsd/11.1/1 - env: T=freebsd/12.1/1 From e1a8c4565667ac44b7d6b3a2cc7f1a569e0b5d45 Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 15:53:14 +0100 Subject: [PATCH 08/13] [tests] Switch from RHEL 8.1 to RHEL 8.2 --- shippable.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/shippable.yml b/shippable.yml index 4ce56f7..9fb7cf7 100644 --- a/shippable.yml +++ b/shippable.yml @@ -25,7 +25,7 @@ matrix: # - env: T=aix/7.2/1 # - env: T=osx/10.11/1 - env: T=rhel/7.8/1 - - env: T=rhel/8.1/1 + - env: T=rhel/8.2/1 - env: T=freebsd/11.1/1 - env: T=freebsd/12.1/1 - env: T=linux/centos6/1 From 90946b1fa6f8d858aaf9c4c39ec4204655785c6f Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 15:54:43 +0100 Subject: [PATCH 09/13] [tests] Remove Fedora 30 and add Fedora 32 --- shippable.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/shippable.yml b/shippable.yml index 9fb7cf7..c0b5154 100644 --- a/shippable.yml +++ b/shippable.yml @@ -31,8 +31,8 @@ matrix: - env: T=linux/centos6/1 - env: T=linux/centos7/1 - env: T=linux/centos8/1 - - env: T=linux/fedora30/1 - env: T=linux/fedora31/1 + - env: T=linux/fedora32/1 - env: T=linux/opensuse15py2/1 - env: T=linux/opensuse15/1 - env: T=linux/ubuntu1604/1 From 19e73a01eac8971211fcb309f9bd21a89c0ad05c Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 15:55:51 +0100 Subject: [PATCH 10/13] Remove ANSIBLE_METADATA --- plugins/modules/virt.py | 3 --- plugins/modules/virt_net.py | 5 ----- plugins/modules/virt_pool.py | 5 ----- 3 files changed, 13 deletions(-) diff --git a/plugins/modules/virt.py b/plugins/modules/virt.py index 7370197..550304e 100644 --- a/plugins/modules/virt.py +++ b/plugins/modules/virt.py @@ -9,9 +9,6 @@ from __future__ import absolute_import, division, print_function __metaclass__ = type -ANSIBLE_METADATA = {'metadata_version': '1.1', - 'status': ['preview'], - 'supported_by': 'community'} DOCUMENTATION = ''' --- diff --git a/plugins/modules/virt_net.py b/plugins/modules/virt_net.py index f6b451c..d62eb5a 100644 --- a/plugins/modules/virt_net.py +++ b/plugins/modules/virt_net.py @@ -8,11 +8,6 @@ __metaclass__ = type -ANSIBLE_METADATA = {'metadata_version': '1.1', - 'status': ['preview'], - 'supported_by': 'community'} - - DOCUMENTATION = ''' --- module: virt_net diff --git a/plugins/modules/virt_pool.py b/plugins/modules/virt_pool.py index 85e8c3c..5fdd419 100644 --- a/plugins/modules/virt_pool.py +++ b/plugins/modules/virt_pool.py @@ -8,11 +8,6 @@ __metaclass__ = type -ANSIBLE_METADATA = {'metadata_version': '1.1', - 'status': ['preview'], - 'supported_by': 'community'} - - DOCUMENTATION = ''' --- module: virt_pool From c7bc422641a8a094bbf1a1ae3dea4cf801e9a381 Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 15:56:38 +0100 Subject: [PATCH 11/13] Remove remnants of smoke tests --- tests/utils/shippable/cloud.sh | 17 +---------------- 1 file changed, 1 insertion(+), 16 deletions(-) diff --git a/tests/utils/shippable/cloud.sh b/tests/utils/shippable/cloud.sh index da037e0..d76c322 100755 --- a/tests/utils/shippable/cloud.sh +++ b/tests/utils/shippable/cloud.sh @@ -13,22 +13,7 @@ target="shippable/${cloud}/group${group}/" stage="${S:-prod}" -changed_all_target="shippable/${cloud}/smoketest/" - -if ! ansible-test integration "${changed_all_target}" --list-targets > /dev/null 2>&1; then - # no smoketest tests are available for this cloud - changed_all_target="none" -fi - -if [ "${group}" == "1" ]; then - # only run smoketest tests for group1 - changed_all_mode="include" -else - # smoketest tests already covered by group1 - changed_all_mode="exclude" -fi - # shellcheck disable=SC2086 ansible-test integration --color -v --retry-on-error "${target}" ${COVERAGE:+"$COVERAGE"} ${CHANGED:+"$CHANGED"} ${UNSTABLE:+"$UNSTABLE"} \ --remote-terminate always --remote-stage "${stage}" \ - --docker --python "${python}" --changed-all-target "${changed_all_target}" --changed-all-mode "${changed_all_mode}" + --docker --python "${python}" From b309373e065bf7442c8ce071feeea352cb873fd9 Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 16:04:08 +0100 Subject: [PATCH 12/13] Use collection namespace in examples --- plugins/connection/libvirt_lxc.py | 2 +- plugins/modules/virt.py | 14 +++++++------- plugins/modules/virt_net.py | 26 +++++++++++++------------- plugins/modules/virt_pool.py | 28 ++++++++++++++-------------- 4 files changed, 35 insertions(+), 35 deletions(-) diff --git a/plugins/connection/libvirt_lxc.py b/plugins/connection/libvirt_lxc.py index 4f80299..947be7b 100644 --- a/plugins/connection/libvirt_lxc.py +++ b/plugins/connection/libvirt_lxc.py @@ -10,7 +10,7 @@ DOCUMENTATION = ''' author: Michael Scherer - connection: libvirt_lxc + connection: community.libvirt.libvirt_lxc short_description: Run tasks in lxc containers via libvirt description: - Run commands or put/fetch files to an existing lxc container using libvirt diff --git a/plugins/modules/virt.py b/plugins/modules/virt.py index 550304e..deb03a4 100644 --- a/plugins/modules/virt.py +++ b/plugins/modules/virt.py @@ -64,7 +64,7 @@ EXAMPLES = ''' # a playbook task line: -- virt: +- community.libvirt.virt: name: alpha state: running @@ -75,37 +75,37 @@ # defining and launching an LXC guest - name: define vm - virt: + community.libvirt.virt: command: define xml: "{{ lookup('template', 'container-template.xml.j2') }}" uri: 'lxc:///' - name: start vm - virt: + community.libvirt.virt: name: foo state: running uri: 'lxc:///' # setting autostart on a qemu VM (default uri) - name: set autostart for a VM - virt: + community.libvirt.virt: name: foo autostart: yes # Defining a VM and making is autostart with host. VM will be off after this task - name: define vm from xml and set autostart - virt: + community.libvirt.virt: command: define xml: "{{ lookup('template', 'vm_template.xml.j2') }}" autostart: yes # Listing VMs - name: list all VMs - virt: + community.libvirt.virt: command: list_vms register: all_vms - name: list only running VMs - virt: + community.libvirt.virt: command: list_vms state: running register: running_vms diff --git a/plugins/modules/virt_net.py b/plugins/modules/virt_net.py index d62eb5a..3101988 100644 --- a/plugins/modules/virt_net.py +++ b/plugins/modules/virt_net.py @@ -68,69 +68,69 @@ EXAMPLES = ''' # Define a new network -- virt_net: +- community.libvirt.virt_net: command: define name: br_nat xml: '{{ lookup("template", "network/bridge.xml.j2") }}' # Start a network -- virt_net: +- community.libvirt.virt_net: command: create name: br_nat # List available networks -- virt_net: +- community.libvirt.virt_net: command: list_nets # Get XML data of a specified network -- virt_net: +- community.libvirt.virt_net: command: get_xml name: br_nat # Stop a network -- virt_net: +- community.libvirt.virt_net: command: destroy name: br_nat # Undefine a network -- virt_net: +- community.libvirt.virt_net: command: undefine name: br_nat # Gather facts about networks # Facts will be available as 'ansible_libvirt_networks' -- virt_net: +- community.libvirt.virt_net: command: facts # Gather information about network managed by 'libvirt' remotely using uri -- virt_net: +- community.libvirt.virt_net: command: info uri: '{{ item }}' with_items: '{{ libvirt_uris }}' register: networks # Ensure that a network is active (needs to be defined and built first) -- virt_net: +- community.libvirt.virt_net: state: active name: br_nat # Ensure that a network is inactive -- virt_net: +- community.libvirt.virt_net: state: inactive name: br_nat # Ensure that a given network will be started at boot -- virt_net: +- community.libvirt.virt_net: autostart: yes name: br_nat # Disable autostart for a given network -- virt_net: +- community.libvirt.virt_net: autostart: no name: br_nat # Add a new host in the dhcp pool -- virt_net: +- community.libvirt.virt_net: name: br_nat command: modify xml: "" diff --git a/plugins/modules/virt_pool.py b/plugins/modules/virt_pool.py index 5fdd419..ce8da46 100644 --- a/plugins/modules/virt_pool.py +++ b/plugins/modules/virt_pool.py @@ -74,74 +74,74 @@ EXAMPLES = ''' # Define a new storage pool -- virt_pool: +- community.libvirt.virt_pool: command: define name: vms xml: '{{ lookup("template", "pool/dir.xml.j2") }}' # Build a storage pool if it does not exist -- virt_pool: +- community.libvirt.virt_pool: command: build name: vms # Start a storage pool -- virt_pool: +- community.libvirt.virt_pool: command: create name: vms # List available pools -- virt_pool: +- community.libvirt.virt_pool: command: list_pools # Get XML data of a specified pool -- virt_pool: +- community.libvirt.virt_pool: command: get_xml name: vms # Stop a storage pool -- virt_pool: +- community.libvirt.virt_pool: command: destroy name: vms # Delete a storage pool (destroys contents) -- virt_pool: +- community.libvirt.virt_pool: command: delete name: vms # Undefine a storage pool -- virt_pool: +- community.libvirt.virt_pool: command: undefine name: vms # Gather facts about storage pools # Facts will be available as 'ansible_libvirt_pools' -- virt_pool: +- community.libvirt.virt_pool: command: facts # Gather information about pools managed by 'libvirt' remotely using uri -- virt_pool: +- community.libvirt.virt_pool: command: info uri: '{{ item }}' with_items: '{{ libvirt_uris }}' register: storage_pools # Ensure that a pool is active (needs to be defined and built first) -- virt_pool: +- community.libvirt.virt_pool: state: active name: vms # Ensure that a pool is inactive -- virt_pool: +- community.libvirt.virt_pool: state: inactive name: vms # Ensure that a given pool will be started at boot -- virt_pool: +- community.libvirt.virt_pool: autostart: yes name: vms # Disable autostart for a given pool -- virt_pool: +- community.libvirt.virt_pool: autostart: no name: vms ''' From 51f8c02ca7c70c1dd7746d209e1be123b6a48fbc Mon Sep 17 00:00:00 2001 From: "Jesse Pretorius (odyssey4me)" Date: Tue, 18 Aug 2020 16:13:58 +0100 Subject: [PATCH 13/13] Add changelog for 1.0.0 --- .gitignore | 3 +++ CHANGELOG.rst | 15 +++++++++++++++ changelogs/changelog.yaml | 10 ++++++++++ changelogs/fragments/23-inventory.yml | 4 ---- 4 files changed, 28 insertions(+), 4 deletions(-) create mode 100644 CHANGELOG.rst create mode 100644 changelogs/changelog.yaml delete mode 100644 changelogs/fragments/23-inventory.yml diff --git a/.gitignore b/.gitignore index 9803526..fe044d7 100644 --- a/.gitignore +++ b/.gitignore @@ -4,3 +4,6 @@ __pycache__/ # ansible-test stuff /tests/output/ + +# antsibull-changelog stuff +/changelogs/.plugin-cache.yaml diff --git a/CHANGELOG.rst b/CHANGELOG.rst new file mode 100644 index 0000000..6d4f63f --- /dev/null +++ b/CHANGELOG.rst @@ -0,0 +1,15 @@ +=============================== +Community.Libvirt Release Notes +=============================== + +.. contents:: Topics + + +v1.0.0 +====== + +Major Changes +------------- + +- added generic libvirt inventory plugin +- removed libvirt_lxc inventory script diff --git a/changelogs/changelog.yaml b/changelogs/changelog.yaml new file mode 100644 index 0000000..94ddca7 --- /dev/null +++ b/changelogs/changelog.yaml @@ -0,0 +1,10 @@ +ancestor: null +releases: + 1.0.0: + changes: + major_changes: + - added generic libvirt inventory plugin + - removed libvirt_lxc inventory script + fragments: + - 23-inventory.yml + release_date: '2020-08-18' diff --git a/changelogs/fragments/23-inventory.yml b/changelogs/fragments/23-inventory.yml deleted file mode 100644 index 89364e4..0000000 --- a/changelogs/fragments/23-inventory.yml +++ /dev/null @@ -1,4 +0,0 @@ ---- -major_changes: - - removed libvirt_lxc inventory script - - added generic libvirt inventory plugin