# STDOUT: ---v---v---v---v---v--- ansible-playbook 2.9.27 config file = /etc/ansible/ansible.cfg configured module search path = ['/home/jenkins/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules'] ansible python module location = /opt/ansible-2.9/lib/python3.9/site-packages/ansible executable location = /opt/ansible-2.9/bin/ansible-playbook python version = 3.9.18 (main, Sep 7 2023, 00:00:00) [GCC 11.4.1 20230605 (Red Hat 11.4.1-2)] Using /etc/ansible/ansible.cfg as config file Skipping callback 'actionable', as we already have a stdout callback. Skipping callback 'counter_enabled', as we already have a stdout callback. Skipping callback 'debug', as we already have a stdout callback. Skipping callback 'dense', as we already have a stdout callback. Skipping callback 'dense', as we already have a stdout callback. Skipping callback 'full_skip', as we already have a stdout callback. Skipping callback 'json', as we already have a stdout callback. Skipping callback 'minimal', as we already have a stdout callback. Skipping callback 'null', as we already have a stdout callback. Skipping callback 'oneline', as we already have a stdout callback. Skipping callback 'selective', as we already have a stdout callback. Skipping callback 'skippy', as we already have a stdout callback. Skipping callback 'stderr', as we already have a stdout callback. Skipping callback 'unixy', as we already have a stdout callback. Skipping callback 'yaml', as we already have a stdout callback. PLAYBOOK: tests_default.yml **************************************************** 1 plays in /WORKDIR/git-support_transactional_updaterzq837i_/tests/tests_default.yml PLAY [Ensure that the role runs with default parameters] *********************** META: ran handlers TASK [linux-system-roles.crypto_policies : Set platform/version specific variables] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:3 Monday 29 July 2024 18:54:59 +0000 (0:00:00.020) 0:00:00.020 *********** included: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml for sut TASK [linux-system-roles.crypto_policies : Ensure ansible_facts used by role] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml:2 Monday 29 July 2024 18:54:59 +0000 (0:00:00.014) 0:00:00.035 *********** ok: [sut] TASK [linux-system-roles.crypto_policies : Check if system is ostree] ********** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml:11 Monday 29 July 2024 18:54:59 +0000 (0:00:00.529) 0:00:00.564 *********** ok: [sut] => { "changed": false, "stat": { "exists": false } } TASK [linux-system-roles.crypto_policies : Set flag to indicate system is ostree] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml:16 Monday 29 July 2024 18:55:00 +0000 (0:00:00.257) 0:00:00.822 *********** ok: [sut] => { "ansible_facts": { "__crypto_policies_is_ostree": false }, "changed": false } TASK [linux-system-roles.crypto_policies : Check if transactional-update exists in /sbin] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml:23 Monday 29 July 2024 18:55:00 +0000 (0:00:00.020) 0:00:00.843 *********** ok: [sut] => { "changed": false, "stat": { "exists": false } } TASK [linux-system-roles.crypto_policies : Set flag if transactional-update exists] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml:28 Monday 29 July 2024 18:55:00 +0000 (0:00:00.189) 0:00:01.032 *********** ok: [sut] => { "ansible_facts": { "__crypto_policies_is_transactional": false }, "changed": false } TASK [linux-system-roles.crypto_policies : Set platform/version specific variables] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml:32 Monday 29 July 2024 18:55:00 +0000 (0:00:00.020) 0:00:01.053 *********** skipping: [sut] => (item=RedHat.yml) => { "ansible_loop_var": "item", "changed": false, "item": "RedHat.yml", "skip_reason": "Conditional result was False" } skipping: [sut] => (item=CentOS.yml) => { "ansible_loop_var": "item", "changed": false, "item": "CentOS.yml", "skip_reason": "Conditional result was False" } skipping: [sut] => (item=CentOS_8.yml) => { "ansible_loop_var": "item", "changed": false, "item": "CentOS_8.yml", "skip_reason": "Conditional result was False" } skipping: [sut] => (item=CentOS_8.yml) => { "ansible_loop_var": "item", "changed": false, "item": "CentOS_8.yml", "skip_reason": "Conditional result was False" } TASK [linux-system-roles.crypto_policies : Ensure required packages are installed] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:6 Monday 29 July 2024 18:55:00 +0000 (0:00:00.029) 0:00:01.082 *********** ok: [sut] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do TASK [linux-system-roles.crypto_policies : Notify user that reboot is needed to apply changes] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:19 Monday 29 July 2024 18:55:03 +0000 (0:00:02.915) 0:00:03.998 *********** skipping: [sut] => {} TASK [linux-system-roles.crypto_policies : Reboot transactional update systems] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:24 Monday 29 July 2024 18:55:03 +0000 (0:00:00.018) 0:00:04.017 *********** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.crypto_policies : Fail if reboot is needed and not set] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:29 Monday 29 July 2024 18:55:03 +0000 (0:00:00.018) 0:00:04.035 *********** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.crypto_policies : Gather facts] *********************** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:37 Monday 29 July 2024 18:55:03 +0000 (0:00:00.018) 0:00:04.053 *********** included: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/gather_facts.yml for sut TASK [linux-system-roles.crypto_policies : Find out what is the currently active policy] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/gather_facts.yml:3 Monday 29 July 2024 18:55:03 +0000 (0:00:00.009) 0:00:04.062 *********** ok: [sut] => { "changed": false, "cmd": [ "update-crypto-policies", "--show" ], "delta": "0:00:00.072616", "end": "2024-07-29 18:55:03.615075", "rc": 0, "start": "2024-07-29 18:55:03.542459" } STDOUT: DEFAULT TASK [linux-system-roles.crypto_policies : Set current policy fact] ************ task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/gather_facts.yml:9 Monday 29 July 2024 18:55:03 +0000 (0:00:00.329) 0:00:04.392 *********** ok: [sut] => { "ansible_facts": { "crypto_policies_active": "DEFAULT" }, "changed": false } TASK [linux-system-roles.crypto_policies : Find base policies files] *********** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:40 Monday 29 July 2024 18:55:03 +0000 (0:00:00.020) 0:00:04.412 *********** ok: [sut] => { "changed": false, "examined": 7, "files": [ { "atime": 1716968748.851, "ctime": 1716968718.641, "dev": 51713, "gid": 0, "gr_name": "root", "inode": 4047304, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1690903086.0, "nlink": 1, "path": "/usr/share/crypto-policies/policies/DEFAULT.pol", "pw_name": "root", "rgrp": true, "roth": true, "rusr": true, "size": 2153, "uid": 0, "wgrp": false, "woth": false, "wusr": true, "xgrp": false, "xoth": false, "xusr": false }, { "atime": 1690903086.0, "ctime": 1716968718.641, "dev": 51713, "gid": 0, "gr_name": "root", "inode": 4047305, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1690903086.0, "nlink": 1, "path": "/usr/share/crypto-policies/policies/EMPTY.pol", "pw_name": "root", "rgrp": true, "roth": true, "rusr": true, "size": 267, "uid": 0, "wgrp": false, "woth": false, "wusr": true, "xgrp": false, "xoth": false, "xusr": false }, { "atime": 1690903086.0, "ctime": 1716968718.641, "dev": 51713, "gid": 0, "gr_name": "root", "inode": 4047306, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1690903086.0, "nlink": 1, "path": "/usr/share/crypto-policies/policies/FIPS.pol", "pw_name": "root", "rgrp": true, "roth": true, "rusr": true, "size": 1726, "uid": 0, "wgrp": false, "woth": false, "wusr": true, "xgrp": false, "xoth": false, "xusr": false }, { "atime": 1690903086.0, "ctime": 1716968718.641, "dev": 51713, "gid": 0, "gr_name": "root", "inode": 4047307, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1690903086.0, "nlink": 1, "path": "/usr/share/crypto-policies/policies/FUTURE.pol", "pw_name": "root", "rgrp": true, "roth": true, "rusr": true, "size": 2102, "uid": 0, "wgrp": false, "woth": false, "wusr": true, "xgrp": false, "xoth": false, "xusr": false }, { "atime": 1690903086.0, "ctime": 1716968718.641, "dev": 51713, "gid": 0, "gr_name": "root", "inode": 4047308, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1690903086.0, "nlink": 1, "path": "/usr/share/crypto-policies/policies/LEGACY.pol", "pw_name": "root", "rgrp": true, "roth": true, "rusr": true, "size": 2471, "uid": 0, "wgrp": false, "woth": false, "wusr": true, "xgrp": false, "xoth": false, "xusr": false } ], "matched": 5 } TASK [linux-system-roles.crypto_policies : Set available base policies fact] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:48 Monday 29 July 2024 18:55:03 +0000 (0:00:00.257) 0:00:04.669 *********** ok: [sut] => { "ansible_facts": { "crypto_policies_available_policies": [ "FUTURE", "FIPS", "DEFAULT", "EMPTY", "LEGACY" ] }, "changed": false } TASK [linux-system-roles.crypto_policies : Find subpolicy files] *************** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:55 Monday 29 July 2024 18:55:03 +0000 (0:00:00.018) 0:00:04.688 *********** ok: [sut] => { "changed": false, "examined": 5, "files": [ { "atime": 1690903086.0, "ctime": 1716968718.641, "dev": 51713, "gid": 0, "gr_name": "root", "inode": 4695037, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1690903086.0, "nlink": 1, "path": "/usr/share/crypto-policies/policies/modules/AD-SUPPORT.pmod", "pw_name": "root", "rgrp": true, "roth": true, "rusr": true, "size": 322, "uid": 0, "wgrp": false, "woth": false, "wusr": true, "xgrp": false, "xoth": false, "xusr": false }, { "atime": 1690903086.0, "ctime": 1716968718.641, "dev": 51713, "gid": 0, "gr_name": "root", "inode": 4695038, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1690903086.0, "nlink": 1, "path": "/usr/share/crypto-policies/policies/modules/ECDHE-ONLY.pmod", "pw_name": "root", "rgrp": true, "roth": true, "rusr": true, "size": 121, "uid": 0, "wgrp": false, "woth": false, "wusr": true, "xgrp": false, "xoth": false, "xusr": false }, { "atime": 1690903086.0, "ctime": 1716968718.641, "dev": 51713, "gid": 0, "gr_name": "root", "inode": 4695039, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1690903086.0, "nlink": 1, "path": "/usr/share/crypto-policies/policies/modules/NO-CAMELLIA.pmod", "pw_name": "root", "rgrp": true, "roth": true, "rusr": true, "size": 90, "uid": 0, "wgrp": false, "woth": false, "wusr": true, "xgrp": false, "xoth": false, "xusr": false }, { "atime": 1690903086.0, "ctime": 1716968718.641, "dev": 51713, "gid": 0, "gr_name": "root", "inode": 4695104, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1690903086.0, "nlink": 1, "path": "/usr/share/crypto-policies/policies/modules/NO-SHA1.pmod", "pw_name": "root", "rgrp": true, "roth": true, "rusr": true, "size": 123, "uid": 0, "wgrp": false, "woth": false, "wusr": true, "xgrp": false, "xoth": false, "xusr": false }, { "atime": 1690903086.0, "ctime": 1716968718.641, "dev": 51713, "gid": 0, "gr_name": "root", "inode": 4695105, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1690903086.0, "nlink": 1, "path": "/usr/share/crypto-policies/policies/modules/OSPP.pmod", "pw_name": "root", "rgrp": true, "roth": true, "rusr": true, "size": 1986, "uid": 0, "wgrp": false, "woth": false, "wusr": true, "xgrp": false, "xoth": false, "xusr": false } ], "matched": 5 } TASK [linux-system-roles.crypto_policies : Set available subpolicies fact] ***** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:63 Monday 29 July 2024 18:55:04 +0000 (0:00:00.185) 0:00:04.874 *********** ok: [sut] => { "ansible_facts": { "crypto_policies_available_subpolicies": [ "OSPP", "NO-CAMELLIA", "ECDHE-ONLY", "AD-SUPPORT", "NO-SHA1" ] }, "changed": false } TASK [linux-system-roles.crypto_policies : Set crypto_policies_available_modules fact (deprecated)] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:70 Monday 29 July 2024 18:55:04 +0000 (0:00:00.019) 0:00:04.893 *********** ok: [sut] => { "ansible_facts": { "crypto_policies_available_modules": [ "OSPP", "NO-CAMELLIA", "ECDHE-ONLY", "AD-SUPPORT", "NO-SHA1" ] }, "changed": false } TASK [linux-system-roles.crypto_policies : Update crypto policy if needed] ***** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:76 Monday 29 July 2024 18:55:04 +0000 (0:00:00.017) 0:00:04.911 *********** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.crypto_policies : Set the reboot_required flag if needed] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:88 Monday 29 July 2024 18:55:04 +0000 (0:00:00.016) 0:00:04.928 *********** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.crypto_policies : Update facts after applying policy] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:96 Monday 29 July 2024 18:55:04 +0000 (0:00:00.018) 0:00:04.947 *********** included: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/gather_facts.yml for sut TASK [linux-system-roles.crypto_policies : Find out what is the currently active policy] *** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/gather_facts.yml:3 Monday 29 July 2024 18:55:04 +0000 (0:00:00.008) 0:00:04.956 *********** ok: [sut] => { "changed": false, "cmd": [ "update-crypto-policies", "--show" ], "delta": "0:00:00.056373", "end": "2024-07-29 18:55:04.415322", "rc": 0, "start": "2024-07-29 18:55:04.358949" } STDOUT: DEFAULT TASK [linux-system-roles.crypto_policies : Set current policy fact] ************ task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/gather_facts.yml:9 Monday 29 July 2024 18:55:04 +0000 (0:00:00.236) 0:00:05.192 *********** ok: [sut] => { "ansible_facts": { "crypto_policies_active": "DEFAULT" }, "changed": false } META: ran handlers TASK [Check the current policy is DEFAULT and common variables] **************** task path: /WORKDIR/git-support_transactional_updaterzq837i_/tests/tests_default.yml:14 Monday 29 July 2024 18:55:04 +0000 (0:00:00.019) 0:00:05.212 *********** ok: [sut] => { "changed": false } MSG: All assertions passed META: ran handlers META: ran handlers PLAY RECAP ********************************************************************* sut : ok=19 changed=0 unreachable=0 failed=0 skipped=6 rescued=0 ignored=0 Monday 29 July 2024 18:55:04 +0000 (0:00:00.021) 0:00:05.234 *********** =============================================================================== linux-system-roles.crypto_policies : Ensure required packages are installed --- 2.92s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:6 linux-system-roles.crypto_policies : Ensure ansible_facts used by role --- 0.53s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml:2 linux-system-roles.crypto_policies : Find out what is the currently active policy --- 0.33s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/gather_facts.yml:3 linux-system-roles.crypto_policies : Check if system is ostree ---------- 0.26s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml:11 linux-system-roles.crypto_policies : Find base policies files ----------- 0.26s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:40 linux-system-roles.crypto_policies : Find out what is the currently active policy --- 0.24s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/gather_facts.yml:3 linux-system-roles.crypto_policies : Check if transactional-update exists in /sbin --- 0.19s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml:23 linux-system-roles.crypto_policies : Find subpolicy files --------------- 0.19s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:55 linux-system-roles.crypto_policies : Set platform/version specific variables --- 0.03s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml:32 Check the current policy is DEFAULT and common variables ---------------- 0.02s /WORKDIR/git-support_transactional_updaterzq837i_/tests/tests_default.yml:14 -- linux-system-roles.crypto_policies : Set flag if transactional-update exists --- 0.02s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml:28 linux-system-roles.crypto_policies : Set flag to indicate system is ostree --- 0.02s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/set_vars.yml:16 linux-system-roles.crypto_policies : Set current policy fact ------------ 0.02s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/gather_facts.yml:9 linux-system-roles.crypto_policies : Set current policy fact ------------ 0.02s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/gather_facts.yml:9 linux-system-roles.crypto_policies : Set available subpolicies fact ----- 0.02s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:63 linux-system-roles.crypto_policies : Set the reboot_required flag if needed --- 0.02s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:88 linux-system-roles.crypto_policies : Set available base policies fact --- 0.02s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:48 linux-system-roles.crypto_policies : Notify user that reboot is needed to apply changes --- 0.02s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:19 linux-system-roles.crypto_policies : Reboot transactional update systems --- 0.02s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:24 linux-system-roles.crypto_policies : Fail if reboot is needed and not set --- 0.02s /WORKDIR/git-support_transactional_updaterzq837i_/tests/roles/linux-system-roles.crypto_policies/tasks/main.yml:29 ---^---^---^---^---^--- # STDERR: ---v---v---v---v---v--- ---^---^---^---^---^---