ansible-playbook [core 2.17.5] config file = None configured module search path = ['/root/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules'] ansible python module location = /usr/local/lib/python3.12/site-packages/ansible ansible collection location = /tmp/collections-W2w executable location = /usr/local/bin/ansible-playbook python version = 3.12.6 (main, Sep 9 2024, 00:00:00) [GCC 14.2.1 20240801 (Red Hat 14.2.1-1)] (/usr/bin/python3.12) jinja version = 3.1.4 libyaml = True No config file found; using defaults running playbook inside collection fedora.linux_system_roles redirecting (type: callback) ansible.builtin.debug to ansible.posix.debug redirecting (type: callback) ansible.builtin.debug to ansible.posix.debug redirecting (type: callback) ansible.builtin.profile_tasks to ansible.posix.profile_tasks Skipping callback 'default', as we already have a stdout callback. Skipping callback 'minimal', as we already have a stdout callback. Skipping callback 'oneline', as we already have a stdout callback. PLAYBOOK: tests_default.yml **************************************************** 1 plays in /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/tests/ha_cluster/tests_default.yml PLAY [Ensure mandatory variables are defined] ********************************** TASK [Set up test environment] ************************************************* task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/tests/ha_cluster/tests_default.yml:10 Tuesday 15 October 2024 15:07:15 -0400 (0:00:00.020) 0:00:00.020 ******* included: fedora.linux_system_roles.ha_cluster for managed-node2 TASK [fedora.linux_system_roles.ha_cluster : Set node name to 'localhost' for single-node clusters] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/test_setup.yml:9 Tuesday 15 October 2024 15:07:15 -0400 (0:00:00.022) 0:00:00.042 ******* ok: [managed-node2] => { "ansible_facts": { "inventory_hostname": "localhost" }, "changed": false } TASK [fedora.linux_system_roles.ha_cluster : Ensure facts used by tests] ******* task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/test_setup.yml:14 Tuesday 15 October 2024 15:07:15 -0400 (0:00:00.063) 0:00:00.106 ******* [WARNING]: Platform linux on host localhost is using the discovered Python interpreter at /usr/bin/python3.12, but future installation of another Python interpreter could change the meaning of that path. See https://docs.ansible.com/ansible- core/2.17/reference_appendices/interpreter_discovery.html for more information. ok: [managed-node2] TASK [fedora.linux_system_roles.ha_cluster : Check if system is ostree] ******** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/test_setup.yml:22 Tuesday 15 October 2024 15:07:16 -0400 (0:00:00.883) 0:00:00.989 ******* ok: [managed-node2] => { "changed": false, "stat": { "exists": false } } TASK [fedora.linux_system_roles.ha_cluster : Set flag to indicate system is ostree] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/test_setup.yml:27 Tuesday 15 October 2024 15:07:16 -0400 (0:00:00.433) 0:00:01.422 ******* ok: [managed-node2] => { "ansible_facts": { "__ha_cluster_is_ostree": false }, "changed": false } TASK [fedora.linux_system_roles.ha_cluster : Do not try to enable RHEL repositories] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/test_setup.yml:32 Tuesday 15 October 2024 15:07:16 -0400 (0:00:00.039) 0:00:01.462 ******* skipping: [managed-node2] => { "changed": false, "false_condition": "ansible_distribution == 'RedHat'", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ha_cluster : Copy nss-altfiles ha_cluster users to /etc/passwd] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/test_setup.yml:41 Tuesday 15 October 2024 15:07:16 -0400 (0:00:00.049) 0:00:01.511 ******* skipping: [managed-node2] => { "changed": false, "false_condition": "__ha_cluster_is_ostree | d(false)", "skip_reason": "Conditional result was False" } TASK [Run the role] ************************************************************ task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/tests/ha_cluster/tests_default.yml:15 Tuesday 15 October 2024 15:07:16 -0400 (0:00:00.030) 0:00:01.542 ******* included: fedora.linux_system_roles.ha_cluster for managed-node2 TASK [fedora.linux_system_roles.ha_cluster : Set platform/version specific variables] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/main.yml:3 Tuesday 15 October 2024 15:07:16 -0400 (0:00:00.034) 0:00:01.576 ******* included: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/set_vars.yml for managed-node2 TASK [fedora.linux_system_roles.ha_cluster : Ensure ansible_facts used by role] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/set_vars.yml:2 Tuesday 15 October 2024 15:07:16 -0400 (0:00:00.019) 0:00:01.596 ******* skipping: [managed-node2] => { "changed": false, "false_condition": "__ha_cluster_required_facts | difference(ansible_facts.keys() | list) | length > 0", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ha_cluster : Check if system is ostree] ******** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/set_vars.yml:10 Tuesday 15 October 2024 15:07:16 -0400 (0:00:00.051) 0:00:01.648 ******* skipping: [managed-node2] => { "changed": false, "false_condition": "not __ha_cluster_is_ostree is defined", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ha_cluster : Set flag to indicate system is ostree] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/set_vars.yml:15 Tuesday 15 October 2024 15:07:16 -0400 (0:00:00.027) 0:00:01.675 ******* skipping: [managed-node2] => { "changed": false, "false_condition": "not __ha_cluster_is_ostree is defined", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ha_cluster : Set platform/version specific variables] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/set_vars.yml:19 Tuesday 15 October 2024 15:07:16 -0400 (0:00:00.027) 0:00:01.703 ******* ok: [managed-node2] => (item=RedHat.yml) => { "ansible_facts": { "__ha_cluster_cloud_agents_packages": [], "__ha_cluster_fence_agent_packages_default": "{{ ['fence-agents-all'] + (['fence-virt'] if ansible_architecture == 'x86_64' else []) }}", "__ha_cluster_fullstack_node_packages": [ "corosync", "libknet1-plugins-all", "resource-agents", "pacemaker" ], "__ha_cluster_pcs_provider": "pcs-0.10", "__ha_cluster_qdevice_node_packages": [ "corosync-qdevice", "bash", "coreutils", "curl", "grep", "nss-tools", "openssl", "sed" ], "__ha_cluster_repos": [], "__ha_cluster_role_essential_packages": [ "pcs", "corosync-qnetd", "openssl" ], "__ha_cluster_sbd_packages": [ "sbd" ], "__ha_cluster_services": [ "corosync", "corosync-qdevice", "pacemaker" ] }, "ansible_included_var_files": [ "/tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/vars/RedHat.yml" ], "ansible_loop_var": "item", "changed": false, "item": "RedHat.yml" } skipping: [managed-node2] => (item=CentOS.yml) => { "ansible_loop_var": "item", "changed": false, "false_condition": "__vars_file is file", "item": "CentOS.yml", "skip_reason": "Conditional result was False" } ok: [managed-node2] => (item=CentOS_10.yml) => { "ansible_facts": { "__ha_cluster_cloud_agents_packages": [ "resource-agents-cloud", "fence-agents-aliyun", "fence-agents-aws", "fence-agents-azure-arm", "fence-agents-compute", "fence-agents-gce", "fence-agents-ibm-powervs", "fence-agents-ibm-vpc", "fence-agents-kubevirt", "fence-agents-openstack" ], "__ha_cluster_repos": [ { "id": "highavailability", "name": "HighAvailability" }, { "id": "resilientstorage", "name": "ResilientStorage" } ] }, "ansible_included_var_files": [ "/tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/vars/CentOS_10.yml" ], "ansible_loop_var": "item", "changed": false, "item": "CentOS_10.yml" } ok: [managed-node2] => (item=CentOS_10.yml) => { "ansible_facts": { "__ha_cluster_cloud_agents_packages": [ "resource-agents-cloud", "fence-agents-aliyun", "fence-agents-aws", "fence-agents-azure-arm", "fence-agents-compute", "fence-agents-gce", "fence-agents-ibm-powervs", "fence-agents-ibm-vpc", "fence-agents-kubevirt", "fence-agents-openstack" ], "__ha_cluster_repos": [ { "id": "highavailability", "name": "HighAvailability" }, { "id": "resilientstorage", "name": "ResilientStorage" } ] }, "ansible_included_var_files": [ "/tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/vars/CentOS_10.yml" ], "ansible_loop_var": "item", "changed": false, "item": "CentOS_10.yml" } TASK [fedora.linux_system_roles.ha_cluster : Set Linux Pacemaker shell specific variables] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/set_vars.yml:34 Tuesday 15 October 2024 15:07:16 -0400 (0:00:00.068) 0:00:01.771 ******* ok: [managed-node2] => { "ansible_facts": {}, "ansible_included_var_files": [ "/tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/vars/shell_pcs.yml" ], "changed": false } TASK [fedora.linux_system_roles.ha_cluster : Enable package repositories] ****** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/main.yml:6 Tuesday 15 October 2024 15:07:17 -0400 (0:00:00.026) 0:00:01.798 ******* included: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/enable-package-repositories.yml for managed-node2 TASK [fedora.linux_system_roles.ha_cluster : Find platform/version specific tasks to enable repositories] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/enable-package-repositories.yml:3 Tuesday 15 October 2024 15:07:17 -0400 (0:00:00.033) 0:00:01.832 ******* ok: [managed-node2] => (item=RedHat.yml) => { "ansible_facts": { "__ha_cluster_enable_repo_tasks_file": "/tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/enable-repositories/RedHat.yml" }, "ansible_loop_var": "item", "changed": false, "item": "RedHat.yml" } ok: [managed-node2] => (item=CentOS.yml) => { "ansible_facts": { "__ha_cluster_enable_repo_tasks_file": "/tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/enable-repositories/CentOS.yml" }, "ansible_loop_var": "item", "changed": false, "item": "CentOS.yml" } skipping: [managed-node2] => (item=CentOS_10.yml) => { "ansible_loop_var": "item", "changed": false, "false_condition": "__ha_cluster_enable_repo_tasks_file_candidate is file", "item": "CentOS_10.yml", "skip_reason": "Conditional result was False" } skipping: [managed-node2] => (item=CentOS_10.yml) => { "ansible_loop_var": "item", "changed": false, "false_condition": "__ha_cluster_enable_repo_tasks_file_candidate is file", "item": "CentOS_10.yml", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ha_cluster : Run platform/version specific tasks to enable repositories] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/enable-package-repositories.yml:21 Tuesday 15 October 2024 15:07:17 -0400 (0:00:00.062) 0:00:01.896 ******* included: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/enable-repositories/CentOS.yml for managed-node2 TASK [fedora.linux_system_roles.ha_cluster : List active CentOS repositories] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/enable-repositories/CentOS.yml:3 Tuesday 15 October 2024 15:07:17 -0400 (0:00:00.064) 0:00:01.961 ******* ok: [managed-node2] => { "changed": false, "cmd": [ "dnf", "repolist" ], "delta": "0:00:00.187110", "end": "2024-10-15 15:07:17.867256", "rc": 0, "start": "2024-10-15 15:07:17.680146" } STDOUT: repo id repo name appstream CentOS Stream 10 - AppStream baseos CentOS Stream 10 - BaseOS beaker-client Beaker Client - RedHatEnterpriseLinux9 beaker-harness Beaker harness beakerlib-libraries Copr repo for beakerlib-libraries owned by bgoncalv highavailability CentOS Stream 10 - HighAvailability TASK [fedora.linux_system_roles.ha_cluster : Enable CentOS repositories] ******* task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/enable-repositories/CentOS.yml:10 Tuesday 15 October 2024 15:07:17 -0400 (0:00:00.727) 0:00:02.689 ******* skipping: [managed-node2] => (item={'id': 'highavailability', 'name': 'HighAvailability'}) => { "ansible_loop_var": "item", "changed": false, "false_condition": "item.id not in __ha_cluster_repolist.stdout", "item": { "id": "highavailability", "name": "HighAvailability" }, "skip_reason": "Conditional result was False" } skipping: [managed-node2] => (item={'id': 'resilientstorage', 'name': 'ResilientStorage'}) => { "ansible_loop_var": "item", "changed": false, "false_condition": "item.name != \"ResilientStorage\" or ha_cluster_enable_repos_resilient_storage", "item": { "id": "resilientstorage", "name": "ResilientStorage" }, "skip_reason": "Conditional result was False" } skipping: [managed-node2] => { "changed": false } MSG: All items skipped TASK [fedora.linux_system_roles.ha_cluster : Install role essential packages] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/main.yml:11 Tuesday 15 October 2024 15:07:17 -0400 (0:00:00.024) 0:00:02.713 ******* ok: [managed-node2] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do TASK [fedora.linux_system_roles.ha_cluster : Check and prepare role variables] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/main.yml:17 Tuesday 15 October 2024 15:07:18 -0400 (0:00:00.782) 0:00:03.496 ******* included: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/shell_pcs/check-and-prepare-role-variables.yml for managed-node2 TASK [fedora.linux_system_roles.ha_cluster : Discover cluster node names] ****** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/shell_pcs/check-and-prepare-role-variables.yml:3 Tuesday 15 October 2024 15:07:18 -0400 (0:00:00.039) 0:00:03.535 ******* ok: [managed-node2] => { "ansible_facts": { "__ha_cluster_node_name": "localhost" }, "changed": false } TASK [fedora.linux_system_roles.ha_cluster : Collect cluster node names] ******* task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/shell_pcs/check-and-prepare-role-variables.yml:7 Tuesday 15 October 2024 15:07:18 -0400 (0:00:00.037) 0:00:03.572 ******* ok: [managed-node2] => { "ansible_facts": { "__ha_cluster_all_node_names": [ "localhost" ] }, "changed": false } TASK [fedora.linux_system_roles.ha_cluster : Fail if ha_cluster_node_options contains unknown or duplicate nodes] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/shell_pcs/check-and-prepare-role-variables.yml:16 Tuesday 15 October 2024 15:07:18 -0400 (0:00:00.041) 0:00:03.614 ******* skipping: [managed-node2] => { "changed": false, "false_condition": "(\n __nodes_from_options != (__nodes_from_options | unique)\n) or (\n __nodes_from_options | difference(__ha_cluster_all_node_names)\n)\n", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ha_cluster : Extract node options] ************* task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/shell_pcs/check-and-prepare-role-variables.yml:30 Tuesday 15 October 2024 15:07:18 -0400 (0:00:00.036) 0:00:03.650 ******* ok: [managed-node2] => { "ansible_facts": { "__ha_cluster_local_node": {} }, "changed": false } TASK [fedora.linux_system_roles.ha_cluster : Fail if passwords are not specified] *** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/shell_pcs/check-and-prepare-role-variables.yml:43 Tuesday 15 October 2024 15:07:18 -0400 (0:00:00.036) 0:00:03.687 ******* failed: [managed-node2] (item=ha_cluster_hacluster_password) => { "ansible_loop_var": "item", "changed": false, "item": "ha_cluster_hacluster_password" } MSG: ha_cluster_hacluster_password must be specified TASK [Extract errors] ********************************************************** task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/tests/ha_cluster/tests_default.yml:19 Tuesday 15 October 2024 15:07:18 -0400 (0:00:00.040) 0:00:03.727 ******* ok: [managed-node2] => { "ansible_facts": { "error_list": [ "ha_cluster_hacluster_password must be specified" ] }, "changed": false } TASK [Check errors] ************************************************************ task path: /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/tests/ha_cluster/tests_default.yml:24 Tuesday 15 October 2024 15:07:18 -0400 (0:00:00.033) 0:00:03.760 ******* ok: [managed-node2] => { "changed": false } MSG: All assertions passed PLAY RECAP ********************************************************************* managed-node2 : ok=20 changed=0 unreachable=0 failed=0 skipped=7 rescued=1 ignored=0 Tuesday 15 October 2024 15:07:19 -0400 (0:00:00.019) 0:00:03.780 ******* =============================================================================== fedora.linux_system_roles.ha_cluster : Ensure facts used by tests ------- 0.88s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/test_setup.yml:14 fedora.linux_system_roles.ha_cluster : Install role essential packages --- 0.78s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/main.yml:11 fedora.linux_system_roles.ha_cluster : List active CentOS repositories --- 0.73s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/enable-repositories/CentOS.yml:3 fedora.linux_system_roles.ha_cluster : Check if system is ostree -------- 0.43s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/test_setup.yml:22 fedora.linux_system_roles.ha_cluster : Set platform/version specific variables --- 0.07s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/set_vars.yml:19 fedora.linux_system_roles.ha_cluster : Run platform/version specific tasks to enable repositories --- 0.06s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/enable-package-repositories.yml:21 fedora.linux_system_roles.ha_cluster : Find platform/version specific tasks to enable repositories --- 0.06s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/enable-package-repositories.yml:3 fedora.linux_system_roles.ha_cluster : Set node name to 'localhost' for single-node clusters --- 0.06s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/test_setup.yml:9 fedora.linux_system_roles.ha_cluster : Ensure ansible_facts used by role --- 0.05s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/set_vars.yml:2 fedora.linux_system_roles.ha_cluster : Do not try to enable RHEL repositories --- 0.05s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/test_setup.yml:32 fedora.linux_system_roles.ha_cluster : Collect cluster node names ------- 0.04s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/shell_pcs/check-and-prepare-role-variables.yml:7 fedora.linux_system_roles.ha_cluster : Fail if passwords are not specified --- 0.04s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/shell_pcs/check-and-prepare-role-variables.yml:43 fedora.linux_system_roles.ha_cluster : Set flag to indicate system is ostree --- 0.04s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/test_setup.yml:27 fedora.linux_system_roles.ha_cluster : Check and prepare role variables --- 0.04s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/main.yml:17 fedora.linux_system_roles.ha_cluster : Discover cluster node names ------ 0.04s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/shell_pcs/check-and-prepare-role-variables.yml:3 fedora.linux_system_roles.ha_cluster : Extract node options ------------- 0.04s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/shell_pcs/check-and-prepare-role-variables.yml:30 fedora.linux_system_roles.ha_cluster : Fail if ha_cluster_node_options contains unknown or duplicate nodes --- 0.04s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/shell_pcs/check-and-prepare-role-variables.yml:16 Run the role ------------------------------------------------------------ 0.03s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/tests/ha_cluster/tests_default.yml:15 fedora.linux_system_roles.ha_cluster : Enable package repositories ------ 0.03s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/roles/ha_cluster/tasks/main.yml:6 Extract errors ---------------------------------------------------------- 0.03s /tmp/collections-W2w/ansible_collections/fedora/linux_system_roles/tests/ha_cluster/tests_default.yml:19