summaryrefslogtreecommitdiff
path: root/neutronclient/tests/unit/test_cli20_port.py
diff options
context:
space:
mode:
Diffstat (limited to 'neutronclient/tests/unit/test_cli20_port.py')
-rw-r--r--neutronclient/tests/unit/test_cli20_port.py794
1 files changed, 0 insertions, 794 deletions
diff --git a/neutronclient/tests/unit/test_cli20_port.py b/neutronclient/tests/unit/test_cli20_port.py
deleted file mode 100644
index ab7e956..0000000
--- a/neutronclient/tests/unit/test_cli20_port.py
+++ /dev/null
@@ -1,794 +0,0 @@
-# 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_vnic_type_smart_nic(self):
- # Create port: --vnic_type smart-nic netid.
- resource = 'port'
- cmd = port.CreatePort(test_cli20.MyApp(sys.stdout), None)
- name = 'myname'
- myid = 'myid'
- netid = 'netid'
- args = ['--vnic_type', 'smart-nic', netid]
- position_names = ['binding:vnic_type', 'network_id']
- position_values = ['smart-nic', netid]
- self._test_create_resource(resource, cmd, name, myid, args,
- position_names, position_values)
-
- # Test dashed options
- args = ['--vnic-type', 'smart-nic', netid]
- position_names = ['binding:vnic_type', 'network_id']
- position_values = ['smart-nic', 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)