| #!/bin/bash |
| set -x |
| function die() { |
| local exitcode=$? |
| set +o xtrace |
| echo $@ |
| cleanup |
| exit $exitcode |
| } |
| |
| net_name=cord-vtn-net1 |
| subnet_name=cord-vtn-subnet1 |
| port_name=cord-vtn-port1 |
| function cleanup() { |
| echo Removing test port, subnet and net... |
| neutron port-delete $port_name |
| neutron subnet-delete $subnet_name |
| neutron net-delete $net_name |
| } |
| |
| noauth_tenant_id=me |
| if [ "$1" == "noauth" ]; then |
| NOAUTH="--tenant_id $noauth_tenant_id" |
| else |
| NOAUTH= |
| fi |
| |
| echo "NOTE: User should be admin in order to perform all operations." |
| sleep 3 |
| |
| # test the CRUD of network |
| network=$net_name |
| neutron net-create $NOAUTH $network || die "fail to create network $network" |
| temp=`neutron net-list -- --name $network --fields id | wc -l` |
| echo $temp |
| if [ $temp -ne 5 ]; then |
| die "networks with name $network is not unique or found" |
| fi |
| network_id=`neutron net-list -- --name $network --fields id | tail -n 2 | head -n 1 | cut -d' ' -f 2` |
| echo "ID of network with name $network is $network_id" |
| |
| neutron net-show $network || die "fail to show network $network" |
| neutron net-show $network_id || die "fail to show network $network_id" |
| |
| neutron net-update $network --admin_state_up False || die "fail to update network $network" |
| neutron net-update $network_id --admin_state_up True || die "fail to update network $network_id" |
| |
| neutron net-list -c id -- --id fakeid || die "fail to list networks with column selection on empty list" |
| |
| # test the CRUD of subnet |
| subnet=$subnet_name |
| cidr=10.0.1.0/24 |
| neutron subnet-create $NOAUTH $network $cidr --name $subnet || die "fail to create subnet $subnet" |
| tempsubnet=`neutron subnet-list -- --name $subnet --fields id | wc -l` |
| echo $tempsubnet |
| if [ $tempsubnet -ne 5 ]; then |
| die "subnets with name $subnet is not unique or found" |
| fi |
| subnet_id=`neutron subnet-list -- --name $subnet --fields id | tail -n 2 | head -n 1 | cut -d' ' -f 2` |
| echo "ID of subnet with name $subnet is $subnet_id" |
| neutron subnet-show $subnet || die "fail to show subnet $subnet" |
| neutron subnet-show $subnet_id || die "fail to show subnet $subnet_id" |
| |
| neutron subnet-update $subnet --dns_nameservers list=true 1.1.1.11 1.1.1.12 || die "fail to update subnet $subnet" |
| neutron subnet-update $subnet_id --dns_nameservers list=true 2.2.2.21 2.2.2.22 || die "fail to update subnet $subnet_id" |
| |
| # test the crud of ports |
| port=$port_name |
| neutron port-create $NOAUTH $network --name $port || die "fail to create port $port" |
| tempport=`neutron port-list -- --name $port --fields id | wc -l` |
| echo $tempport |
| if [ $tempport -ne 5 ]; then |
| die "ports with name $port is not unique or found" |
| fi |
| port_id=`neutron port-list -- --name $port --fields id | tail -n 2 | head -n 1 | cut -d' ' -f 2` |
| echo "ID of port with name $port is $port_id" |
| neutron port-show $port || die "fail to show port $port" |
| neutron port-show $port_id || die "fail to show port $port_id" |
| neutron port-update $port --device_id deviceid1 || die "fail to update port $port" |
| neutron port-update $port_id --device_id deviceid2 || die "fail to update port $port_id" |
| neutron port-update $port_id --allowed-address-pair ip_address=1.1.1.11,mac_address=10:00:00:00:00:00 --allowed-address-pair ip_address=1.1.1.12,mac_address=10:00:00:00:00:01 || die "fail to update port $port_id --allowed-address-pair" |
| neutron port-show $port || die "fail to show port $port" |
| neutron port-show $port_id || die "fail to show port $port_id" |
| neutron port-update $port_id --no-allowed-address-pairs || die "fail to update port $port_id --no-allowed-address-pairs" |
| neutron port-show $port || die "fail to show port $port" |
| neutron port-show $port_id || die "fail to show port $port_id" |
| neutron port-delete $port_id |
| |
| # test the create port with allowed-address-pairs |
| port=$port_name |
| neutron port-create $NOAUTH $network --name $port -- --allowed-address-pairs type=dict list=true ip_address=1.1.1.11,mac_address=10:00:00:00:00:00 ip_address=1.1.1.12,mac_address=10:00:00:00:00:01 || die "fail to create port $port" |
| tempport=`neutron port-list -- --name $port --fields id | wc -l` |
| echo $tempport |
| if [ $tempport -ne 5 ]; then |
| die "ports with name $port is not unique or found" |
| fi |
| port_id=`neutron port-list -- --name $port --fields id | tail -n 2 | head -n 1 | cut -d' ' -f 2` |
| echo "ID of port with name $port is $port_id" |
| neutron port-show $port || die "fail to show port $port" |
| neutron port-show $port_id || die "fail to show port $port_id" |
| neutron port-update $port_id --no-allowed-address-pairs || die "fail to update port $port_id --no-allowed-address-pairs" |
| neutron port-show $port_id |
| |
| # test quota commands RUD |
| DEFAULT_NETWORKS=10 |
| DEFAULT_PORTS=50 |
| tenant_id=tenant_a |
| tenant_id_b=tenant_b |
| neutron quota-update --tenant_id $tenant_id --network 30 || die "fail to update quota for tenant $tenant_id" |
| neutron quota-update --tenant_id $tenant_id_b --network 20 || die "fail to update quota for tenant $tenant_id" |
| networks=`neutron quota-list -c network -c tenant_id | grep $tenant_id | awk '{print $2}'` |
| if [ $networks -ne 30 ]; then |
| die "networks quota should be 30" |
| fi |
| networks=`neutron quota-list -c network -c tenant_id | grep $tenant_id_b | awk '{print $2}'` |
| if [ $networks -ne 20 ]; then |
| die "networks quota should be 20" |
| fi |
| networks=`neutron quota-show --tenant_id $tenant_id | grep network | awk -F'|' '{print $3}'` |
| if [ $networks -ne 30 ]; then |
| die "networks quota should be 30" |
| fi |
| neutron quota-delete --tenant_id $tenant_id || die "fail to delete quota for tenant $tenant_id" |
| networks=`neutron quota-show --tenant_id $tenant_id | grep network | awk -F'|' '{print $3}'` |
| if [ $networks -ne $DEFAULT_NETWORKS ]; then |
| die "networks quota should be $DEFAULT_NETWORKS" |
| fi |
| # update self |
| if [ "t$NOAUTH" = "t" ]; then |
| # with auth |
| neutron quota-update --port 99 || die "fail to update quota for self" |
| ports=`neutron quota-show | grep port | awk -F'|' '{print $3}'` |
| if [ $ports -ne 99 ]; then |
| die "ports quota should be 99" |
| fi |
| |
| ports=`neutron quota-list -c port | grep 99 | awk '{print $2}'` |
| if [ $ports -ne 99 ]; then |
| die "ports quota should be 99" |
| fi |
| neutron quota-delete || die "fail to delete quota for tenant self" |
| ports=`neutron quota-show | grep port | awk -F'|' '{print $3}'` |
| if [ $ports -ne $DEFAULT_PORTS ]; then |
| die "ports quota should be $DEFAULT_PORTS" |
| fi |
| else |
| # without auth |
| neutron quota-update --port 100 |
| if [ $? -eq 0 ]; then |
| die "without valid context on server, quota update command should fail." |
| fi |
| neutron quota-show |
| if [ $? -eq 0 ]; then |
| die "without valid context on server, quota show command should fail." |
| fi |
| neutron quota-delete |
| if [ $? -eq 0 ]; then |
| die "without valid context on server, quota delete command should fail." |
| fi |
| neutron quota-list || die "fail to update quota for self" |
| fi |
| |
| cleanup |
| echo "Success! :)" |
| |