Creating Device configuration snippets [CREATED] h1: initial,routing [CREATED] h2: initial,routing [CREATED] h3: initial,routing [CREATED] h4: initial,routing [CREATED] s1: initial,vlan Checking Are lab devices ready to be configured? [INFO] Checking lab devices with an Ansible playbook [WARNING]: Could not match supplied host pattern, ignoring: netlab_ready_ssh [WARNING]: Found variable using reserved name: hosts PLAY [Wait for SSH servers] **************************************************** skipping: no hosts matched PLAY [Wait for device-specific conditions] ************************************* TASK [Set variables that cannot be set with VARS] ****************************** ok: [s1] TASK [Find device readiness script] ******************************************** ok: [s1] TASK [Wait for device to become ready] ***************************************** included: /home/pipi/net101/tools/netsim/ansible/tasks/readiness-check/junos.yml for s1 TASK [set_fact] **************************************************************** ok: [s1] TASK [Wait for first interface (et-0/0/0)] ************************************* ok: [s1] PLAY RECAP ********************************************************************* s1 : ok=5 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0 Config Deploying device configurations [INFO] Executing initial configuration for node h1 (namespace clab- ml-85-h1) [INFO] Executing initial configuration for node h2 (namespace clab- ml-85-h2) [INFO] Executing initial configuration for node h3 (namespace clab- ml-85-h3) [INFO] Executing initial configuration for node h4 (namespace clab- ml-85-h4) [INFO] Executing routing configuration for node h1 (namespace clab- ml-85-h1) [INFO] Executing routing configuration for node h2 (namespace clab- ml-85-h2) [INFO] Executing routing configuration for node h4 (namespace clab- ml-85-h4) [INFO] Executing routing configuration for node h3 (namespace clab- ml-85-h3) [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/net101/tools/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/net101/tools/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=========================================\nsystem {\n host-name s1;\n static-host-mapping {\n h1 inet 172.16.0.1;\n h2 inet 172.16.0.2;\n h3 inet 172.16.1.3;\n h4 inet 172.16.2.4;\n }\n}\n\n\ninterfaces {\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n}\ninterfaces {\n\n lo0.0 {\n \n family inet {\n address 10.0.0.5/32;\n }\n \n }\n et-0/0/0.0 {\n description \"[Access VLAN red] s1 -> h1\";\n \n \n }\n et-0/0/1.0 {\n description \"[Access VLAN red] s1 -> h2\";\n \n \n }\n et-0/0/2.0 {\n description \"[Access VLAN blue] s1 -> h3\";\n \n \n }\n et-0/0/3.0 {\n description \"[Access VLAN green] s1 -> h4\";\n \n \n }\n irb.700 {\n description \"VLAN red (700) -> [h1,h2] [stub]\";\n \n \n }\n irb.701 {\n description \"VLAN blue (701) -> [h3] [stub]\";\n \n family inet {\n address 172.16.1.5/24;\n }\n \n }\n irb.702 {\n description \"VLAN green (702) -> [h4] [stub]\";\n \n family inet {\n address 172.16.2.5/24;\n }\n \n }\n}\nprotocols {\n lldp {\n interface re0:mgmt-0 {\n disable;\n }\n interface all;\n }\n}\n" } TASK [Deploy initial configuration] ******************************************** included: /home/pipi/net101/tools/netsim/ansible/tasks/deploy-config/junos.yml for s1 TASK [junos_config: deploying initial from /work/netlab_cicd/other_vm/node_files/s1/initial] *** [WARNING]: mgd: statement has no contents; ignored 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/net101/tools/netsim/ansible/tasks/deploy-module.yml for s1 => (item=vlan) included: /home/pipi/net101/tools/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=========================================\nvlans {\n red {\n vlan-id 700;\n\n\n }\n blue {\n vlan-id 701;\n\n l3-interface irb.701;\n\n }\n green {\n vlan-id 702;\n\n l3-interface irb.702;\n\n }\n}\n\ninterfaces {\n\n\n et-0/0/0.0 {\n family ethernet-switching {\n\n vlan {\n members red;\n }\n\n }\n }\n\n\n\n et-0/0/1.0 {\n family ethernet-switching {\n\n vlan {\n members red;\n }\n\n }\n }\n\n\n\n et-0/0/2.0 {\n family ethernet-switching {\n\n vlan {\n members blue;\n }\n\n }\n }\n\n\n\n et-0/0/3.0 {\n family ethernet-switching {\n\n vlan {\n members green;\n }\n\n }\n }\n\n\n}\n" } TASK [Deploy vlan configuration] *********************************************** included: /home/pipi/net101/tools/netsim/ansible/tasks/deploy-config/junos.yml for s1 TASK [junos_config: deploying vlan from /work/netlab_cicd/other_vm/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 The device under test is a mixed layer-2/layer-3 switch. Red VLAN is a layer-2-only VLAN, the device acts as a L2/L3 switch on all other VLANs h1 and h2 should be able to ping each other, but not h3 or h4 h3 and h4 should be able to ping each other, but not h1 or h2