Creating Device configuration snippets [CREATED] h1: initial,routing [CREATED] h2: initial,routing [CREATED] h3: initial,routing [CREATED] h4: initial,routing [CREATED] s1: initial,vlan [CREATED] s2: normalize,initial,vlan Checking Are lab devices ready to be configured? [INFO] Checking SSH server(s) on s1,s2 Config Deploying device configurations [INFO] Executing initial configuration for node h1 (namespace clab- ml-84-h1) [INFO] Executing initial configuration for node h2 (namespace clab- ml-84-h2) [INFO] Executing initial configuration for node h3 (namespace clab- ml-84-h3) [INFO] Executing initial configuration for node h4 (namespace clab- ml-84-h4) [INFO] Executing normalize configuration for node s2 [INFO] Executing routing configuration for node h1 (namespace clab- ml-84-h1) [INFO] Executing routing configuration for node h3 (namespace clab- ml-84-h3) [INFO] Executing routing configuration for node h2 (namespace clab- ml-84-h2) [INFO] Executing routing configuration for node h4 (namespace clab- ml-84-h4) [INFO] Executing initial configuration for node s2 [INFO] Executing vlan configuration for node s2 [INFO] Starting Ansible playbook to deploy the rest of the configurations [WARNING]: Found variable using reserved name: hosts PLAY [Deploy initial device configuration] ************************************* TASK [Set variables that cannot be set with VARS] ****************************** ok: [s1] TASK [Normalize config on bridge-like devices] ********************************* included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for s1 TASK [Figure out whether to deploy the module normalize on current device] ***** ok: [s1] TASK [Find configuration template for normalize] ******************************* ok: [s1] TASK [fail] ******************************************************************** skipping: [s1] TASK [Find configuration deployment deploy_script for normalize] *************** ok: [s1] TASK [Print deployed configuration when running in verbose mode] *************** skipping: [s1] TASK [Deploy normalize configuration] ****************************************** skipping: [s1] TASK [Deploy initial configuration] ******************************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for s1 TASK [Figure out whether to deploy the module initial on current device] ******* ok: [s1] TASK [Find configuration template for initial] ********************************* ok: [s1] TASK [fail] ******************************************************************** skipping: [s1] TASK [Find configuration deployment deploy_script for initial] ***************** ok: [s1] TASK [Print deployed configuration when running in verbose mode] *************** ok: [s1] => { "msg": "initial configuration for s1\n=========================================\nhostname s1\n!\nno ip domain lookup\nlogging buffered 256000\n\n!\nlldp run\n!\nip host h1 172.16.0.1\nip host h2 172.16.0.2\nip host h3 172.16.1.3\nip host h4 172.16.1.4\nip host s2 10.0.0.6\n!\nip routing\n!\nno ipv6 unicast-routing\n!\n!\nbridge irb\n!\nbridge 1 protocol vlan-bridge\nbridge 1 route ip\n!\nbridge 2 protocol vlan-bridge\nbridge 2 route ip\n!\n\n!\n!\ninterface Loopback0\n ip address 10.0.0.5 255.255.255.255\n!\ninterface Ethernet0/0\n no lldp transmit\n no lldp receive\n!\ninterface Ethernet0/1\n description s1 -> s2\n no shutdown\n!\ninterface Ethernet0/2\n description [Access VLAN red] s1 -> h1\n no shutdown\n!\ninterface Ethernet0/3\n description [Access VLAN blue] s1 -> h3\n no shutdown\n!\ninterface BDI700\n description VLAN red (700) -> [h1,h2,s2]\n ip address 172.16.0.5 255.255.255.0\n no shutdown\n!\ninterface BDI701\n description VLAN blue (701) -> [h3,h4,s2]\n ip address 172.16.1.5 255.255.255.0\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 s1 TASK [ios_config: deploying initial from /work/netlab_cicd/cisco_c/node_files/s1/initial] *** [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 changed: [s1] PLAY [Deploy module-specific configurations] *********************************** TASK [Set variables that cannot be set with VARS] ****************************** ok: [s1] TASK [Deploy individual configuration modules] ********************************* included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for s1 => (item=vlan) included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-module.yml for s1 => (item=routing) TASK [Figure out whether to deploy the module vlan on current device] ********** ok: [s1] TASK [Find configuration template for vlan] ************************************ ok: [s1] TASK [fail] ******************************************************************** skipping: [s1] TASK [Find configuration deployment deploy_script for vlan] ******************** ok: [s1] TASK [Print deployed configuration when running in verbose mode] *************** ok: [s1] => { "msg": "vlan configuration for s1\n=========================================\n!\nbridge-domain 700\n member Ethernet0/1 service-instance 700\n member Ethernet0/2 service-instance 700\n!\nbridge-domain 701\n member Ethernet0/1 service-instance 701\n member Ethernet0/3 service-instance 701\n!\ninterface Ethernet0/1\n service instance 700 ethernet\n encapsulation dot1q 700\n rewrite ingress tag pop 1\n rewrite egress tag push dot1q 700\n service instance 701 ethernet\n encapsulation dot1q 701\n rewrite ingress tag pop 1\n rewrite egress tag push dot1q 701\n!\ninterface Ethernet0/2\n service instance 700 ethernet\n encapsulation untagged\n!\ninterface Ethernet0/3\n service instance 701 ethernet\n encapsulation untagged\n" } TASK [Deploy vlan configuration] *********************************************** included: /home/pipi/netlab_gh/netsim/ansible/tasks/deploy-config/ios.yml for s1 TASK [ios_config: deploying vlan from /work/netlab_cicd/cisco_c/node_files/s1/vlan] *** changed: [s1] TASK [Figure out whether to deploy the module routing on current device] ******* ok: [s1] TASK [Find configuration template for routing] ********************************* skipping: [s1] TASK [fail] ******************************************************************** skipping: [s1] TASK [Find configuration deployment deploy_script for routing] ***************** skipping: [s1] TASK [Print deployed configuration when running in verbose mode] *************** skipping: [s1] TASK [Deploy routing configuration] ******************************************** skipping: [s1] PLAY [Deploy custom deployment templates] ************************************** skipping: no hosts matched PLAY RECAP ********************************************************************* s1 : ok=22 changed=2 unreachable=0 failed=0 skipped=10 rescued=0 ignored=0 Results of configuration script deployments ================================================================================ h1 Script: initial,routing h2 Script: initial,routing h3 Script: initial,routing h4 Script: initial,routing s2 Script: normalize,initial,vlan The devices under test are layer-3 switches bridging between ports in the same VLAN and routing across VLANs * All hosts should be able to ping each other and switch interfaces in the same VLAN * Hosts should be able to ping loopback address of the adjacent switch (static routes point to nearest router) Please note it might take a while for the lab to work due to STP learning phase