# 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_rewrite_vqono0n/tests/tests_default_nm.yml PLAY [Run playbook 'tests_default.yml' with nm as provider] ******************** TASK [Gathering Facts] ********************************************************* task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tests_default_nm.yml:3 Wednesday 14 February 2024 21:18:04 +0000 (0:00:00.011) 0:00:00.011 **** ok: [sut] META: ran handlers TASK [Include the task 'el_repo_setup.yml'] ************************************ task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tests_default_nm.yml:6 Wednesday 14 February 2024 21:18:05 +0000 (0:00:00.979) 0:00:00.991 **** included: /WORKDIR/git-bond_options_rewrite_vqono0n/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_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:3 Wednesday 14 February 2024 21:18:05 +0000 (0:00:00.010) 0:00:01.002 **** ok: [sut] TASK [Check if system is ostree] *********************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:19 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.562) 0:00:01.564 **** ok: [sut] => { "changed": false, "stat": { "exists": false } } TASK [Set flag to indicate system is ostree] *********************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:24 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.347) 0:00:01.912 **** ok: [sut] => { "ansible_facts": { "__network_is_ostree": false }, "changed": false } TASK [Fix CentOS6 Base repo] *************************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:28 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.031) 0:00:01.943 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Include the task 'enable_epel.yml'] ************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:53 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.019) 0:00:01.962 **** included: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml for sut TASK [Create EPEL 38] ********************************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml:8 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.034) 0:00:01.997 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Install yum-utils package] *********************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml:24 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.012) 0:00:02.009 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 7] *********************************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml:30 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.012) 0:00:02.021 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 8] *********************************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml:35 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.015) 0:00:02.037 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 6] *********************************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml:40 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.020) 0:00:02.058 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Set network provider to 'nm'] ******************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tests_default_nm.yml:8 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.009) 0:00:02.067 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:4 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.012) 0:00:02.080 **** included: /WORKDIR/git-bond_options_rewrite_vqono0n/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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/set_facts.yml:3 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.063) 0:00:02.144 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/set_facts.yml:13 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.010) 0:00:02.154 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/set_facts.yml:18 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.014) 0:00:02.169 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/set_facts.yml:22 Wednesday 14 February 2024 21:18:06 +0000 (0:00:00.009) 0:00:02.179 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/set_facts.yml:27 Wednesday 14 February 2024 21:18:09 +0000 (0:00:02.368) 0:00:04.547 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:7 Wednesday 14 February 2024 21:18:10 +0000 (0:00:01.119) 0:00:05.667 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:11 Wednesday 14 February 2024 21:18:10 +0000 (0:00:00.023) 0:00:05.690 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:19 Wednesday 14 February 2024 21:18:10 +0000 (0:00:00.020) 0:00:05.711 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Install packages] *************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:30 Wednesday 14 February 2024 21:18:10 +0000 (0:00:00.021) 0:00:05.732 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:43 Wednesday 14 February 2024 21:18:10 +0000 (0:00:00.044) 0:00:05.776 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:58 Wednesday 14 February 2024 21:18:10 +0000 (0:00:00.025) 0:00:05.802 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:74 Wednesday 14 February 2024 21:18:10 +0000 (0:00:00.028) 0:00:05.831 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:88 Wednesday 14 February 2024 21:18:10 +0000 (0:00:00.024) 0:00:05.856 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:99 Wednesday 14 February 2024 21:18:11 +0000 (0:00:00.712) 0:00:06.568 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Enable network service] ********************* task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:108 Wednesday 14 February 2024 21:18:11 +0000 (0:00:00.027) 0:00:06.595 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:116 Wednesday 14 February 2024 21:18:11 +0000 (0:00:00.027) 0:00:06.623 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:125 Wednesday 14 February 2024 21:18:11 +0000 (0:00:00.041) 0:00:06.664 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:137 Wednesday 14 February 2024 21:18:11 +0000 (0:00:00.557) 0:00:07.222 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:143 Wednesday 14 February 2024 21:18:11 +0000 (0:00:00.060) 0:00:07.282 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:147 Wednesday 14 February 2024 21:18:11 +0000 (0:00:00.042) 0:00:07.325 **** 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_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:152 Wednesday 14 February 2024 21:18:11 +0000 (0:00:00.025) 0:00:07.350 **** skipping: [sut] => {} TASK [linux-system-roles.network : Re-test connectivity] *********************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:158 Wednesday 14 February 2024 21:18:12 +0000 (0:00:00.046) 0:00:07.397 **** ok: [sut] => { "changed": false, "ping": "pong" } TASK [Include the task 'el_repo_setup.yml'] ************************************ task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tests_default.yml:9 Wednesday 14 February 2024 21:18:12 +0000 (0:00:00.296) 0:00:07.693 **** included: /WORKDIR/git-bond_options_rewrite_vqono0n/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_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:3 Wednesday 14 February 2024 21:18:12 +0000 (0:00:00.050) 0:00:07.744 **** ok: [sut] TASK [Check if system is ostree] *********************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:19 Wednesday 14 February 2024 21:18:12 +0000 (0:00:00.553) 0:00:08.297 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Set flag to indicate system is ostree] *********************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:24 Wednesday 14 February 2024 21:18:12 +0000 (0:00:00.021) 0:00:08.319 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Fix CentOS6 Base repo] *************************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:28 Wednesday 14 February 2024 21:18:12 +0000 (0:00:00.021) 0:00:08.340 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Include the task 'enable_epel.yml'] ************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:53 Wednesday 14 February 2024 21:18:12 +0000 (0:00:00.021) 0:00:08.361 **** included: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml for sut TASK [Create EPEL 38] ********************************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml:8 Wednesday 14 February 2024 21:18:13 +0000 (0:00:00.037) 0:00:08.398 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Install yum-utils package] *********************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml:24 Wednesday 14 February 2024 21:18:13 +0000 (0:00:00.044) 0:00:08.442 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 7] *********************************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml:30 Wednesday 14 February 2024 21:18:13 +0000 (0:00:00.021) 0:00:08.464 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 8] *********************************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml:35 Wednesday 14 February 2024 21:18:13 +0000 (0:00:00.026) 0:00:08.491 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 6] *********************************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml:40 Wednesday 14 February 2024 21:18:13 +0000 (0:00:00.032) 0:00:08.524 **** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Test warning and info logs] ********************************************** task path: /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tests_default.yml:11 Wednesday 14 February 2024 21:18:13 +0000 (0:00:00.030) 0:00:08.555 **** 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 21:18:13 +0000 (0:00:00.011) 0:00:08.566 **** =============================================================================== linux-system-roles.network : Check which services are running ----------- 2.37s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/set_facts.yml:22 linux-system-roles.network : Check which packages are installed --------- 1.12s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/set_facts.yml:27 Gathering Facts --------------------------------------------------------- 0.98s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tests_default_nm.yml:3 -------- linux-system-roles.network : Enable and start NetworkManager ------------ 0.71s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:88 Gather the minimum subset of ansible_facts required by the network role test --- 0.56s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:3 ----- linux-system-roles.network : Configure networking connection profiles --- 0.56s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:125 Gather the minimum subset of ansible_facts required by the network role test --- 0.55s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:3 ----- Check if system is ostree ----------------------------------------------- 0.35s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:19 ---- linux-system-roles.network : Re-test connectivity ----------------------- 0.30s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:158 linux-system-roles.network : Ensure ansible_facts used by role ---------- 0.06s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:4 linux-system-roles.network : Configure networking state ----------------- 0.06s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:137 Include the task 'el_repo_setup.yml' ------------------------------------ 0.05s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tests_default.yml:9 ----------- linux-system-roles.network : Show debug messages for the network_state --- 0.05s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:152 linux-system-roles.network : Install packages --------------------------- 0.04s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:30 Create EPEL 38 ---------------------------------------------------------- 0.04s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml:8 ------- linux-system-roles.network : Show stderr messages for the network_connections --- 0.04s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:143 linux-system-roles.network : Ensure initscripts network file dependency is present --- 0.04s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/roles/linux-system-roles.network/tasks/main.yml:116 Include the task 'enable_epel.yml' -------------------------------------- 0.04s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:53 ---- Include the task 'enable_epel.yml' -------------------------------------- 0.03s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/el_repo_setup.yml:53 ---- Enable EPEL 8 ----------------------------------------------------------- 0.03s /WORKDIR/git-bond_options_rewrite_vqono0n/tests/tasks/enable_epel.yml:35 ------ ---^---^---^---^---^--- # STDERR: ---v---v---v---v---v--- [DEPRECATION WARNING]: Distribution fedora 38 on host sut should use /usr/bin/python3, 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. ---^---^---^---^---^---