2a13f189be
Resolves: RHEL-58465 - package rhel-system-roles.noarch does not provide docs for ansible-doc [rhel-8.10.z] Resolves: RHEL-58494 ad_integration - fix: Sets domain name lower case in realmd.conf section header [rhel-8.10.z] Resolves: RHEL-58917 bootloader - bootloader role tests do not work on ostree [rhel-8.10.z] Resolves: RHEL-45711 bootloader - fix: Set user.cfg path to /boot/grub2/ on EL 9 UEFI [rhel-8] Resolves: RHEL-58515 cockpit - cockpit install all wildcard match does not work in newer el9 [rhel-8.10.z] Resolves: RHEL-58485 logging - RFE - system-roles - logging: Add truncate options for local file inputs [rhel-8.10.z] Resolves: RHEL-58481 logging - redhat.rhel_system_roles.logging role fails to process logging_outputs: of type: "custom" [rhel-8.10.z] Resolves: RHEL-58477 logging - [RFE] Add the umask settings or enable a variable in linux-system-roles.logging [rhel-8.10.z] Resolves: RHEL-37550 logging - Setup imuxsock using rhel-system-roles.logging causing an error EL8 Resolves: RHEL-58519 nbde_client - feat: Allow initrd configuration to be skipped [rhel-8.10.z] Resolves: RHEL-58525 podman - fix: proper cleanup for networks; ensure cleanup of resources [rhel-8.10.z] Resolves: RHEL-58511 podman - fix: grab name of network to remove from quadlet file [rhel-8.10.z] Resolves: RHEL-58507 podman - Create podman secret when skip_existing=True and it does not exist [rhel-8.10.z] Resolves: RHEL-58503 podman - fix: do not use become for changing hostdir ownership, and expose subuid/subgid info [rhel-8.10.z] Resolves: RHEL-58498 podman - fix: use correct user for cancel linger file name [rhel-8.10.z] Resolves: RHEL-58460 podman - redhat.rhel_system_roles.podman fails to configure and run containers with podman rootless using different username and groupname. [rhel-8.10.z] Resolves: RHEL-58473 sshd - second SSHD service broken [rhel-8.10.z] Resolves: RHEL-58469 storage - rhel-system-role.storage is not idempotent [rhel-8.10.z] Resolves: RHEL-58489 timesync - System Roles: No module documentation [rhel-8.10.z] (cherry picked from commit 350d523452546e35bb0805af9ad9cc74712899d7)
215 lines
6.7 KiB
Diff
215 lines
6.7 KiB
Diff
From 07053a415b4a0bde557f28f6f607250915e908e6 Mon Sep 17 00:00:00 2001
|
|
From: Rich Megginson <rmeggins@redhat.com>
|
|
Date: Wed, 17 Apr 2024 11:35:52 -0600
|
|
Subject: [PATCH 106/115] fix: make kube cleanup idempotent
|
|
|
|
Cause: The task that calls podman_play was not checking if the kube yaml
|
|
file existed when cleaning up.
|
|
|
|
Consequence: The task would give an error that the pod could not be
|
|
removed.
|
|
|
|
Fix: Do not attempt to remove the pod if the kube yaml file does not
|
|
exist.
|
|
|
|
Result: Calling the podman role repeatedly to remove a kube spec
|
|
will not fail and will not report changes for subsequent removals.
|
|
|
|
QE: tests_basic.yml has been changed to check for this case
|
|
|
|
Signed-off-by: Rich Megginson <rmeggins@redhat.com>
|
|
(cherry picked from commit e506f39b6608613a5801190091a72b013b85a888)
|
|
---
|
|
tasks/cleanup_kube_spec.yml | 9 +++++-
|
|
tests/tests_basic.yml | 62 ++++++++++++++++++++++++++-----------
|
|
2 files changed, 52 insertions(+), 19 deletions(-)
|
|
|
|
diff --git a/tasks/cleanup_kube_spec.yml b/tasks/cleanup_kube_spec.yml
|
|
index c864179..b6b47bd 100644
|
|
--- a/tasks/cleanup_kube_spec.yml
|
|
+++ b/tasks/cleanup_kube_spec.yml
|
|
@@ -25,6 +25,11 @@
|
|
vars:
|
|
__service_error: Could not find the requested service
|
|
|
|
+- name: Check if kube file exists
|
|
+ stat:
|
|
+ path: "{{ __podman_kube_file }}"
|
|
+ register: __podman_kube_file_stat
|
|
+
|
|
- name: Remove pod/containers
|
|
containers.podman.podman_play: "{{ __podman_kube_spec |
|
|
combine({'kube_file': __podman_kube_file}) }}"
|
|
@@ -33,7 +38,9 @@
|
|
become: "{{ __podman_rootless | ternary(true, omit) }}"
|
|
become_user: "{{ __podman_rootless | ternary(__podman_user, omit) }}"
|
|
register: __podman_removed
|
|
- when: not __podman_rootless or __podman_xdg_stat.stat.exists
|
|
+ when:
|
|
+ - not __podman_rootless or __podman_xdg_stat.stat.exists
|
|
+ - __podman_kube_file_stat.stat.exists
|
|
|
|
- name: Remove kubernetes yaml file
|
|
file:
|
|
diff --git a/tests/tests_basic.yml b/tests/tests_basic.yml
|
|
index 121c3a7..b8ddc50 100644
|
|
--- a/tests/tests_basic.yml
|
|
+++ b/tests/tests_basic.yml
|
|
@@ -6,13 +6,16 @@
|
|
- vars/test_vars.yml
|
|
vars:
|
|
podman_host_directories:
|
|
- "/tmp/httpd1-create":
|
|
+ "{{ __test_tmpdir.path ~ '/httpd1-create' }}":
|
|
mode: "0777"
|
|
- owner: "{{ 1001 + podman_subuid_info['user1']['start'] - 1 }}"
|
|
- group: "{{ 1001 + podman_subgid_info['user1']['start'] - 1 }}"
|
|
+ owner: "{{ 1001 +
|
|
+ podman_subuid_info[__podman_test_username]['start'] - 1 }}"
|
|
+ group: "{{ 1001 +
|
|
+ podman_subgid_info[__podman_test_username]['start'] - 1 }}"
|
|
podman_run_as_user: root
|
|
+ __podman_test_username: podman_basic_user
|
|
test_names_users:
|
|
- - [httpd1, user1, 1001]
|
|
+ - [httpd1, "{{ __podman_test_username }}", 1001]
|
|
- [httpd2, root, 0]
|
|
- [httpd3, root, 0]
|
|
podman_create_host_directories: true
|
|
@@ -26,7 +29,7 @@
|
|
- state: started
|
|
debug: true
|
|
log_level: debug
|
|
- run_as_user: user1
|
|
+ run_as_user: "{{ __podman_test_username }}"
|
|
kube_file_content:
|
|
apiVersion: v1
|
|
kind: Pod
|
|
@@ -57,10 +60,10 @@
|
|
volumes:
|
|
- name: www
|
|
hostPath:
|
|
- path: /tmp/httpd1
|
|
+ path: "{{ __test_tmpdir.path ~ '/httpd1' }}"
|
|
- name: create
|
|
hostPath:
|
|
- path: /tmp/httpd1-create
|
|
+ path: "{{ __test_tmpdir.path ~ '/httpd1-create' }}"
|
|
- state: started
|
|
debug: true
|
|
log_level: debug
|
|
@@ -94,10 +97,10 @@
|
|
volumes:
|
|
- name: www
|
|
hostPath:
|
|
- path: /tmp/httpd2
|
|
+ path: "{{ __test_tmpdir.path ~ '/httpd2' }}"
|
|
- name: create
|
|
hostPath:
|
|
- path: /tmp/httpd2-create
|
|
+ path: "{{ __test_tmpdir.path ~ '/httpd2-create' }}"
|
|
__podman_kube_file_content: |
|
|
apiVersion: v1
|
|
kind: Pod
|
|
@@ -128,11 +131,23 @@
|
|
volumes:
|
|
- name: www
|
|
hostPath:
|
|
- path: /tmp/httpd3
|
|
+ path: "{{ __test_tmpdir.path ~ '/httpd3' }}"
|
|
- name: create
|
|
hostPath:
|
|
- path: /tmp/httpd3-create
|
|
+ path: "{{ __test_tmpdir.path ~ '/httpd3-create' }}"
|
|
tasks:
|
|
+ - name: Create tmpdir for testing
|
|
+ tempfile:
|
|
+ state: directory
|
|
+ prefix: lsr_
|
|
+ suffix: _podman
|
|
+ register: __test_tmpdir
|
|
+
|
|
+ - name: Change tmpdir permissions
|
|
+ file:
|
|
+ path: "{{ __test_tmpdir.path }}"
|
|
+ mode: "0777"
|
|
+
|
|
- name: Run basic tests
|
|
vars:
|
|
__podman_use_kube_file:
|
|
@@ -156,7 +171,7 @@
|
|
|
|
- name: Create user
|
|
user:
|
|
- name: user1
|
|
+ name: "{{ __podman_test_username }}"
|
|
uid: 1001
|
|
|
|
- name: Create tempfile for kube_src
|
|
@@ -171,12 +186,12 @@
|
|
copy:
|
|
content: "{{ __podman_kube_file_content }}"
|
|
dest: "{{ __kube_file_src.path }}"
|
|
- mode: 0600
|
|
+ mode: "0600"
|
|
delegate_to: localhost
|
|
|
|
- name: Create host directories for data
|
|
file:
|
|
- path: /tmp/{{ item[0] }}
|
|
+ path: "{{ __test_tmpdir.path ~ '/' ~ item[0] }}"
|
|
state: directory
|
|
mode: "0755"
|
|
owner: "{{ item[1] }}"
|
|
@@ -184,7 +199,7 @@
|
|
|
|
- name: Create data files
|
|
copy:
|
|
- dest: /tmp/{{ item[0] }}/index.txt
|
|
+ dest: "{{ __test_tmpdir.path ~ '/' ~ item[0] ~ '/index.txt' }}"
|
|
content: "123"
|
|
mode: "0644"
|
|
owner: "{{ item[1] }}"
|
|
@@ -315,7 +330,7 @@
|
|
loop: [15001, 15002]
|
|
|
|
- name: Check host directories
|
|
- command: ls -alrtF /tmp/{{ item[0] }}-create
|
|
+ command: ls -alrtF {{ __test_tmpdir.path ~ '/' ~ item[0] }}-create
|
|
loop: "{{ test_names_users }}"
|
|
changed_when: false
|
|
|
|
@@ -419,6 +434,18 @@
|
|
register: __stat
|
|
failed_when: __stat.stat.exists
|
|
|
|
+ - name: Remove pods and units again - test idempotence
|
|
+ include_role:
|
|
+ name: linux-system-roles.podman
|
|
+ vars:
|
|
+ # noqa jinja[spacing]
|
|
+ podman_kube_specs: "{{ __podman_kube_specs |
|
|
+ union([__podman_use_kube_file]) |
|
|
+ map('combine', {'state':'absent'}) | list }}"
|
|
+ podman_create_host_directories: false
|
|
+ podman_firewall: []
|
|
+ podman_selinux_ports: []
|
|
+
|
|
rescue:
|
|
- name: Dump journal
|
|
command: journalctl -ex
|
|
@@ -438,9 +465,8 @@
|
|
|
|
- name: Clean up host directories
|
|
file:
|
|
- path: /tmp/{{ item }}
|
|
+ path: "{{ __test_tmpdir.path }}"
|
|
state: absent
|
|
- loop: [httpd1, httpd2, httpd3]
|
|
tags:
|
|
- tests::cleanup
|
|
|
|
--
|
|
2.46.0
|
|
|