Skip to content

Commit

Permalink
Attempt to fix tests
Browse files Browse the repository at this point in the history
  • Loading branch information
spetrosi committed Jan 4, 2024
1 parent 291587e commit afac1ce
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 30 deletions.
3 changes: 2 additions & 1 deletion handlers/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,8 @@
changed_when: true
when: >-
(ansible_distribution in ['CentOS', 'RedHat'] and
ansible_facts.distribution_major_version is version('7', '=')) or
(ansible_facts.distribution_major_version is version('7', '=') or
ansible_facts.distribution_major_version is version('9', '='))) or
ansible_distribution == 'Fedora'
- name: Rebuild grub config
Expand Down
70 changes: 41 additions & 29 deletions tests/tests_add_rm.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,37 +14,44 @@
include_role:
name: linux-system-roles.bootloader

- name: Clone the oldest kernel and initrd for test purposes
# Images in CI might have a grub timeout set to a different other than the
# default 5 value.
# In this case, the above invocation require handlers to be flushed.
- name: Flush handlers
meta: flush_handlers

- name: Set fact with the default kernel to use for clones
set_fact:
test_kernel: "{{ bootloader_facts | rejectattr('initrd', 'undefined')
| selectattr('default', 'equalto', True) | first }}"

- name: Clone test_kernel kernel and initrd for test purposes
copy:
src: "{{ item.src }}"
remote_src: true
dest: "{{ item.dest }}"
mode: preserve
loop:
- src: "{{ (bootloader_facts | last).kernel }}"
dest: "{{ (bootloader_facts | last).kernel }}_clone1"
- src: "{{ (bootloader_facts | last).initrd |
regex_replace(' .*$', '') }}"
dest: "{{ (bootloader_facts | last).initrd |
regex_replace(' .*$', '') }}_clone1"
- src: "{{ (bootloader_facts | last).kernel }}"
dest: "{{ (bootloader_facts | last).kernel }}_clone2"
- src: "{{ (bootloader_facts | last).initrd |
regex_replace(' .*$', '') }}"
dest: "{{ (bootloader_facts | last).initrd |
regex_replace(' .*$', '') }}_clone2"
- src: "{{ test_kernel.kernel }}"
dest: "{{ test_kernel.kernel }}_clone1"
- src: "{{ test_kernel.initrd | regex_replace(' .*$', '') }}"
dest: "{{ test_kernel.initrd | regex_replace(' .*$', '') }}_clone1"
- src: "{{ test_kernel.kernel }}"
dest: "{{ test_kernel.kernel }}_clone2"
- src: "{{ test_kernel.initrd | regex_replace(' .*$', '') }}"
dest: "{{ test_kernel.initrd | regex_replace(' .*$', '') }}_clone2"

- name: Create Clone1 kernel with copy_defaults=true
vars:
bootloader_settings:
- kernel:
path: "{{ (bootloader_facts | last).kernel }}_clone1"
initrd: "{{ (bootloader_facts | last).initrd |
path: "{{ test_kernel.kernel }}_clone1"
initrd: "{{ test_kernel.initrd |
regex_replace(' .*$', '') }}_clone1"
title: Clone1
options:
- name: console
value: tty0
- name: test
value: setting
state: present
- copy_default: true
include_role:
Expand All @@ -66,20 +73,22 @@
- name: Verify settings
vars:
__default_args: "{{
(bootloader_facts | selectattr('default', 'equalto', True) |
(bootloader_facts | selectattr('title', 'defined') |
selectattr('default', 'equalto', True) |
first).args }}"
assert:
that: >-
(bootloader_facts | selectattr('title', 'search', 'Clone1') |
first).args == __default_args ~ ' console=tty0'
(bootloader_facts | selectattr('title', 'defined') |
selectattr('title', 'search', 'Clone1') |
first).args == __default_args ~ ' test=setting'
- name: Remove Clone1 kernel with 3 kernel keys
vars:
bootloader_gather_facts: true
bootloader_settings:
- kernel:
path: "{{ (bootloader_facts | last).kernel }}_clone1"
initrd: "{{ (bootloader_facts | last).initrd |
path: "{{ test_kernel.kernel }}_clone1"
initrd: "{{ test_kernel.initrd |
regex_replace(' .*$', '') }}_clone1"
title: Clone1
options:
Expand All @@ -93,15 +102,16 @@

- name: Verify that Clone1 kernel is removed
assert:
that: bootloader_facts | selectattr('title', 'search', 'Clone1') |
that: bootloader_facts | selectattr('title', 'defined') |
selectattr('title', 'search', 'Clone1') |
list | length == 0

- name: Create clone2 kernel without copy_defaults=true
vars:
bootloader_settings:
- kernel:
path: "{{ (bootloader_facts | last).kernel }}_clone2"
initrd: "{{ (bootloader_facts | last).initrd |
path: "{{ test_kernel.kernel }}_clone2"
initrd: "{{ test_kernel.initrd |
regex_replace(' .*$', '') }}_clone2"
title: Clone2
options:
Expand All @@ -127,16 +137,17 @@
- name: Verify settings
assert:
that: >-
(bootloader_facts | selectattr('title', 'search', 'Clone2') |
(bootloader_facts | selectattr('title', 'defined') |
selectattr('title', 'search', 'Clone2') |
first).args == 'console=tty0'
- name: Remove Clone2 kernel with kernel path
vars:
bootloader_gather_facts: true
bootloader_settings:
- kernel:
path: "{{ (bootloader_facts | last).kernel }}_clone2"
initrd: "{{ (bootloader_facts | last).initrd |
path: "{{ test_kernel.kernel }}_clone2"
initrd: "{{ test_kernel.initrd |
regex_replace(' .*$', '') }}_clone2"
title: Clone2
state: absent
Expand All @@ -145,5 +156,6 @@

- name: Verify that Clone2 kernel is removed
assert:
that: bootloader_facts | selectattr('title', 'search', 'Clone2') |
that: bootloader_facts | selectattr('title', 'defined') |
selectattr('title', 'search', 'Clone2') |
list | length == 0
3 changes: 3 additions & 0 deletions tests/tests_settings.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@
include_role:
name: linux-system-roles.bootloader

# Images in CI might have a grub timeout set to a different other than the
# default 5 value.
# In this case, the above invocation require handlers to be flushed.
- name: Flush handlers
meta: flush_handlers

Expand Down

0 comments on commit afac1ce

Please sign in to comment.