Warning in ansible: You're using Ansible version 12.x or higher; netlab might not work correctly ... Ansible core version 2.19 introduced breaking changes in templates and playbooks ... We tested netlab core with Ansible version 12.x but not every device template ... You might want to downgrade Ansible to version 11.10 or lower. ... Use 'netlab install ansible' on Ubuntu to do that ... Finally, please open a GitHub issue if you experience errors/crashes ... Set defaults.ansible.warnings.ver12 to False to hide this warning [INFO] Checking for updates in configuration templates [INFO] Creating configuration snippets [WARNING]: Could not match supplied host pattern, ignoring: unprovisioned [WARNING]: Found variable using reserved name 'hosts'. Origin: /work/netlab_cicd/group_vars/all/topology.yml:158:1 156 ipv4: 10.2.0.0/24 157 prefix: 32 158 hosts: ^ column 1 PLAY [Deploy initial device configuration] ************************************* TASK [Set variables that cannot be set with VARS] ****************************** ok: [r1] ok: [r3] ok: [dut] ok: [r2] ok: [r4] TASK [Generic readiness tests] ************************************************* included: /home/pipi/netlab_gh/netsim/ansible/tasks/readiness-check/ssh.yml for r1, r2, r3, r4, dut => (item=ssh) TASK [Check if 'sshpass' is installed] ***************************************** ok: [r1 -> localhost] TASK [Check for 'timeout' command] ********************************************* ok: [r1 -> localhost] ok: [r3 -> localhost] ok: [r2 -> localhost] ok: [r4 -> localhost] ok: [dut -> localhost] TASK [Execute local ssh command to check ssh readiness] ************************ FAILED - RETRYING: [r1 -> localhost]: Execute local ssh command to check ssh readiness (20 retries left). FAILED - RETRYING: [r3 -> localhost]: Execute local ssh command to check ssh readiness (20 retries left). FAILED - RETRYING: [r2 -> localhost]: Execute local ssh command to check ssh readiness (20 retries left). FAILED - RETRYING: [r4 -> localhost]: Execute local ssh command to check ssh readiness (20 retries left). ok: [dut -> localhost] ok: [r3 -> localhost] ok: [r1 -> localhost] ok: [r2 -> localhost] ok: [r4 -> localhost] TASK [Confirm r1 SSH server works] ********************************************* ok: [r1] => { "msg": "Node r1 is ready." } ok: [r2] => { "msg": "Node r2 is ready." } ok: [dut] => { "msg": "Node dut is ready." } ok: [r3] => { "msg": "Node r3 is ready." } ok: [r4] => { "msg": "Node r4 is ready." } TASK [Find device readiness script] ******************************************** ok: [r1] ok: [r3] ok: [r2] ok: [dut] ok: [r4] TASK [Wait for device to become ready] ***************************************** skipping: [r1] skipping: [r2] skipping: [r3] skipping: [r4] skipping: [dut] TASK [Normalize config on bridge-like devices] ********************************* included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r1 included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r2 included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r3 included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r4 included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for dut TASK [Figure out whether to deploy the module normalize on current device] ***** ok: [r1] TASK [Find configuration template for normalize] ******************************* ok: [r1] TASK [fail] ******************************************************************** skipping: [r1] TASK [Find configuration deployment deploy_script for normalize] *************** ok: [r1] TASK [Print deployed configuration when running in verbose mode] *************** ok: [r1] => { "msg": "normalize configuration for r1\n=========================================\n!\ninterface Ethernet1\n shutdown\n" } TASK [Deploy normalize configuration] ****************************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r1 TASK [eos_config: deploying normalize from /work/netlab_cicd/node_files/r1/normalize] *** [WARNING]: To ensure idempotency and correct diff the input configuration lines should be similar to how they appear if present in the running configuration on device including the indentation [WARNING]: Task result `warnings` was instead of . changed: [r1] TASK [Figure out whether to deploy the module normalize on current device] ***** ok: [r2] TASK [Find configuration template for normalize] ******************************* ok: [r2] TASK [fail] ******************************************************************** skipping: [r2] TASK [Find configuration deployment deploy_script for normalize] *************** ok: [r2] TASK [Print deployed configuration when running in verbose mode] *************** ok: [r2] => { "msg": "normalize configuration for r2\n=========================================\n!\ninterface Ethernet1\n shutdown\n" } TASK [Deploy normalize configuration] ****************************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r2 TASK [eos_config: deploying normalize from /work/netlab_cicd/node_files/r2/normalize] *** changed: [r2] TASK [Figure out whether to deploy the module normalize on current device] ***** ok: [r3] TASK [Find configuration template for normalize] ******************************* ok: [r3] TASK [fail] ******************************************************************** skipping: [r3] TASK [Find configuration deployment deploy_script for normalize] *************** ok: [r3] TASK [Print deployed configuration when running in verbose mode] *************** ok: [r3] => { "msg": "normalize configuration for r3\n=========================================\n!\ninterface Ethernet1\n shutdown\n" } TASK [Deploy normalize configuration] ****************************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r3 TASK [eos_config: deploying normalize from /work/netlab_cicd/node_files/r3/normalize] *** changed: [r3] TASK [Figure out whether to deploy the module normalize on current device] ***** ok: [r4] TASK [Find configuration template for normalize] ******************************* ok: [r4] TASK [fail] ******************************************************************** skipping: [r4] TASK [Find configuration deployment deploy_script for normalize] *************** ok: [r4] TASK [Print deployed configuration when running in verbose mode] *************** ok: [r4] => { "msg": "normalize configuration for r4\n=========================================\n!\ninterface Ethernet1\n shutdown\n" } TASK [Deploy normalize configuration] ****************************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r4 TASK [eos_config: deploying normalize from /work/netlab_cicd/node_files/r4/normalize] *** changed: [r4] TASK [Figure out whether to deploy the module normalize on current device] ***** ok: [dut] TASK [Find configuration template for normalize] ******************************* ok: [dut] TASK [fail] ******************************************************************** skipping: [dut] TASK [Find configuration deployment deploy_script for normalize] *************** ok: [dut] TASK [Print deployed configuration when running in verbose mode] *************** skipping: [dut] TASK [Deploy normalize configuration] ****************************************** skipping: [dut] TASK [Deploy initial configuration] ******************************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r1 included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r2 included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r3 included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r4 included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for dut TASK [Figure out whether to deploy the module initial on current device] ******* ok: [r1] TASK [Find configuration template for initial] ********************************* ok: [r1] TASK [fail] ******************************************************************** skipping: [r1] TASK [Find configuration deployment deploy_script for initial] ***************** ok: [r1] TASK [Print deployed configuration when running in verbose mode] *************** ok: [r1] => { "msg": "initial configuration for r1\n=========================================\nhostname r1\n!\nlogging monitor debugging\naaa authorization exec default local\n!\nlldp run\nip routing\nipv6 unicast-routing\n!\n!\nip host dut 10.0.0.1\nip host dut-red 10.1.0.1 10.1.0.5\nip host dut-blue 10.1.0.9 10.1.0.13\nip host r2 10.0.0.12 10.1.0.6\nip host r3 10.0.0.23 10.1.0.10\nip host r4 10.0.0.24 10.1.0.14\nipv6 host dut 2001:db8:1:1::1\nipv6 host r2 2001:db8:1:c::1\nipv6 host r3 2001:db8:1:17::1\nipv6 host r4 2001:db8:1:18::1\n!\ninterface Management0\n no lldp transmit\n no lldp receive\n!\ninterface Loopback0\n ip address 10.0.0.11/32\n ipv6 nd ra interval 5\n ipv6 address 2001:db8:1:b::1/64\n!\ninterface Ethernet1\n no switchport\n platform tfa phy control-frame disabled\n description r1 -> dut [external]\n ip address 10.1.0.2/30\n mac-address caf0.000b.0001\n!\n no shutdown\n!\n" } TASK [Deploy initial configuration] ******************************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r1 TASK [eos_config: deploying initial from /work/netlab_cicd/node_files/r1/initial] *** changed: [r1] TASK [Figure out whether to deploy the module initial on current device] ******* ok: [r2] TASK [Find configuration template for initial] ********************************* ok: [r2] TASK [fail] ******************************************************************** skipping: [r2] TASK [Find configuration deployment deploy_script for initial] ***************** ok: [r2] TASK [Print deployed configuration when running in verbose mode] *************** ok: [r2] => { "msg": "initial configuration for r2\n=========================================\nhostname r2\n!\nlogging monitor debugging\naaa authorization exec default local\n!\nlldp run\nip routing\nipv6 unicast-routing\n!\n!\nip host dut 10.0.0.1\nip host dut-red 10.1.0.1 10.1.0.5\nip host dut-blue 10.1.0.9 10.1.0.13\nip host r1 10.0.0.11 10.1.0.2\nip host r3 10.0.0.23 10.1.0.10\nip host r4 10.0.0.24 10.1.0.14\nipv6 host dut 2001:db8:1:1::1\nipv6 host r1 2001:db8:1:b::1\nipv6 host r3 2001:db8:1:17::1\nipv6 host r4 2001:db8:1:18::1\n!\ninterface Management0\n no lldp transmit\n no lldp receive\n!\ninterface Loopback0\n ip address 10.0.0.12/32\n ipv6 nd ra interval 5\n ipv6 address 2001:db8:1:c::1/64\n!\ninterface Ethernet1\n no switchport\n platform tfa phy control-frame disabled\n description r2 -> dut [external]\n ip address 10.1.0.6/30\n mac-address caf0.000c.0001\n!\n no shutdown\n!\n" } TASK [Deploy initial configuration] ******************************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r2 TASK [eos_config: deploying initial from /work/netlab_cicd/node_files/r2/initial] *** changed: [r2] TASK [Figure out whether to deploy the module initial on current device] ******* ok: [r3] TASK [Find configuration template for initial] ********************************* ok: [r3] TASK [fail] ******************************************************************** skipping: [r3] TASK [Find configuration deployment deploy_script for initial] ***************** ok: [r3] TASK [Print deployed configuration when running in verbose mode] *************** ok: [r3] => { "msg": "initial configuration for r3\n=========================================\nhostname r3\n!\nlogging monitor debugging\naaa authorization exec default local\n!\nlldp run\nip routing\nipv6 unicast-routing\n!\n!\nip host dut 10.0.0.1\nip host dut-red 10.1.0.1 10.1.0.5\nip host dut-blue 10.1.0.9 10.1.0.13\nip host r1 10.0.0.11 10.1.0.2\nip host r2 10.0.0.12 10.1.0.6\nip host r4 10.0.0.24 10.1.0.14\nipv6 host dut 2001:db8:1:1::1\nipv6 host r1 2001:db8:1:b::1\nipv6 host r2 2001:db8:1:c::1\nipv6 host r4 2001:db8:1:18::1\n!\ninterface Management0\n no lldp transmit\n no lldp receive\n!\ninterface Loopback0\n ip address 10.0.0.23/32\n ipv6 nd ra interval 5\n ipv6 address 2001:db8:1:17::1/64\n!\ninterface Ethernet1\n no switchport\n platform tfa phy control-frame disabled\n description r3 -> dut [external]\n ip address 10.1.0.10/30\n mac-address caf0.0017.0001\n!\n no shutdown\n!\n" } TASK [Deploy initial configuration] ******************************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r3 TASK [eos_config: deploying initial from /work/netlab_cicd/node_files/r3/initial] *** changed: [r3] TASK [Figure out whether to deploy the module initial on current device] ******* ok: [r4] TASK [Find configuration template for initial] ********************************* ok: [r4] TASK [fail] ******************************************************************** skipping: [r4] TASK [Find configuration deployment deploy_script for initial] ***************** ok: [r4] TASK [Print deployed configuration when running in verbose mode] *************** ok: [r4] => { "msg": "initial configuration for r4\n=========================================\nhostname r4\n!\nlogging monitor debugging\naaa authorization exec default local\n!\nlldp run\nip routing\nipv6 unicast-routing\n!\n!\nip host dut 10.0.0.1\nip host dut-red 10.1.0.1 10.1.0.5\nip host dut-blue 10.1.0.9 10.1.0.13\nip host r1 10.0.0.11 10.1.0.2\nip host r2 10.0.0.12 10.1.0.6\nip host r3 10.0.0.23 10.1.0.10\nipv6 host dut 2001:db8:1:1::1\nipv6 host r1 2001:db8:1:b::1\nipv6 host r2 2001:db8:1:c::1\nipv6 host r3 2001:db8:1:17::1\n!\ninterface Management0\n no lldp transmit\n no lldp receive\n!\ninterface Loopback0\n ip address 10.0.0.24/32\n ipv6 nd ra interval 5\n ipv6 address 2001:db8:1:18::1/64\n!\ninterface Ethernet1\n no switchport\n platform tfa phy control-frame disabled\n description r4 -> dut [external]\n ip address 10.1.0.14/30\n mac-address caf0.0018.0001\n!\n no shutdown\n!\n" } TASK [Deploy initial configuration] ******************************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r4 TASK [eos_config: deploying initial from /work/netlab_cicd/node_files/r4/initial] *** changed: [r4] TASK [Figure out whether to deploy the module initial on current device] ******* ok: [dut] TASK [Find configuration template for initial] ********************************* ok: [dut] TASK [fail] ******************************************************************** skipping: [dut] TASK [Find configuration deployment deploy_script for initial] ***************** ok: [dut] TASK [Print deployed configuration when running in verbose mode] *************** ok: [dut] => { "msg": "initial configuration for dut\n=========================================\nhostname dut\n!\nno ip domain lookup\nlogging buffered 256000\n\n!\nlldp run\n!\nip host dut-red 10.1.0.1 10.1.0.5\nip host dut-blue 10.1.0.9 10.1.0.13\nip host r1 10.0.0.11 10.1.0.2 2001:db8:1:b::1\nip host r2 10.0.0.12 10.1.0.6 2001:db8:1:c::1\nip host r3 10.0.0.23 10.1.0.10 2001:db8:1:17::1\nip host r4 10.0.0.24 10.1.0.14 2001:db8:1:18::1\n!\nip routing\n!\nipv6 unicast-routing\n!\nvrf definition red\n rd 65000:1\n route-target import 65000:1\n route-target export 65000:1\n!\n address-family ipv4\n exit-address-family\n!\nvrf definition blue\n rd 65000:2\n route-target import 65000:2\n route-target export 65000:2\n!\n address-family ipv4\n exit-address-family\n!\n\n!\n!\ninterface Loopback0\n ip address 10.0.0.1 255.255.255.255\n ipv6 address 2001:DB8:1:1::1/64\n!\ninterface Ethernet0/0\n no lldp transmit\n no lldp receive\n!\ninterface Ethernet0/1\n vrf forwarding red\n description dut -> r1 [external]\n ip address 10.1.0.1 255.255.255.252\n no shutdown\n!\ninterface Ethernet0/2\n vrf forwarding red\n description dut -> r2 [external]\n ip address 10.1.0.5 255.255.255.252\n no shutdown\n!\ninterface Ethernet0/3\n vrf forwarding blue\n description dut -> r3 [external]\n ip address 10.1.0.9 255.255.255.252\n no shutdown\n!\ninterface Ethernet1/0\n vrf forwarding blue\n description dut -> r4 [external]\n ip address 10.1.0.13 255.255.255.252\n no shutdown\n!\n!\nline vty 0 4\n exec-timeout 0 0 \n!\nno banner exec\nno banner login\nno banner incoming\n" } TASK [Deploy initial configuration] ******************************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/ios.yml for dut TASK [ios_config: deploying initial from /work/netlab_cicd/node_files/dut/initial] *** changed: [dut] PLAY [Deploy module-specific configurations] *********************************** TASK [Set variables that cannot be set with VARS] ****************************** ok: [r2] ok: [r3] ok: [r1] ok: [dut] ok: [r4] TASK [Deploy individual configuration modules] ********************************* included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r1 => (item=bgp) included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r1 => (item=vrf) included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r2 => (item=bgp) included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r2 => (item=vrf) included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r3 => (item=bgp) included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r3 => (item=vrf) included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r4 => (item=bgp) included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for r4 => (item=vrf) included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for dut => (item=bgp) included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for dut => (item=vrf) TASK [Figure out whether to deploy the module bgp on current device] *********** ok: [r1] TASK [Find configuration template for bgp] ************************************* ok: [r1] TASK [fail] ******************************************************************** skipping: [r1] TASK [Find configuration deployment deploy_script for bgp] ********************* ok: [r1] TASK [Print deployed configuration when running in verbose mode] *************** ok: [r1] => { "msg": "bgp configuration for r1\n=========================================\n!\n!\nrouter bgp 65101\n bgp advertise-inactive\n bgp log-neighbor-changes\n no bgp default ipv4-unicast\n no bgp default ipv6-unicast\n router-id 10.0.0.11\n!\n neighbor 10.1.0.1 remote-as 65000\n neighbor 10.1.0.1 description dut\n neighbor 10.1.0.1 send-community standard large \n!\n!\n address-family ipv4\n\n!\n!\n! Originate networks from connected subnets\n!\n network 10.0.0.11/32\n!\n!\n neighbor 10.1.0.1 activate\n neighbor 10.1.0.1 next-hop-self\n!\n address-family ipv6\n\n!\n!\n! Originate networks from connected subnets\n!\n network 2001:db8:1:b::/64\n!\n!\n!\n" } TASK [Deploy bgp configuration] ************************************************ included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r1 TASK [eos_config: deploying bgp from /work/netlab_cicd/node_files/r1/bgp] ****** changed: [r1] TASK [Figure out whether to deploy the module vrf on current device] *********** ok: [r1] TASK [Find configuration template for vrf] ************************************* skipping: [r1] TASK [fail] ******************************************************************** skipping: [r1] TASK [Find configuration deployment deploy_script for vrf] ********************* skipping: [r1] TASK [Print deployed configuration when running in verbose mode] *************** skipping: [r1] TASK [Deploy vrf configuration] ************************************************ skipping: [r1] TASK [Figure out whether to deploy the module bgp on current device] *********** ok: [r2] TASK [Find configuration template for bgp] ************************************* ok: [r2] TASK [fail] ******************************************************************** skipping: [r2] TASK [Find configuration deployment deploy_script for bgp] ********************* ok: [r2] TASK [Print deployed configuration when running in verbose mode] *************** ok: [r2] => { "msg": "bgp configuration for r2\n=========================================\n!\n!\nrouter bgp 65102\n bgp advertise-inactive\n bgp log-neighbor-changes\n no bgp default ipv4-unicast\n no bgp default ipv6-unicast\n router-id 10.0.0.12\n!\n neighbor 10.1.0.5 remote-as 65000\n neighbor 10.1.0.5 description dut\n neighbor 10.1.0.5 send-community standard large \n!\n!\n address-family ipv4\n\n!\n!\n! Originate networks from connected subnets\n!\n network 10.0.0.12/32\n!\n!\n neighbor 10.1.0.5 activate\n neighbor 10.1.0.5 next-hop-self\n!\n address-family ipv6\n\n!\n!\n! Originate networks from connected subnets\n!\n network 2001:db8:1:c::/64\n!\n!\n!\n" } TASK [Deploy bgp configuration] ************************************************ included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r2 TASK [eos_config: deploying bgp from /work/netlab_cicd/node_files/r2/bgp] ****** changed: [r2] TASK [Figure out whether to deploy the module vrf on current device] *********** ok: [r2] TASK [Find configuration template for vrf] ************************************* skipping: [r2] TASK [fail] ******************************************************************** skipping: [r2] TASK [Find configuration deployment deploy_script for vrf] ********************* skipping: [r2] TASK [Print deployed configuration when running in verbose mode] *************** skipping: [r2] TASK [Deploy vrf configuration] ************************************************ skipping: [r2] TASK [Figure out whether to deploy the module bgp on current device] *********** ok: [r3] TASK [Find configuration template for bgp] ************************************* ok: [r3] TASK [fail] ******************************************************************** skipping: [r3] TASK [Find configuration deployment deploy_script for bgp] ********************* ok: [r3] TASK [Print deployed configuration when running in verbose mode] *************** ok: [r3] => { "msg": "bgp configuration for r3\n=========================================\n!\n!\nrouter bgp 65103\n bgp advertise-inactive\n bgp log-neighbor-changes\n no bgp default ipv4-unicast\n no bgp default ipv6-unicast\n router-id 10.0.0.23\n!\n neighbor 10.1.0.9 remote-as 65000\n neighbor 10.1.0.9 description dut\n neighbor 10.1.0.9 send-community standard large \n!\n!\n address-family ipv4\n\n!\n!\n! Originate networks from connected subnets\n!\n network 10.0.0.23/32\n!\n!\n neighbor 10.1.0.9 activate\n neighbor 10.1.0.9 next-hop-self\n!\n address-family ipv6\n\n!\n!\n! Originate networks from connected subnets\n!\n network 2001:db8:1:17::/64\n!\n!\n!\n" } TASK [Deploy bgp configuration] ************************************************ included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r3 TASK [eos_config: deploying bgp from /work/netlab_cicd/node_files/r3/bgp] ****** changed: [r3] TASK [Figure out whether to deploy the module vrf on current device] *********** ok: [r3] TASK [Find configuration template for vrf] ************************************* skipping: [r3] TASK [fail] ******************************************************************** skipping: [r3] TASK [Find configuration deployment deploy_script for vrf] ********************* skipping: [r3] TASK [Print deployed configuration when running in verbose mode] *************** skipping: [r3] TASK [Deploy vrf configuration] ************************************************ skipping: [r3] TASK [Figure out whether to deploy the module bgp on current device] *********** ok: [r4] TASK [Find configuration template for bgp] ************************************* ok: [r4] TASK [fail] ******************************************************************** skipping: [r4] TASK [Find configuration deployment deploy_script for bgp] ********************* ok: [r4] TASK [Print deployed configuration when running in verbose mode] *************** ok: [r4] => { "msg": "bgp configuration for r4\n=========================================\n!\n!\nrouter bgp 65104\n bgp advertise-inactive\n bgp log-neighbor-changes\n no bgp default ipv4-unicast\n no bgp default ipv6-unicast\n router-id 10.0.0.24\n!\n neighbor 10.1.0.13 remote-as 65000\n neighbor 10.1.0.13 description dut\n neighbor 10.1.0.13 send-community standard large \n!\n!\n address-family ipv4\n\n!\n!\n! Originate networks from connected subnets\n!\n network 10.0.0.24/32\n!\n!\n neighbor 10.1.0.13 activate\n neighbor 10.1.0.13 next-hop-self\n!\n address-family ipv6\n\n!\n!\n! Originate networks from connected subnets\n!\n network 2001:db8:1:18::/64\n!\n!\n!\n" } TASK [Deploy bgp configuration] ************************************************ included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r4 TASK [eos_config: deploying bgp from /work/netlab_cicd/node_files/r4/bgp] ****** changed: [r4] TASK [Figure out whether to deploy the module vrf on current device] *********** ok: [r4] TASK [Find configuration template for vrf] ************************************* skipping: [r4] TASK [fail] ******************************************************************** skipping: [r4] TASK [Find configuration deployment deploy_script for vrf] ********************* skipping: [r4] TASK [Print deployed configuration when running in verbose mode] *************** skipping: [r4] TASK [Deploy vrf configuration] ************************************************ skipping: [r4] TASK [Figure out whether to deploy the module bgp on current device] *********** ok: [dut] TASK [Find configuration template for bgp] ************************************* ok: [dut] TASK [fail] ******************************************************************** skipping: [dut] TASK [Find configuration deployment deploy_script for bgp] ********************* ok: [dut] TASK [Print deployed configuration when running in verbose mode] *************** ok: [dut] => { "msg": "bgp configuration for dut\n=========================================\n!\nip bgp-community new-format\n!\nrouter bgp 65000\n no bgp default ipv4-unicast\n bgp update-delay 5\n bgp nopeerup-delay cold-boot 1\n bgp nopeerup-delay user-initiated 1\n bgp router-id 10.0.0.1\n!\n address-family ipv4\n bgp scan-time 5\n!\n!\n! Originate networks from connected subnets\n!\n network 10.0.0.1 mask 255.255.255.255\n\n!\n address-family ipv6\n bgp scan-time 5\n!\n!\n! Originate networks from connected subnets\n!\n network 2001:db8:1:1::/64\n\n!\n!\n" } TASK [Deploy bgp configuration] ************************************************ included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/ios.yml for dut TASK [ios_config: deploying bgp from /work/netlab_cicd/node_files/dut/bgp] ***** changed: [dut] TASK [Figure out whether to deploy the module vrf on current device] *********** ok: [dut] TASK [Find configuration template for vrf] ************************************* ok: [dut] TASK [fail] ******************************************************************** skipping: [dut] TASK [Find configuration deployment deploy_script for vrf] ********************* ok: [dut] TASK [Print deployed configuration when running in verbose mode] *************** ok: [dut] => { "msg": "vrf configuration for dut\n=========================================\n!\nrouter bgp 65000\n address-family ipv4 vrf red\n bgp router-id 10.0.0.1\n redistribute connected\n\n!\n!\n neighbor 10.1.0.2 remote-as 65101\n neighbor 10.1.0.2 description r1\n\n neighbor 10.1.0.2 activate\n neighbor 10.1.0.2 advertisement-interval 0\n neighbor 10.1.0.2 send-community standard\n\n neighbor 10.1.0.6 remote-as 65102\n neighbor 10.1.0.6 description r2\n\n neighbor 10.1.0.6 activate\n neighbor 10.1.0.6 advertisement-interval 0\n neighbor 10.1.0.6 send-community standard\n\n address-family ipv4 vrf blue\n bgp router-id 10.0.0.1\n redistribute connected\n\n!\n!\n neighbor 10.1.0.10 remote-as 65103\n neighbor 10.1.0.10 description r3\n\n neighbor 10.1.0.10 activate\n neighbor 10.1.0.10 advertisement-interval 0\n neighbor 10.1.0.10 send-community standard\n\n neighbor 10.1.0.14 remote-as 65104\n neighbor 10.1.0.14 description r4\n\n neighbor 10.1.0.14 activate\n neighbor 10.1.0.14 advertisement-interval 0\n neighbor 10.1.0.14 send-community standard\n\n" } TASK [Deploy vrf configuration] ************************************************ included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/ios.yml for dut TASK [ios_config: deploying vrf from /work/netlab_cicd/node_files/dut/vrf] ***** changed: [dut] PLAY [Deploy custom deployment templates] ************************************** TASK [Run custom configuration deployment scripts] ***************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-custom-config.yml for r1, r2, r3, r4 => (item=bgp-xact) TASK [Find configuration template] ********************************************* ok: [r1] ok: [r2] ok: [r3] ok: [r4] TASK [fail] ******************************************************************** skipping: [r1] skipping: [r2] skipping: [r3] skipping: [r4] TASK [Check is the configuration template is a file] *************************** ok: [r1 -> localhost] ok: [r2 -> localhost] ok: [r4 -> localhost] ok: [r3 -> localhost] TASK [fail] ******************************************************************** skipping: [r1] skipping: [r2] skipping: [r3] skipping: [r4] TASK [Process template /work/netlab_cicd/node_files/r1/bgp-xact for r1] ******** skipping: [r1] skipping: [r2] skipping: [r3] skipping: [r4] TASK [Find custom configuration deployment script] ***************************** ok: [r1] ok: [r2] ok: [r3] ok: [r4] TASK [Run the configuration deployment script] ********************************* included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/eos.yml for r1, r2, r3, r4 TASK [eos_config: deploying bgp-xact from /work/netlab_cicd/node_files/r1/bgp-xact] *** changed: [r3] changed: [r4] changed: [r2] changed: [r1] PLAY RECAP ********************************************************************* dut : ok=32 changed=3 unreachable=0 failed=0 skipped=7 rescued=0 ignored=0 r1 : ok=37 changed=4 unreachable=0 failed=0 skipped=12 rescued=0 ignored=0 r2 : ok=36 changed=4 unreachable=0 failed=0 skipped=12 rescued=0 ignored=0 r3 : ok=36 changed=4 unreachable=0 failed=0 skipped=12 rescued=0 ignored=0 r4 : ok=36 changed=4 unreachable=0 failed=0 skipped=12 rescued=0 ignored=0 Warning: The following warnings were generated during the 'netlab initial' processing Warning: ansible: You're using Ansible version 12.x or higher; netlab might not work correctly [CREATED] r1: normalize,initial,bgp,bgp-xact [CREATED] r2: normalize,initial,bgp,bgp-xact [CREATED] r3: normalize,initial,bgp,bgp-xact [CREATED] r4: normalize,initial,bgp,bgp-xact [CREATED] dut: initial,bgp,vrf The device under test has two VRFs with two interfaces in each VRF. Routers are attached to those interfaces and run BGP with device under test. Assuming the multi-vrf test case succeeded, this one adds BGP routing with CE routers. * r1 and r2 should be able to ping each other * r3 and r4 should be able to ping each other * r1 should not be able to reach r3 The test also checks whether DUT unnecessarily enables IPv6 AF over IPv4 EBGP sessions