# STDOUT: ---v---v---v---v---v--- Using /etc/ansible/ansible.cfg as config file PLAY [Run playbook 'playbooks/tests_dummy.yml' with nm as provider] ************ TASK [Gathering Facts] ********************************************************* Friday 27 May 2022 16:36:27 +0000 (0:00:00.125) 0:00:00.125 ************ ok: [sut] TASK [include_tasks] *********************************************************** Friday 27 May 2022 16:36:29 +0000 (0:00:02.027) 0:00:02.153 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/tasks/el_repo_setup.yml for sut TASK [Fix CentOS6 Base repo] *************************************************** Friday 27 May 2022 16:36:29 +0000 (0:00:00.121) 0:00:02.274 ************ skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [include_tasks] *********************************************************** Friday 27 May 2022 16:36:29 +0000 (0:00:00.111) 0:00:02.386 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/tasks/enable_epel.yml for sut TASK [Create EPEL 8] *********************************************************** Friday 27 May 2022 16:36:30 +0000 (0:00:00.191) 0:00:02.578 ************ changed: [sut] => { "changed": true, "cmd": [ "yum", "install", "-y", "https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm" ], "delta": "0:00:02.562456", "end": "2022-05-27 16:36:33.043698", "rc": 0, "start": "2022-05-27 16:36:30.481242" } STDOUT: Updating Subscription Management repositories. Unable to read consumer identity This system is not registered with an entitlement server. You can use subscription-manager to register. Last metadata expiration check: 0:00:21 ago on Fri May 27 16:36:10 2022. epel-release-latest-8.noarch.rpm 161 kB/s | 23 kB 00:00 Dependencies resolved. ================================================================================ Package Architecture Version Repository Size ================================================================================ Installing: epel-release noarch 8-15.el8 @commandline 23 k Transaction Summary ================================================================================ Install 1 Package Total size: 23 k Installed size: 32 k Downloading Packages: Running transaction check Transaction check succeeded. Running transaction test Transaction test succeeded. Running transaction Preparing : 1/1 Installing : epel-release-8-15.el8.noarch 1/1 Running scriptlet: epel-release-8-15.el8.noarch 1/1 Verifying : epel-release-8-15.el8.noarch 1/1 Installed products updated. Installed: epel-release-8-15.el8.noarch Complete! TASK [Enable EPEL 7] *********************************************************** Friday 27 May 2022 16:36:33 +0000 (0:00:03.481) 0:00:06.059 ************ skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 8] *********************************************************** Friday 27 May 2022 16:36:33 +0000 (0:00:00.106) 0:00:06.166 ************ changed: [sut] => { "changed": true, "cmd": [ "dnf", "config-manager", "--set-enabled", "epel" ], "delta": "0:00:00.551382", "end": "2022-05-27 16:36:34.199742", "rc": 0, "start": "2022-05-27 16:36:33.648360" } STDOUT: Updating Subscription Management repositories. Unable to read consumer identity This system is not registered with an entitlement server. You can use subscription-manager to register. TASK [Enable EPEL 6] *********************************************************** Friday 27 May 2022 16:36:34 +0000 (0:00:01.078) 0:00:07.244 ************ skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Set network provider to 'nm'] ******************************************** Friday 27 May 2022 16:36:34 +0000 (0:00:00.130) 0:00:07.375 ************ ok: [sut] => { "ansible_facts": { "network_provider": "nm" }, "changed": false } PLAY [all] ********************************************************************* TASK [Gathering Facts] ********************************************************* Friday 27 May 2022 16:36:35 +0000 (0:00:00.101) 0:00:07.476 ************ ok: [sut] TASK [Show playbook name] ****************************************************** Friday 27 May 2022 16:36:35 +0000 (0:00:00.833) 0:00:08.310 ************ ok: [sut] => {} MSG: this is: playbooks/tests_dummy.yml TASK [include_tasks] *********************************************************** Friday 27 May 2022 16:36:35 +0000 (0:00:00.048) 0:00:08.358 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/playbooks/tasks/run_test.yml for sut TASK [TEST: Create a dummy interface] ****************************************** Friday 27 May 2022 16:36:35 +0000 (0:00:00.058) 0:00:08.417 ************ ok: [sut] => {} MSG: ########## Create a dummy interface ########## TASK [Show item] *************************************************************** Friday 27 May 2022 16:36:36 +0000 (0:00:00.062) 0:00:08.480 ************ ok: [sut] => (item=lsr_description) => { "ansible_loop_var": "item", "item": "lsr_description", "lsr_description": "Create a dummy interface" } ok: [sut] => (item=lsr_setup) => { "ansible_loop_var": "item", "item": "lsr_setup", "lsr_setup": [ "tasks/delete_interface.yml", "tasks/assert_device_absent.yml" ] } ok: [sut] => (item=lsr_test) => { "ansible_loop_var": "item", "item": "lsr_test", "lsr_test": [ "tasks/create_dummy_profile.yml" ] } ok: [sut] => (item=lsr_assert) => { "ansible_loop_var": "item", "item": "lsr_assert", "lsr_assert": [ "tasks/assert_profile_present.yml", "tasks/assert_device_present.yml" ] } ok: [sut] => (item=lsr_assert_when) => { "ansible_loop_var": "item", "item": "lsr_assert_when", "lsr_assert_when": "VARIABLE IS NOT DEFINED!: 'lsr_assert_when' is undefined" } ok: [sut] => (item=lsr_fail_debug) => { "ansible_loop_var": "item", "item": "lsr_fail_debug", "lsr_fail_debug": [ "__network_connections_result" ] } ok: [sut] => (item=lsr_cleanup) => { "ansible_loop_var": "item", "item": "lsr_cleanup", "lsr_cleanup": [ "tasks/cleanup_profile+device.yml" ] } TASK [include_tasks] *********************************************************** Friday 27 May 2022 16:36:36 +0000 (0:00:00.310) 0:00:08.790 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/playbooks/tasks/show_interfaces.yml for sut TASK [include] ***************************************************************** Friday 27 May 2022 16:36:36 +0000 (0:00:00.119) 0:00:08.909 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/playbooks/tasks/get_current_interfaces.yml for sut TASK [Gather current interface info] ******************************************* Friday 27 May 2022 16:36:36 +0000 (0:00:00.155) 0:00:09.065 ************ ok: [sut] => { "changed": false, "cmd": [ "ls", "-1" ], "delta": "0:00:00.003814", "end": "2022-05-27 16:36:36.411975", "rc": 0, "start": "2022-05-27 16:36:36.408161" } STDOUT: eth0 lo TASK [Set current_interfaces] ************************************************** Friday 27 May 2022 16:36:36 +0000 (0:00:00.347) 0:00:09.412 ************ ok: [sut] => { "ansible_facts": { "current_interfaces": [ "eth0", "lo" ] }, "changed": false } TASK [Show current_interfaces] ************************************************* Friday 27 May 2022 16:36:37 +0000 (0:00:00.137) 0:00:09.549 ************ ok: [sut] => {} MSG: current_interfaces: ['eth0', 'lo'] TASK [setup] ******************************************************************* Friday 27 May 2022 16:36:37 +0000 (0:00:00.132) 0:00:09.681 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/playbooks/tasks/delete_interface.yml for sut included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/playbooks/tasks/assert_device_absent.yml for sut TASK [remove test interface if necessary] ************************************** Friday 27 May 2022 16:36:37 +0000 (0:00:00.203) 0:00:09.885 ************ fatal: [sut]: FAILED! => { "changed": false, "cmd": [ "ip", "link", "del", "dummy0" ], "delta": "0:00:00.010522", "end": "2022-05-27 16:36:37.271046", "rc": 1, "start": "2022-05-27 16:36:37.260524" } STDERR: Cannot find device "dummy0" MSG: non-zero return code ...ignoring TASK [include] ***************************************************************** Friday 27 May 2022 16:36:37 +0000 (0:00:00.383) 0:00:10.268 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/playbooks/tasks/get_interface_stat.yml for sut TASK [Get stat for interface dummy0] ******************************************* Friday 27 May 2022 16:36:38 +0000 (0:00:00.322) 0:00:10.590 ************ ok: [sut] => { "changed": false, "stat": { "exists": false } } TASK [assert that interface dummy0 is absent] ********************************** Friday 27 May 2022 16:36:39 +0000 (0:00:00.926) 0:00:11.517 ************ ok: [sut] => { "changed": false } MSG: All assertions passed TASK [test] ******************************************************************** Friday 27 May 2022 16:36:39 +0000 (0:00:00.114) 0:00:11.632 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/playbooks/tasks/create_dummy_profile.yml for sut TASK [Include network role] **************************************************** Friday 27 May 2022 16:36:39 +0000 (0:00:00.217) 0:00:11.850 ************ TASK [linux-system-roles.network : Ensure ansible_facts used by role] ********** Friday 27 May 2022 16:36:39 +0000 (0:00:00.257) 0:00:12.108 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/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] *** Friday 27 May 2022 16:36:40 +0000 (0:00:00.702) 0:00:12.810 ************ 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 services are running] *********** Friday 27 May 2022 16:36:41 +0000 (0:00:00.690) 0:00:13.501 ************ 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] ********* Friday 27 May 2022 16:36:43 +0000 (0:00:02.493) 0:00:15.995 ************ 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] ********************* Friday 27 May 2022 16:36:45 +0000 (0:00:02.279) 0:00:18.274 ************ ok: [sut] => {} MSG: Using network provider: nm TASK [linux-system-roles.network : Install packages] *************************** Friday 27 May 2022 16:36:45 +0000 (0:00:00.120) 0:00:18.395 ************ skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Restart NetworkManager due to wireless or team interfaces] *** Friday 27 May 2022 16:36:46 +0000 (0:00:00.224) 0:00:18.620 ************ skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Enable and start NetworkManager] ************ Friday 27 May 2022 16:36:46 +0000 (0:00:00.208) 0:00:18.828 ************ 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] ************ Friday 27 May 2022 16:36:47 +0000 (0:00:01.617) 0:00:20.446 ************ skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Enable network service] ********************* Friday 27 May 2022 16:36:48 +0000 (0:00:00.281) 0:00:20.727 ************ 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] *** Friday 27 May 2022 16:36:48 +0000 (0:00:00.301) 0:00:21.029 ************ skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Configure networking connection profiles] *** Friday 27 May 2022 16:36:48 +0000 (0:00:00.182) 0:00:21.211 ************ changed: [sut] => { "_invocation": { "module_args": { "__debug_flags": "", "__header": "#\n# Ansible managed\n#\n", "connections": [ { "ip": { "address": [ "192.0.2.42/30" ] }, "name": "dummy0", "state": "up", "type": "dummy" } ], "force_state_change": false, "ignore_errors": false, "provider": "nm" } }, "changed": true } STDERR: [003] #0, state:up persistent_state:present, 'dummy0': add connection dummy0, 4dbdfd28-c4e9-4290-99ae-4f5065789be4 [004] #0, state:up persistent_state:present, 'dummy0': up connection dummy0, 4dbdfd28-c4e9-4290-99ae-4f5065789be4 (is-modified) TASK [linux-system-roles.network : Show stderr messages] *********************** Friday 27 May 2022 16:36:51 +0000 (0:00:02.374) 0:00:23.586 ************ ok: [sut] => { "__network_connections_result.stderr_lines": [ "[003] #0, state:up persistent_state:present, 'dummy0': add connection dummy0, 4dbdfd28-c4e9-4290-99ae-4f5065789be4", "[004] #0, state:up persistent_state:present, 'dummy0': up connection dummy0, 4dbdfd28-c4e9-4290-99ae-4f5065789be4 (is-modified)" ] } TASK [linux-system-roles.network : Show debug messages] ************************ Friday 27 May 2022 16:36:51 +0000 (0:00:00.254) 0:00:23.840 ************ ok: [sut] => { "__network_connections_result": { "_invocation": { "module_args": { "__debug_flags": "", "__header": "#\n# Ansible managed\n#\n", "connections": [ { "ip": { "address": [ "192.0.2.42/30" ] }, "name": "dummy0", "state": "up", "type": "dummy" } ], "force_state_change": false, "ignore_errors": false, "provider": "nm" } }, "changed": true, "failed": false, "stderr": "[003] #0, state:up persistent_state:present, 'dummy0': add connection dummy0, 4dbdfd28-c4e9-4290-99ae-4f5065789be4\n[004] #0, state:up persistent_state:present, 'dummy0': up connection dummy0, 4dbdfd28-c4e9-4290-99ae-4f5065789be4 (is-modified)\n", "stderr_lines": [ "[003] #0, state:up persistent_state:present, 'dummy0': add connection dummy0, 4dbdfd28-c4e9-4290-99ae-4f5065789be4", "[004] #0, state:up persistent_state:present, 'dummy0': up connection dummy0, 4dbdfd28-c4e9-4290-99ae-4f5065789be4 (is-modified)" ] } } TASK [linux-system-roles.network : Re-test connectivity] *********************** Friday 27 May 2022 16:36:51 +0000 (0:00:00.119) 0:00:23.960 ************ ok: [sut] => { "changed": false, "ping": "pong" } TASK [Show result] ************************************************************* Friday 27 May 2022 16:36:52 +0000 (0:00:00.887) 0:00:24.848 ************ ok: [sut] => { "__network_connections_result": { "_invocation": { "module_args": { "__debug_flags": "", "__header": "#\n# Ansible managed\n#\n", "connections": [ { "ip": { "address": [ "192.0.2.42/30" ] }, "name": "dummy0", "state": "up", "type": "dummy" } ], "force_state_change": false, "ignore_errors": false, "provider": "nm" } }, "changed": true, "failed": false, "stderr": "[003] #0, state:up persistent_state:present, 'dummy0': add connection dummy0, 4dbdfd28-c4e9-4290-99ae-4f5065789be4\n[004] #0, state:up persistent_state:present, 'dummy0': up connection dummy0, 4dbdfd28-c4e9-4290-99ae-4f5065789be4 (is-modified)\n", "stderr_lines": [ "[003] #0, state:up persistent_state:present, 'dummy0': add connection dummy0, 4dbdfd28-c4e9-4290-99ae-4f5065789be4", "[004] #0, state:up persistent_state:present, 'dummy0': up connection dummy0, 4dbdfd28-c4e9-4290-99ae-4f5065789be4 (is-modified)" ] } } TASK [asserts] ***************************************************************** Friday 27 May 2022 16:36:52 +0000 (0:00:00.199) 0:00:25.048 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/playbooks/tasks/assert_profile_present.yml for sut included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/playbooks/tasks/assert_device_present.yml for sut TASK [include] ***************************************************************** Friday 27 May 2022 16:36:53 +0000 (0:00:00.460) 0:00:25.508 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/playbooks/tasks/get_profile_stat.yml for sut TASK [Initialize NM profile exist and ansible_managed comment flag] ************ Friday 27 May 2022 16:36:53 +0000 (0:00:00.191) 0:00:25.700 ************ ok: [sut] => { "ansible_facts": { "lsr_net_profile_ansible_managed": false, "lsr_net_profile_exists": false }, "changed": false } TASK [stat profile file] ******************************************************* Friday 27 May 2022 16:36:53 +0000 (0:00:00.216) 0:00:25.917 ************ ok: [sut] => { "changed": false, "stat": { "exists": false } } TASK [Set NM profile exist flag based on the profile files] ******************** Friday 27 May 2022 16:36:54 +0000 (0:00:00.548) 0:00:26.465 ************ skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Get NM profile info] ***************************************************** Friday 27 May 2022 16:36:54 +0000 (0:00:00.263) 0:00:26.728 ************ ok: [sut] => { "changed": false, "cmd": "nmcli -f NAME,FILENAME connection show |grep dummy0 | grep /etc", "delta": "0:00:00.121861", "end": "2022-05-27 16:36:54.238426", "rc": 0, "start": "2022-05-27 16:36:54.116565" } STDOUT: dummy0 /etc/NetworkManager/system-connections/dummy0.nmconnection TASK [Set NM profile exist flag and ansible_managed flag true based on the nmcli output] *** Friday 27 May 2022 16:36:54 +0000 (0:00:00.566) 0:00:27.295 ************ ok: [sut] => { "ansible_facts": { "lsr_net_profile_ansible_managed": true, "lsr_net_profile_exists": true }, "changed": false } TASK [Get the ansible_managed comment in ifcfg-dummy0] ************************* Friday 27 May 2022 16:36:54 +0000 (0:00:00.148) 0:00:27.443 ************ skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Verify the ansible_managed comment in ifcfg-dummy0] ********************** Friday 27 May 2022 16:36:55 +0000 (0:00:00.169) 0:00:27.613 ************ skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [assert that profile 'dummy0' is present] ********************************* Friday 27 May 2022 16:36:55 +0000 (0:00:00.140) 0:00:27.753 ************ ok: [sut] => { "changed": false } MSG: All assertions passed TASK [assert that ansible managed comment in 'dummy0' is present] ************** Friday 27 May 2022 16:36:55 +0000 (0:00:00.336) 0:00:28.089 ************ ok: [sut] => { "changed": false } MSG: All assertions passed TASK [include] ***************************************************************** Friday 27 May 2022 16:36:56 +0000 (0:00:00.385) 0:00:28.474 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/playbooks/tasks/get_interface_stat.yml for sut TASK [Get stat for interface dummy0] ******************************************* Friday 27 May 2022 16:36:56 +0000 (0:00:00.290) 0:00:28.765 ************ ok: [sut] => { "changed": false, "stat": { "atime": 1653669410.365218, "block_size": 4096, "blocks": 0, "ctime": 1653669410.365218, "dev": 20, "device_type": 0, "executable": true, "exists": true, "gid": 0, "gr_name": "root", "inode": 21048, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": true, "isreg": false, "issock": false, "isuid": false, "lnk_source": "/sys/devices/virtual/net/dummy0", "lnk_target": "../../devices/virtual/net/dummy0", "mode": "0777", "mtime": 1653669410.365218, "nlink": 1, "path": "/sys/class/net/dummy0", "pw_name": "root", "readable": true, "rgrp": true, "roth": true, "rusr": true, "size": 0, "uid": 0, "wgrp": true, "woth": true, "writeable": true, "wusr": true, "xgrp": true, "xoth": true, "xusr": true } } TASK [assert that interface dummy0 is present] ********************************* Friday 27 May 2022 16:36:56 +0000 (0:00:00.362) 0:00:29.128 ************ ok: [sut] => { "changed": false } MSG: All assertions passed TASK [conditional asserts] ***************************************************** Friday 27 May 2022 16:36:56 +0000 (0:00:00.177) 0:00:29.306 ************ TASK [Success in test 'Create a dummy interface'] ****************************** Friday 27 May 2022 16:36:57 +0000 (0:00:00.154) 0:00:29.461 ************ ok: [sut] => {} MSG: +++++ Success in test 'Create a dummy interface' +++++ TASK [cleanup] ***************************************************************** Friday 27 May 2022 16:36:57 +0000 (0:00:00.286) 0:00:29.747 ************ included: /WORKDIR/dist-git-network-bond_fix-IHMNac/tests/playbooks/tasks/cleanup_profile+device.yml for sut TASK [Cleanup profile and device] ********************************************** Friday 27 May 2022 16:36:57 +0000 (0:00:00.207) 0:00:29.954 ************ fatal: [sut]: FAILED! => { "changed": false, "cmd": "nmcli con delete dummy0\nnmcli con load /etc/sysconfig/network-scripts/ifcfg-dummy0\nrm -f /etc/sysconfig/network-scripts/ifcfg-dummy0\nip link del dummy0\n", "delta": "0:00:00.075893", "end": "2022-05-27 16:36:57.407693", "rc": 1, "start": "2022-05-27 16:36:57.331800" } STDOUT: Connection 'dummy0' (4dbdfd28-c4e9-4290-99ae-4f5065789be4) successfully deleted. STDERR: Cannot find device "dummy0" MSG: non-zero return code ...ignoring PLAY RECAP ********************************************************************* sut : ok=49 changed=3 unreachable=0 failed=0 skipped=12 rescued=0 ignored=2 Friday 27 May 2022 16:36:57 +0000 (0:00:00.434) 0:00:30.389 ************ =============================================================================== Create EPEL 8 ----------------------------------------------------------- 3.48s linux-system-roles.network : Check which services are running ----------- 2.49s linux-system-roles.network : Configure networking connection profiles --- 2.37s linux-system-roles.network : Check which packages are installed --------- 2.28s Gathering Facts --------------------------------------------------------- 2.03s linux-system-roles.network : Enable and start NetworkManager ------------ 1.62s Enable EPEL 8 ----------------------------------------------------------- 1.08s Get stat for interface dummy0 ------------------------------------------- 0.93s linux-system-roles.network : Re-test connectivity ----------------------- 0.89s Gathering Facts --------------------------------------------------------- 0.83s linux-system-roles.network : Ensure ansible_facts used by role ---------- 0.70s linux-system-roles.network : Ensure ansible_facts used by role are present --- 0.69s Get NM profile info ----------------------------------------------------- 0.57s stat profile file ------------------------------------------------------- 0.55s asserts ----------------------------------------------------------------- 0.46s Cleanup profile and device ---------------------------------------------- 0.43s assert that ansible managed comment in 'dummy0' is present -------------- 0.39s remove test interface if necessary -------------------------------------- 0.38s Get stat for interface dummy0 ------------------------------------------- 0.36s Gather current interface info ------------------------------------------- 0.35s ---^---^---^---^---^--- # STDERR: ---v---v---v---v---v--- /opt/ansible-2.9/lib/python3.6/site-packages/ansible/parsing/vault/__init__.py:44: CryptographyDeprecationWarning: Python 3.6 is no longer supported by the Python core team. Therefore, support for it is deprecated in cryptography and will be removed in a future release. from cryptography.exceptions import InvalidSignature ---^---^---^---^---^---