# 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_nm.yml ************************************************* 2 plays in /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tests_default_nm.yml PLAY [Run playbook 'tests_default.yml' with nm as provider] ******************** TASK [Gathering Facts] ********************************************************* task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tests_default_nm.yml:3 Wednesday 14 February 2024 17:05:43 +0000 (0:00:00.012) 0:00:00.012 **** ok: [sut] META: ran handlers TASK [Include the task 'el_repo_setup.yml'] ************************************ task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tests_default_nm.yml:6 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.713) 0:00:00.725 **** included: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml for sut TASK [Gather the minimum subset of ansible_facts required by the network role test] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:3 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.011) 0:00:00.737 **** ok: [sut] TASK [Check if system is ostree] *********************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:19 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.354) 0:00:01.092 **** ok: [sut] => { "changed": false, "stat": { "exists": false } } TASK [Set flag to indicate system is ostree] *********************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:24 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.271) 0:00:01.363 **** ok: [sut] => { "ansible_facts": { "__network_is_ostree": false }, "changed": false } TASK [Fix CentOS6 Base repo] *************************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:28 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.060) 0:00:01.423 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Include the task 'enable_epel.yml'] ************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:53 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.020) 0:00:01.444 **** included: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml for sut TASK [Create EPEL 9] *********************************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml:8 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.033) 0:00:01.477 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Install yum-utils package] *********************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml:24 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.011) 0:00:01.489 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 7] *********************************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml:30 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.011) 0:00:01.500 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 8] *********************************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml:35 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.010) 0:00:01.511 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 6] *********************************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml:40 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.011) 0:00:01.523 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Set network provider to 'nm'] ******************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tests_default_nm.yml:8 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.011) 0:00:01.534 **** ok: [sut] => { "ansible_facts": { "network_provider": "nm" }, "changed": false } META: ran handlers META: ran handlers PLAY [Test executing the role with default parameters] ************************* META: ran handlers TASK [linux-system-roles.network : Ensure ansible_facts used by role] ********** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:4 Wednesday 14 February 2024 17:05:44 +0000 (0:00:00.012) 0:00:01.546 **** included: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/set_facts.yml for sut TASK [linux-system-roles.network : Ensure ansible_facts used by role are present] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/set_facts.yml:3 Wednesday 14 February 2024 17:05:45 +0000 (0:00:00.066) 0:00:01.613 **** skipping: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Check if system is ostree] ****************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/set_facts.yml:13 Wednesday 14 February 2024 17:05:45 +0000 (0:00:00.013) 0:00:01.626 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Set flag to indicate system is ostree] ****** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/set_facts.yml:18 Wednesday 14 February 2024 17:05:45 +0000 (0:00:00.011) 0:00:01.638 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Check which services are running] *********** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/set_facts.yml:22 Wednesday 14 February 2024 17:05:45 +0000 (0:00:00.011) 0:00:01.649 **** ok: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Check which packages are installed] ********* task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/set_facts.yml:27 Wednesday 14 February 2024 17:05:46 +0000 (0:00:01.515) 0:00:03.165 **** ok: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Print network provider] ********************* task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:7 Wednesday 14 February 2024 17:05:47 +0000 (0:00:01.098) 0:00:04.263 **** ok: [sut] => {} MSG: Using network provider: nm TASK [linux-system-roles.network : Abort applying the network state configuration if using the `network_state` variable with the initscripts provider] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:11 Wednesday 14 February 2024 17:05:47 +0000 (0:00:00.045) 0:00:04.308 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Abort applying the network state configuration if the system version of the managed host is below 8] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:19 Wednesday 14 February 2024 17:05:47 +0000 (0:00:00.023) 0:00:04.332 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Install packages] *************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:30 Wednesday 14 February 2024 17:05:47 +0000 (0:00:00.022) 0:00:04.355 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Install NetworkManager and nmstate when using network_state variable] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:43 Wednesday 14 February 2024 17:05:47 +0000 (0:00:00.045) 0:00:04.400 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Install python3-libnmstate when using network_state variable] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:58 Wednesday 14 February 2024 17:05:47 +0000 (0:00:00.023) 0:00:04.424 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Restart NetworkManager due to wireless or team interfaces] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:74 Wednesday 14 February 2024 17:05:47 +0000 (0:00:00.023) 0:00:04.448 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Enable and start NetworkManager] ************ task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:88 Wednesday 14 February 2024 17:05:47 +0000 (0:00:00.025) 0:00:04.474 **** ok: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Enable and start wpa_supplicant] ************ task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:99 Wednesday 14 February 2024 17:05:48 +0000 (0:00:00.511) 0:00:04.985 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Enable network service] ********************* task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:108 Wednesday 14 February 2024 17:05:48 +0000 (0:00:00.027) 0:00:05.013 **** skipping: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Ensure initscripts network file dependency is present] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:116 Wednesday 14 February 2024 17:05:48 +0000 (0:00:00.024) 0:00:05.037 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Configure networking connection profiles] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:125 Wednesday 14 February 2024 17:05:48 +0000 (0:00:00.022) 0:00:05.060 **** ok: [sut] => { "_invocation": { "module_args": { "__debug_flags": "", "__header": "#\n# Ansible managed\n#\n# system_role:network\n", "connections": [], "force_state_change": false, "ignore_errors": false, "provider": "nm" } }, "changed": false } STDERR: TASK [linux-system-roles.network : Configure networking state] ***************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:137 Wednesday 14 February 2024 17:05:48 +0000 (0:00:00.459) 0:00:05.519 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Show stderr messages for the network_connections] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:143 Wednesday 14 February 2024 17:05:48 +0000 (0:00:00.023) 0:00:05.543 **** ok: [sut] => { "__network_connections_result.stderr_lines": [ "" ] } TASK [linux-system-roles.network : Show debug messages for the network_connections] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:147 Wednesday 14 February 2024 17:05:48 +0000 (0:00:00.025) 0:00:05.568 **** ok: [sut] => { "__network_connections_result": { "_invocation": { "module_args": { "__debug_flags": "", "__header": "#\n# Ansible managed\n#\n# system_role:network\n", "connections": [], "force_state_change": false, "ignore_errors": false, "provider": "nm" } }, "changed": false, "failed": false, "stderr": "\n", "stderr_lines": [ "" ] } } TASK [linux-system-roles.network : Show debug messages for the network_state] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:152 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.054) 0:00:05.623 **** skipping: [sut] => {} TASK [linux-system-roles.network : Re-test connectivity] *********************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:158 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.024) 0:00:05.648 **** ok: [sut] => { "changed": false, "ping": "pong" } TASK [Include the task 'el_repo_setup.yml'] ************************************ task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tests_default.yml:9 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.246) 0:00:05.894 **** included: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml for sut TASK [Gather the minimum subset of ansible_facts required by the network role test] *** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:3 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.038) 0:00:05.932 **** ok: [sut] TASK [Check if system is ostree] *********************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:19 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.360) 0:00:06.293 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Set flag to indicate system is ostree] *********************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:24 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.022) 0:00:06.316 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Fix CentOS6 Base repo] *************************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:28 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.022) 0:00:06.338 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Include the task 'enable_epel.yml'] ************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:53 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.024) 0:00:06.363 **** included: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml for sut TASK [Create EPEL 9] *********************************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml:8 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.040) 0:00:06.404 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Install yum-utils package] *********************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml:24 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.024) 0:00:06.429 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 7] *********************************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml:30 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.026) 0:00:06.455 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 8] *********************************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml:35 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.024) 0:00:06.480 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 6] *********************************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml:40 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.024) 0:00:06.504 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Test warning and info logs] ********************************************** task path: /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tests_default.yml:11 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.024) 0:00:06.529 **** ok: [sut] => { "changed": false } MSG: All assertions passed META: ran handlers META: ran handlers PLAY RECAP ********************************************************************* sut : ok=20 changed=0 unreachable=0 failed=0 skipped=28 rescued=0 ignored=0 Wednesday 14 February 2024 17:05:49 +0000 (0:00:00.013) 0:00:06.542 **** =============================================================================== linux-system-roles.network : Check which services are running ----------- 1.52s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/set_facts.yml:22 linux-system-roles.network : Check which packages are installed --------- 1.10s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/set_facts.yml:27 Gathering Facts --------------------------------------------------------- 0.71s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tests_default_nm.yml:3 -------- linux-system-roles.network : Enable and start NetworkManager ------------ 0.51s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:88 linux-system-roles.network : Configure networking connection profiles --- 0.46s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:125 Gather the minimum subset of ansible_facts required by the network role test --- 0.36s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:3 ----- Gather the minimum subset of ansible_facts required by the network role test --- 0.35s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:3 ----- Check if system is ostree ----------------------------------------------- 0.27s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:19 ---- linux-system-roles.network : Re-test connectivity ----------------------- 0.25s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:158 linux-system-roles.network : Ensure ansible_facts used by role ---------- 0.07s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:4 Set flag to indicate system is ostree ----------------------------------- 0.06s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:24 ---- linux-system-roles.network : Show debug messages for the network_connections --- 0.05s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:147 linux-system-roles.network : Install packages --------------------------- 0.05s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:30 linux-system-roles.network : Print network provider --------------------- 0.05s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:7 Include the task 'enable_epel.yml' -------------------------------------- 0.04s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:53 ---- Include the task 'el_repo_setup.yml' ------------------------------------ 0.04s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tests_default.yml:9 ----------- Include the task 'enable_epel.yml' -------------------------------------- 0.03s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/el_repo_setup.yml:53 ---- linux-system-roles.network : Enable and start wpa_supplicant ------------ 0.03s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:99 Install yum-utils package ----------------------------------------------- 0.03s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/tasks/enable_epel.yml:24 ------ linux-system-roles.network : Restart NetworkManager due to wireless or team interfaces --- 0.03s /WORKDIR/git-bond_options_rewritem3h09x7t/tests/roles/linux-system-roles.network/tasks/main.yml:74 ---^---^---^---^---^--- # STDERR: ---v---v---v---v---v--- [DEPRECATION WARNING]: Distribution centos 9 on host sut should use /usr/libexec/platform-python, but is using /usr/bin/python for backward compatibility with prior Ansible releases. A future Ansible release will default to using the discovered platform python for this host. See https://docs .ansible.com/ansible/2.9/reference_appendices/interpreter_discovery.html for more information. This feature will be removed in version 2.12. Deprecation warnings can be disabled by setting deprecation_warnings=False in ansible.cfg. ---^---^---^---^---^---