1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00
community.general/test/integration/targets/zypper/tasks/zypper.yml
Matt Martz 4fe08441be Deprecate tests used as filters (#32361)
* Warn on tests used as filters

* Update docs, add aliases for tests that fit more gramatically with test syntax

* Fix rst formatting

* Add successful filter, alias of success

* Remove renamed_deprecation, it was overkill

* Make directory alias for is_dir

* Update tests to use proper jinja test syntax

* Update additional documentation, living outside of YAML files, to reflect proper jinja test syntax

* Add conversion script, porting guide updates, and changelog updates

* Update newly added uses of tests as filters

* No underscore variable

* Convert recent tests as filter changes to win_stat

* Fix some changes related to rebasing a few integration tests

* Make tests_as_filters_warning explicitly accept the name of the test, instead of inferring the name

* Add test for tests_as_filters_warning

* Update tests as filters in newly added/modified tests

* Address recent changes to several integration tests

* Address recent changes in cs_vpc
2017-11-27 17:58:08 -05:00

318 lines
7 KiB
YAML

# UNINSTALL
- name: uninstall hello
zypper: name=hello state=removed
register: zypper_result
- name: check hello with rpm
shell: rpm -q hello
failed_when: False
register: rpm_result
- debug: var=zypper_result
- debug: var=rpm_result
- name: verify uninstallation of hello
assert:
that:
- "zypper_result.rc == 0"
- "rpm_result.rc == 1"
# UNINSTALL AGAIN
- name: uninstall hello again
zypper: name=hello state=removed
register: zypper_result
- name: verify no change on re-uninstall
assert:
that:
- "not zypper_result.changed"
# INSTALL
- name: install hello
zypper: name=hello state=present
register: zypper_result
- name: check hello with rpm
shell: rpm -q hello
failed_when: False
register: rpm_result
- debug: var=zypper_result
- debug: var=rpm_result
- name: verify installation of hello
assert:
that:
- "zypper_result.rc == 0"
- "zypper_result.changed"
- "rpm_result.rc == 0"
# INSTALL AGAIN
- name: install hello again
zypper: name=hello state=present
register: zypper_result
- name: verify no change on second install
assert:
that:
- "not zypper_result.changed"
# Multiple packages
- name: uninstall hello and metamail
zypper:
name:
- hello
- metamail
state: removed
register: zypper_result
- name: check hello with rpm
shell: rpm -q hello
failed_when: False
register: rpm_hello_result
- name: check metamail with rpm
shell: rpm -q metamail
failed_when: False
register: rpm_metamail_result
- name: verify packages uninstalled
assert:
that:
- "rpm_hello_result.rc != 0"
- "rpm_metamail_result.rc != 0"
- name: install hello and metamail
zypper:
name:
- hello
- metamail
state: present
register: zypper_result
- name: check hello with rpm
shell: rpm -q hello
failed_when: False
register: rpm_hello_result
- name: check metamail with rpm
shell: rpm -q metamail
failed_when: False
register: rpm_metamail_result
- name: verify packages installed
assert:
that:
- "zypper_result.rc == 0"
- "zypper_result.changed"
- "rpm_hello_result.rc == 0"
- "rpm_metamail_result.rc == 0"
- name: uninstall hello and metamail
zypper:
name:
- hello
- metamail
state: removed
# INSTALL nonexistent package
- name: install hello from url
zypper: name=doesnotexist state=present
register: zypper_result
ignore_errors: yes
- name: verify package installation failed
assert:
that:
- "zypper_result.rc == 104"
- "zypper_result.msg.startswith('No provider of')"
# INSTALL broken local package
- name: create directory
file:
path: "{{output_dir | expanduser}}/zypper1"
state: directory
- name: fake rpm package
file:
path: "{{output_dir | expanduser}}/zypper1/broken.rpm"
state: touch
- name: install broken rpm
zypper:
name="{{output_dir | expanduser}}/zypper1/broken.rpm"
state=present
register: zypper_result
ignore_errors: yes
- debug: var=zypper_result
- name: verify we failed installation of broken rpm
assert:
that:
- "zypper_result.rc == 3"
- "'Problem reading the RPM header' in zypper_result.stdout"
# Build and install an empty rpm
- name: uninstall empty
zypper:
name: empty
state: removed
- name: clean zypper RPM cache
file:
name: /var/cache/zypper/RPMS
state: absent
- name: create directory
file:
path: "{{output_dir | expanduser}}/zypper2"
state: directory
- name: copy spec file
copy:
src: empty.spec
dest: "{{ output_dir | expanduser }}/zypper2/empty.spec"
- name: build rpm
command: |
rpmbuild -bb \
--define "_topdir {{output_dir | expanduser }}/zypper2/rpm-build"
--define "_builddir %{_topdir}" \
--define "_rpmdir %{_topdir}" \
--define "_srcrpmdir %{_topdir}" \
--define "_specdir {{output_dir | expanduser}}/zypper2" \
--define "_sourcedir %{_topdir}" \
{{ output_dir }}/zypper2/empty.spec
register: rpm_build_result
- name: install empty rpm
zypper:
name: "{{ output_dir | expanduser }}/zypper2/rpm-build/noarch/empty-1-0.noarch.rpm"
disable_gpg_check: yes
register: zypper_result
- name: check empty with rpm
shell: rpm -q empty
failed_when: False
register: rpm_result
- name: verify installation of empty
assert:
that:
- "zypper_result.rc == 0"
- "zypper_result.changed"
- "rpm_result.rc == 0"
- name: uninstall empty
zypper:
name: empty
state: removed
# test simultaneous remove and install using +- prefixes
- name: install hello to prep next task
zypper:
name: hello
state: present
- name: remove metamail to prep next task
zypper:
name: metamail
state: absent
- name: install and remove in the same run, with +- prefix
zypper:
name:
- -hello
- +metamail
state: present
register: zypper_res1
- name: install and remove again, leave out plus
zypper: name={{item}} state=present
with_items:
- metamail
- -hello
register: zypper_res1a
- name: in and rm swapped
zypper: name={{item}} state=present
with_items:
- -metamail
- hello
register: zypper_res1b
- name: install metamail
zypper: name=metamail state=absent
register: zypper_res2
- name: remove hello
zypper: name=hello state=present
register: zypper_res3
- name: verify simultaneous install/remove worked
assert:
that:
- zypper_res1 is successful
- zypper_res1 is changed
- zypper_res1a is not changed
- zypper_res1b is changed
- zypper_res2 is not changed
- zypper_res3 is not changed
- name: install and remove with state=absent
zypper: name={{item}} state=absent
with_items:
- metamail
- +hello
register: zypper_res
ignore_errors: yes
- name: verify simultaneous install/remove failed with absent
assert:
that:
- zypper_res is failed
- zypper_res.results[0].msg == "Can not combine '+' prefix with state=remove/absent."
- name: try rm patch
zypper: name=openSUSE-2016-128 type=patch state=absent
ignore_errors: yes
register: zypper_patch
- assert:
that:
- zypper_patch is failed
- zypper_patch.msg.startswith('Can not remove patches.')
- name: try rm URL
zypper: name=http://download.opensuse.org/repositories/openSUSE:/Leap:/{{ ansible_distribution_version }}/standard/x86_64/hello-2.9-6.2.x86_64.rpm state=absent
ignore_errors: yes
register: zypper_rm
- assert:
that:
- zypper_rm is failed
- zypper_rm.msg.startswith('Can not remove via URL.')
# check for https://github.com/ansible/ansible/issues/20139
- name: run updatecache
zypper:
name: hello
state: present
update_cache: True
register: zypper_result_update_cache
- name: run updatecache in check mode
zypper:
name: hello
state: present
update_cache: True
check_mode: True
register: zypper_result_update_cache_check
- assert:
that:
- zypper_result_update_cache is successful
- zypper_result_update_cache_check is successful
- zypper_result_update_cache_check is not changed