
Now that we no longer support py27, we can use the standard library unittest.mock module instead of the third party mock lib. Change-Id: I12e1a2a4a22116cabd09a3b808f871d98e4bd1f2 Signed-off-by: Sean McGinnis <sean.mcginnis@gmail.com>
775 lines
33 KiB
Python
775 lines
33 KiB
Python
# Copyright 2012 OpenStack Foundation.
|
|
# All Rights Reserved
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
#
|
|
|
|
import itertools
|
|
import sys
|
|
from unittest import mock
|
|
|
|
|
|
from neutronclient.neutron.v2_0 import port
|
|
from neutronclient import shell
|
|
from neutronclient.tests.unit import test_cli20
|
|
|
|
|
|
class CLITestV20PortJSON(test_cli20.CLITestV20Base):
|
|
def setUp(self):
|
|
super(CLITestV20PortJSON, self).setUp(plurals={'tags': 'tag'})
|
|
|
|
def test_create_port(self):
|
|
# Create port: netid.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = [netid, '--description', 'DESC']
|
|
position_names = ['network_id']
|
|
position_values = []
|
|
position_values.extend([netid])
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values,
|
|
description='DESC')
|
|
|
|
def test_create_port_extra_dhcp_opts_args(self):
|
|
# Create port: netid --extra_dhcp_opt.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
extra_dhcp_opts = [{'opt_name': 'bootfile-name',
|
|
'opt_value': 'pxelinux.0'},
|
|
{'opt_name': 'tftp-server',
|
|
'opt_value': '123.123.123.123'},
|
|
{'opt_name': 'server-ip-address',
|
|
'opt_value': '123.123.123.45'}]
|
|
args = [netid]
|
|
for dhcp_opt in extra_dhcp_opts:
|
|
args += ['--extra-dhcp-opt',
|
|
('opt_name=%(opt_name)s,opt_value=%(opt_value)s' %
|
|
dhcp_opt)]
|
|
position_names = ['network_id', 'extra_dhcp_opts']
|
|
position_values = [netid, extra_dhcp_opts]
|
|
position_values.extend([netid])
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_extra_dhcp_opts_args_ip_version(self):
|
|
# Create port: netid --extra_dhcp_opt.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
extra_dhcp_opts = [{'opt_name': 'bootfile-name',
|
|
'opt_value': 'pxelinux.0',
|
|
'ip_version': "4"},
|
|
{'opt_name': 'tftp-server',
|
|
'opt_value': '2001:192:168::1',
|
|
'ip_version': "6"},
|
|
{'opt_name': 'server-ip-address',
|
|
'opt_value': '123.123.123.45',
|
|
'ip_version': "4"}]
|
|
args = [netid]
|
|
for dhcp_opt in extra_dhcp_opts:
|
|
args += ['--extra-dhcp-opt',
|
|
('opt_name=%(opt_name)s,opt_value=%(opt_value)s,'
|
|
'ip_version=%(ip_version)s' %
|
|
dhcp_opt)]
|
|
position_names = ['network_id', 'extra_dhcp_opts']
|
|
position_values = [netid, extra_dhcp_opts]
|
|
position_values.extend([netid])
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_full(self):
|
|
# Create port: --mac_address mac --device_id deviceid netid.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = ['--mac_address', 'mac', '--device_id', 'deviceid', netid]
|
|
position_names = ['network_id', 'mac_address', 'device_id']
|
|
position_values = [netid, 'mac', 'deviceid']
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
# Test dashed options
|
|
args = ['--mac-address', 'mac', '--device-id', 'deviceid', netid]
|
|
position_names = ['network_id', 'mac_address', 'device_id']
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_vnic_type_normal(self):
|
|
# Create port: --vnic_type normal netid.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = ['--vnic_type', 'normal', netid]
|
|
position_names = ['binding:vnic_type', 'network_id']
|
|
position_values = ['normal', netid]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
# Test dashed options
|
|
args = ['--vnic-type', 'normal', netid]
|
|
position_names = ['binding:vnic_type', 'network_id']
|
|
position_values = ['normal', netid]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_vnic_type_direct(self):
|
|
# Create port: --vnic_type direct netid.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = ['--vnic_type', 'direct', netid]
|
|
position_names = ['binding:vnic_type', 'network_id']
|
|
position_values = ['direct', netid]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
# Test dashed options
|
|
args = ['--vnic-type', 'direct', netid]
|
|
position_names = ['binding:vnic_type', 'network_id']
|
|
position_values = ['direct', netid]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_vnic_type_direct_physical(self):
|
|
# Create port: --vnic_type direct-physical netid.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = ['--vnic_type', 'direct-physical', netid]
|
|
position_names = ['binding:vnic_type', 'network_id']
|
|
position_values = ['direct-physical', netid]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
# Test dashed options
|
|
args = ['--vnic-type', 'direct-physical', netid]
|
|
position_names = ['binding:vnic_type', 'network_id']
|
|
position_values = ['direct-physical', netid]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_vnic_type_macvtap(self):
|
|
# Create port: --vnic_type macvtap netid.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = ['--vnic_type', 'macvtap', netid]
|
|
position_names = ['binding:vnic_type', 'network_id']
|
|
position_values = ['macvtap', netid]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
# Test dashed options
|
|
args = ['--vnic-type', 'macvtap', netid]
|
|
position_names = ['binding:vnic_type', 'network_id']
|
|
position_values = ['macvtap', netid]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_vnic_type_baremetal(self):
|
|
# Create port: --vnic_type baremetal netid.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = ['--vnic_type', 'baremetal', netid]
|
|
position_names = ['binding:vnic_type', 'network_id']
|
|
position_values = ['baremetal', netid]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
# Test dashed options
|
|
args = ['--vnic-type', 'baremetal', netid]
|
|
position_names = ['binding:vnic_type', 'network_id']
|
|
position_values = ['baremetal', netid]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_with_binding_profile(self):
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = ['--binding_profile', '{"foo":"bar"}', netid]
|
|
position_names = ['binding:profile', 'network_id']
|
|
position_values = [{'foo': 'bar'}, netid]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
# Test dashed options
|
|
args = ['--binding-profile', '{"foo":"bar"}', netid]
|
|
position_names = ['binding:profile', 'network_id']
|
|
position_values = [{'foo': 'bar'}, netid]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_tenant(self):
|
|
# Create port: --tenant_id tenantid netid.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = ['--tenant_id', 'tenantid', netid, ]
|
|
position_names = ['network_id']
|
|
position_values = []
|
|
position_values.extend([netid])
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values,
|
|
tenant_id='tenantid')
|
|
|
|
# Test dashed options
|
|
args = ['--tenant-id', 'tenantid', netid, ]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values,
|
|
tenant_id='tenantid')
|
|
|
|
def test_create_port_tags(self):
|
|
# Create port: netid mac_address device_id --tags a b.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = [netid, '--tags', 'a', 'b']
|
|
position_names = ['network_id']
|
|
position_values = []
|
|
position_values.extend([netid])
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values,
|
|
tags=['a', 'b'])
|
|
|
|
def test_create_port_secgroup(self):
|
|
# Create port: --security-group sg1_id netid.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = ['--security-group', 'sg1_id', netid]
|
|
position_names = ['network_id', 'security_groups']
|
|
position_values = [netid, ['sg1_id']]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_secgroups(self):
|
|
# Create port: <security_groups> netid
|
|
# The <security_groups> are --security-group sg1_id
|
|
# --security-group sg2_id
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = ['--security-group', 'sg1_id',
|
|
'--security-group', 'sg2_id',
|
|
netid]
|
|
position_names = ['network_id', 'security_groups']
|
|
position_values = [netid, ['sg1_id', 'sg2_id']]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_secgroup_off(self):
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = ['--no-security-groups', netid]
|
|
position_names = ['network_id', 'security_groups']
|
|
position_values = [netid, []]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_secgroups_list(self):
|
|
# Create port: netid <security_groups>
|
|
# The <security_groups> are --security-groups list=true sg_id1 sg_id2
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
args = [netid, '--security-groups', 'list=true', 'sg_id1', 'sg_id2']
|
|
position_names = ['network_id', 'security_groups']
|
|
position_values = [netid, ['sg_id1', 'sg_id2']]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_with_qos_policy(self):
|
|
# Create port: --qos-policy mypolicy.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
qos_policy_name = 'mypolicy'
|
|
args = [netid, '--qos-policy', qos_policy_name]
|
|
position_names = ['network_id', 'qos_policy_id']
|
|
position_values = [netid, qos_policy_name]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_with_dns_name(self):
|
|
# Create port: --dns-name my-port.
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
dns_name_name = 'my-port'
|
|
args = [netid, '--dns-name', dns_name_name]
|
|
position_names = ['network_id', 'dns_name']
|
|
position_values = [netid, dns_name_name]
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_with_allowed_address_pair_ipaddr(self):
|
|
# Create port:
|
|
# --allowed-address-pair ip_address=addr0
|
|
# --allowed-address-pair ip_address=addr1
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
pairs = [{'ip_address': '123.123.123.123'},
|
|
{'ip_address': '123.123.123.45'}]
|
|
args = [netid,
|
|
'--allowed-address-pair',
|
|
'ip_address=123.123.123.123',
|
|
'--allowed-address-pair',
|
|
'ip_address=123.123.123.45']
|
|
position_names = ['network_id', 'allowed_address_pairs']
|
|
position_values = [netid, pairs]
|
|
position_values.extend([netid])
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_create_port_with_allowed_address_pair(self):
|
|
# Create port:
|
|
# --allowed-address-pair ip_address=addr0,mac_address=mac0
|
|
# --allowed-address-pair ip_address=addr1,mac_address=mac1
|
|
resource = 'port'
|
|
cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
|
|
name = 'myname'
|
|
myid = 'myid'
|
|
netid = 'netid'
|
|
pairs = [{'ip_address': '123.123.123.123',
|
|
'mac_address': '10:00:00:00:00:00'},
|
|
{'ip_address': '123.123.123.45',
|
|
'mac_address': '10:00:00:00:00:01'}]
|
|
args = [netid,
|
|
'--allowed-address-pair',
|
|
'ip_address=123.123.123.123,mac_address=10:00:00:00:00:00',
|
|
'--allowed-address-pair',
|
|
'ip_address=123.123.123.45,mac_address=10:00:00:00:00:01']
|
|
position_names = ['network_id', 'allowed_address_pairs']
|
|
position_values = [netid, pairs]
|
|
position_values.extend([netid])
|
|
self._test_create_resource(resource, cmd, name, myid, args,
|
|
position_names, position_values)
|
|
|
|
def test_list_ports(self):
|
|
# List ports: -D.
|
|
resources = "ports"
|
|
cmd = port.ListPort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_list_resources(resources, cmd, True)
|
|
|
|
def test_list_ports_pagination(self):
|
|
resources = "ports"
|
|
cmd = port.ListPort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_list_resources_with_pagination(resources, cmd)
|
|
|
|
def test_list_ports_sort(self):
|
|
# list ports:
|
|
# --sort-key name --sort-key id --sort-key asc --sort-key desc
|
|
resources = "ports"
|
|
cmd = port.ListPort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_list_resources(resources, cmd,
|
|
sort_key=["name", "id"],
|
|
sort_dir=["asc", "desc"])
|
|
|
|
def test_list_ports_limit(self):
|
|
# list ports: -P.
|
|
resources = "ports"
|
|
cmd = port.ListPort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_list_resources(resources, cmd, page_size=1000)
|
|
|
|
def test_list_ports_tags(self):
|
|
# List ports: -- --tags a b.
|
|
resources = "ports"
|
|
cmd = port.ListPort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_list_resources(resources, cmd, tags=['a', 'b'])
|
|
|
|
def test_list_ports_detail_tags(self):
|
|
# List ports: -D -- --tags a b.
|
|
resources = "ports"
|
|
cmd = port.ListPort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_list_resources(resources, cmd, detail=True, tags=['a', 'b'])
|
|
|
|
def test_list_ports_fields(self):
|
|
# List ports: --fields a --fields b -- --fields c d.
|
|
resources = "ports"
|
|
cmd = port.ListPort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_list_resources(resources, cmd,
|
|
fields_1=['a', 'b'], fields_2=['c', 'd'])
|
|
|
|
def test_list_ports_with_fixed_ips_in_csv(self):
|
|
# List ports: -f csv.
|
|
resources = "ports"
|
|
cmd = port.ListPort(test_cli20.MyApp(sys.stdout), None)
|
|
fixed_ips = [{"subnet_id": "30422057-d6df-4c90-8314-aefb5e326666",
|
|
"ip_address": "10.0.0.12"},
|
|
{"subnet_id": "30422057-d6df-4c90-8314-aefb5e326666",
|
|
"ip_address": "10.0.0.4"}]
|
|
contents = [{'name': 'name1', 'fixed_ips': fixed_ips}]
|
|
self._test_list_resources(resources, cmd, True,
|
|
response_contents=contents,
|
|
output_format='csv')
|
|
|
|
def _test_list_router_port(self, resources, cmd,
|
|
myid, detail=False, tags=(),
|
|
fields_1=(), fields_2=()):
|
|
reses = {resources: [{'id': 'myid1', },
|
|
{'id': 'myid2', }, ], }
|
|
|
|
resstr = self.client.serialize(reses)
|
|
# url method body
|
|
query = ""
|
|
args = detail and ['-D', ] or []
|
|
|
|
if fields_1:
|
|
for field in fields_1:
|
|
args.append('--fields')
|
|
args.append(field)
|
|
args.append(myid)
|
|
if tags:
|
|
args.append('--')
|
|
args.append("--tag")
|
|
for tag in tags:
|
|
args.append(tag)
|
|
if (not tags) and fields_2:
|
|
args.append('--')
|
|
if fields_2:
|
|
args.append("--fields")
|
|
for field in fields_2:
|
|
args.append(field)
|
|
for field in itertools.chain(fields_1, fields_2):
|
|
if query:
|
|
query += "&fields=" + field
|
|
else:
|
|
query = "fields=" + field
|
|
|
|
for tag in tags:
|
|
if query:
|
|
query += "&tag=" + tag
|
|
else:
|
|
query = "tag=" + tag
|
|
if detail:
|
|
query = query and query + '&verbose=True' or 'verbose=True'
|
|
query = query and query + '&device_id=%s' or 'device_id=%s'
|
|
path = getattr(self.client, resources + "_path")
|
|
with mock.patch.object(cmd, "get_client",
|
|
return_value=self.client) as mock_get_client, \
|
|
mock.patch.object(self.client.httpclient, "request",
|
|
return_value=(test_cli20.MyResp(200),
|
|
resstr)) as mock_request:
|
|
cmd_parser = cmd.get_parser("list_" + resources)
|
|
shell.run_command(cmd, cmd_parser, args)
|
|
|
|
self.assert_mock_multiple_calls_with_same_arguments(
|
|
mock_get_client, mock.call(), 2)
|
|
mock_request.assert_called_once_with(
|
|
test_cli20.MyUrlComparator(
|
|
test_cli20.end_url(path, query % myid), self.client),
|
|
'GET',
|
|
body=None,
|
|
headers=test_cli20.ContainsKeyValue(
|
|
{'X-Auth-Token': test_cli20.TOKEN}))
|
|
_str = self.fake_stdout.make_string()
|
|
|
|
self.assertIn('myid1', _str)
|
|
|
|
def test_list_router_ports(self):
|
|
# List router ports: -D.
|
|
resources = "ports"
|
|
cmd = port.ListRouterPort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_list_router_port(resources, cmd,
|
|
self.test_id, True)
|
|
|
|
def test_list_router_ports_tags(self):
|
|
# List router ports: -- --tags a b.
|
|
resources = "ports"
|
|
cmd = port.ListRouterPort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_list_router_port(resources, cmd,
|
|
self.test_id, tags=['a', 'b'])
|
|
|
|
def test_list_router_ports_detail_tags(self):
|
|
# List router ports: -D -- --tags a b.
|
|
resources = "ports"
|
|
cmd = port.ListRouterPort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_list_router_port(resources, cmd, self.test_id,
|
|
detail=True, tags=['a', 'b'])
|
|
|
|
def test_list_router_ports_fields(self):
|
|
# List ports: --fields a --fields b -- --fields c d.
|
|
resources = "ports"
|
|
cmd = port.ListRouterPort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_list_router_port(resources, cmd, self.test_id,
|
|
fields_1=['a', 'b'],
|
|
fields_2=['c', 'd'])
|
|
|
|
def test_update_port(self):
|
|
# Update port: myid --name myname --admin-state-up False --tags a b.
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_update_resource(resource, cmd, 'myid',
|
|
['myid', '--name', 'myname',
|
|
'--admin-state-up', 'False',
|
|
'--description', 'garbage',
|
|
'--tags', 'a', 'b'],
|
|
{'name': 'myname',
|
|
'admin_state_up': 'False',
|
|
'description': 'garbage',
|
|
'tags': ['a', 'b'], })
|
|
|
|
def test_update_port_secgroup(self):
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
myid = 'myid'
|
|
args = ['--security-group', 'sg1_id', myid]
|
|
updatefields = {'security_groups': ['sg1_id']}
|
|
self._test_update_resource(resource, cmd, myid, args, updatefields)
|
|
|
|
def test_update_port_secgroups(self):
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
myid = 'myid'
|
|
args = ['--security-group', 'sg1_id',
|
|
'--security-group', 'sg2_id',
|
|
myid]
|
|
updatefields = {'security_groups': ['sg1_id', 'sg2_id']}
|
|
self._test_update_resource(resource, cmd, myid, args, updatefields)
|
|
|
|
def test_update_port_extra_dhcp_opts(self):
|
|
# Update port: myid --extra_dhcp_opt.
|
|
resource = 'port'
|
|
myid = 'myid'
|
|
args = [myid,
|
|
'--extra-dhcp-opt',
|
|
"opt_name=bootfile-name,opt_value=pxelinux.0",
|
|
'--extra-dhcp-opt',
|
|
"opt_name=tftp-server,opt_value=123.123.123.123",
|
|
'--extra-dhcp-opt',
|
|
"opt_name=server-ip-address,opt_value=123.123.123.45"
|
|
]
|
|
updatedfields = {'extra_dhcp_opts': [{'opt_name': 'bootfile-name',
|
|
'opt_value': 'pxelinux.0'},
|
|
{'opt_name': 'tftp-server',
|
|
'opt_value': '123.123.123.123'},
|
|
{'opt_name': 'server-ip-address',
|
|
'opt_value': '123.123.123.45'}]}
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_update_resource(resource, cmd, myid, args, updatedfields)
|
|
|
|
def test_update_port_fixed_ip(self):
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
myid = 'myid'
|
|
subnet_id = 'subnet_id'
|
|
ip_addr = '123.123.123.123'
|
|
args = [myid,
|
|
'--fixed-ip',
|
|
"subnet_id=%(subnet_id)s,ip_address=%(ip_addr)s" %
|
|
{'subnet_id': subnet_id,
|
|
'ip_addr': ip_addr}]
|
|
updated_fields = {"fixed_ips": [{'subnet_id': subnet_id,
|
|
'ip_address': ip_addr}]}
|
|
self._test_update_resource(resource, cmd, myid, args, updated_fields)
|
|
|
|
def test_update_port_device_id_device_owner(self):
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
myid = 'myid'
|
|
args = ['--device-id', 'dev_id', '--device-owner', 'fake', myid]
|
|
updatefields = {'device_id': 'dev_id',
|
|
'device_owner': 'fake'}
|
|
self._test_update_resource(resource, cmd, myid, args, updatefields)
|
|
|
|
def test_update_port_extra_dhcp_opts_ip_version(self):
|
|
# Update port: myid --extra_dhcp_opt.
|
|
resource = 'port'
|
|
myid = 'myid'
|
|
args = [myid,
|
|
'--extra-dhcp-opt',
|
|
"opt_name=bootfile-name,opt_value=pxelinux.0,ip_version=4",
|
|
'--extra-dhcp-opt',
|
|
"opt_name=tftp-server,opt_value=2001:192:168::1,ip_version=6",
|
|
'--extra-dhcp-opt',
|
|
"opt_name=server-ip-address,opt_value=null,ip_version=4"
|
|
]
|
|
updatedfields = {'extra_dhcp_opts': [{'opt_name': 'bootfile-name',
|
|
'opt_value': 'pxelinux.0',
|
|
'ip_version': '4'},
|
|
{'opt_name': 'tftp-server',
|
|
'opt_value': '2001:192:168::1',
|
|
'ip_version': '6'},
|
|
{'opt_name': 'server-ip-address',
|
|
'opt_value': None,
|
|
'ip_version': '4'}]}
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_update_resource(resource, cmd, myid, args, updatedfields)
|
|
|
|
def test_update_port_with_qos_policy(self):
|
|
# Update port: myid --qos-policy mypolicy.
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_update_resource(resource, cmd, 'myid',
|
|
['myid', '--qos-policy', 'mypolicy'],
|
|
{'qos_policy_id': 'mypolicy', })
|
|
|
|
def test_update_port_with_no_qos_policy(self):
|
|
# Update port: myid --no-qos-policy.
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_update_resource(resource, cmd, 'myid',
|
|
['myid', '--no-qos-policy'],
|
|
{'qos_policy_id': None, })
|
|
|
|
def test_update_port_with_dns_name(self):
|
|
# Update port: myid --dns-name my-port.
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_update_resource(resource, cmd, 'myid',
|
|
['myid', '--dns-name', 'my-port'],
|
|
{'dns_name': 'my-port', })
|
|
|
|
def test_update_port_with_no_dns_name(self):
|
|
# Update port: myid --no-dns-name
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_update_resource(resource, cmd, 'myid',
|
|
['myid', '--no-dns-name'],
|
|
{'dns_name': "", })
|
|
|
|
def test_delete_extra_dhcp_opts_from_port(self):
|
|
resource = 'port'
|
|
myid = 'myid'
|
|
args = [myid,
|
|
'--extra-dhcp-opt',
|
|
"opt_name=bootfile-name,opt_value=null",
|
|
'--extra-dhcp-opt',
|
|
"opt_name=tftp-server,opt_value=123.123.123.123",
|
|
'--extra-dhcp-opt',
|
|
"opt_name=server-ip-address,opt_value=123.123.123.45"
|
|
]
|
|
# the client code will change the null to None and send to server,
|
|
# where its interpreted as delete the DHCP option on the port.
|
|
updatedfields = {'extra_dhcp_opts': [{'opt_name': 'bootfile-name',
|
|
'opt_value': None},
|
|
{'opt_name': 'tftp-server',
|
|
'opt_value': '123.123.123.123'},
|
|
{'opt_name': 'server-ip-address',
|
|
'opt_value': '123.123.123.45'}]}
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_update_resource(resource, cmd, myid, args, updatedfields)
|
|
|
|
def test_update_port_security_group_off(self):
|
|
# Update port: --no-security-groups myid.
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_update_resource(resource, cmd, 'myid',
|
|
['--no-security-groups', 'myid'],
|
|
{'security_groups': []})
|
|
|
|
def test_update_port_allowed_address_pair_ipaddr(self):
|
|
# Update port(ip_address only):
|
|
# --allowed-address-pairs ip_address=addr0
|
|
# --allowed-address-pairs ip_address=addr1
|
|
import sys
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
myid = 'myid'
|
|
pairs = [{'ip_address': '123.123.123.123'},
|
|
{'ip_address': '123.123.123.45'}]
|
|
args = [myid,
|
|
'--allowed-address-pair',
|
|
'ip_address=123.123.123.123',
|
|
'--allowed-address-pair',
|
|
'ip_address=123.123.123.45']
|
|
updatefields = {'allowed_address_pairs': pairs}
|
|
self._test_update_resource(resource, cmd, myid, args, updatefields)
|
|
|
|
def test_update_port_allowed_address_pair(self):
|
|
# Update port:
|
|
# --allowed-address-pair ip_address=addr0,mac_address=mac0
|
|
# --allowed-address-pair ip_address_addr1,mac_address=mac1
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
myid = 'myid'
|
|
pairs = [{'ip_address': '123.123.123.123',
|
|
'mac_address': '10:00:00:00:00:00'},
|
|
{'ip_address': '123.123.123.45',
|
|
'mac_address': '10:00:00:00:00:01'}]
|
|
args = [myid,
|
|
'--allowed-address-pair',
|
|
'ip_address=123.123.123.123,mac_address=10:00:00:00:00:00',
|
|
'--allowed-address-pair',
|
|
'ip_address=123.123.123.45,mac_address=10:00:00:00:00:01']
|
|
updatefields = {'allowed_address_pairs': pairs}
|
|
self._test_update_resource(resource, cmd, myid, args, updatefields)
|
|
|
|
def test_update_port_allowed_address_pairs_off(self):
|
|
# Update port: --no-allowed-address-pairs.
|
|
resource = 'port'
|
|
cmd = port.UpdatePort(test_cli20.MyApp(sys.stdout), None)
|
|
self._test_update_resource(resource, cmd, 'myid',
|
|
['--no-allowed-address-pairs', 'myid'],
|
|
{'allowed_address_pairs': []})
|
|
|
|
def test_show_port(self):
|
|
# Show port: --fields id --fields name myid.
|
|
resource = 'port'
|
|
cmd = port.ShowPort(test_cli20.MyApp(sys.stdout), None)
|
|
args = ['--fields', 'id', '--fields', 'name', self.test_id]
|
|
self._test_show_resource(resource, cmd, self.test_id,
|
|
args, ['id', 'name'])
|
|
|
|
def test_delete_port(self):
|
|
# Delete port: myid.
|
|
resource = 'port'
|
|
cmd = port.DeletePort(test_cli20.MyApp(sys.stdout), None)
|
|
myid = 'myid'
|
|
args = [myid]
|
|
self._test_delete_resource(resource, cmd, myid, args)
|