testbed-cli.sh
is the command line to setup/teardown the testbed, as well as add/remove/switch topology.
- Maintenance purposes only
./testbed-cli.sh start-vms {server_name} ~./password
# after a server restarted./testbed-cli.sh stop-vms {server_name} ~./password
# before a server restarted
- General usage
./testbed-cli.sh add-topo {topo_name} ~./password
# create topo with name {topo_name} from testbed.csv./testbed-cli.sh remove-topo {topo_name} ~./password
# destroy topo with name {topo_name} from testbed.csv./testbed-cli.sh renumber-topo {topo_name} ~./password
# renumber topo with name {topo_name} from testbed.csv
# conf-name,group-name,topo,ptf_image_name,ptf,ptf_ip,ptf_ipv6,server,vm_base,dut,inv_name,auto_recover,comment
vms1-1-t1,vms1-1,t1,docker-ptf,ptf-1,10.0.10.5/23,,server_1,VM0100,str-msn2700-11,lab,True,t1 tests
vms1-1-t1-lag,vms1-1,t1-lag,docker-ptf,ptf-2,10.0.10.5/23,,server_1,VM0100,str-msn2700-11,lab,False,t1-lag tests
Goal is to use one VM with different topologies
-
To add a new testbed “vms1-1-t1”:
- ./testbed-cli add-topo vms1-1-t1 ~/.password
-
To switch from testbed “vms1-1-t1” to testbed “vms1-1-lag”
- ./testbed-cli remove-topo vms1-1-t1 ~/.password
- ./testbed-cli add-topo vms1-1-t1-lag ~/.password
Feature: The VMs configuration will be updated while switching from one topo to another Feature: Might be used for renumbering too Caveat: Have to remember what was the initial topology. Should be fixed in future
# conf-name,group-name,topo,ptf_image_name,ptf,ptf_ip,ptf_ipv6,server,vm_base,dut,comment
vms2-2-b,vms2-2,t1,docker-ptf,ptf-1,10.0.10.7/23,,server_1,VM0100,str-d6000-05,brcm test
vms2-2-m,vms2-2,t1,docker-ptf,ptf-2,10.0.10.7/23,,server_1,VM0100,str-msn2700-5,mlnx test
Goal is to use one VM set against different DUTs
-
To add a new testbed “vms2-2-b”:
- ./testbed-cli add-topo vms2-2-b ~/.password
-
To switch from testbed “vms2-2-b” to testbed “vms2-2-m”
- ./testbed-cli renumber-topo vms2-2-m ~/.password
Feature: The VMs configuration will NOT be updated while switching from one topo to another (faster).
TODO: check topo field when renumbering between topologies
# conf-name,group-name,topo,ptf_image_name,ptf,ptf_ip,ptf_ipv6,server,vm_base,dut,comment
example-ixia,vms6-1,t0-64,docker-keysight-api-server,example-ixia-ptf-1,10.0.0.30/32,,server_1,,example-s6100-dut-1,Test with Keysight API Server
-
To add a new testbed “example-ixia”:
- ./testbed-cli add-topo example-ixia ~/.password
-
To remove a Keysight API server docker container
- ./testbed-cli remove-topo example-ixia ~/.password remove_keysight_api_server
-
If remove_keysight_api_server is not used in the arguments then the Keysight API server docker container will not be removed
- ./testbed-cli remove-topo example-ixia ~/.password
Note that it's mandatory to name the image "docker-keysight-api-server", as that triggers the Ixia IxNetwork API server deployment. Much like the PTF docker image, this image will be pulled from the configured docker registry.
Also, topologies with the Keysight API server will not be using any VMs.
Keysight API server can be accessed using the ptf_ip
from the testbed file. Since the api-server is not deployed again if already running one should use the original pft_ip
to access it across the ixia-testbeds.
The most recent IxNetwork API Server docker image can be found here. See also the Ixia software download page for any newer versions.