Add port security option to network commands

Add the "--enable-port-security" and "--disable-port-security" options
to the "network create" and "network set" commands. This supports setting
the default port security for ports created on a network.

Change-Id: I1deb505bd77cef2e4bc3c2dbbb0c450665136f47
Implements: blueprint neutron-client
This commit is contained in:
Richard Theis 2016-06-29 09:48:04 -05:00
parent 6920c9e839
commit 92d0fbeafd
5 changed files with 82 additions and 0 deletions

View File

@ -24,6 +24,7 @@ Create new network
[--enable | --disable] [--enable | --disable]
[--share | --no-share] [--share | --no-share]
[--availability-zone-hint <availability-zone>] [--availability-zone-hint <availability-zone>]
[--enable-port-security | --disable-port-security]
[--external [--default | --no-default] | --internal] [--external [--default | --no-default] | --internal]
[--provider-network-type <provider-network-type>] [--provider-network-type <provider-network-type>]
[--provider-physical-network <provider-physical-network>] [--provider-physical-network <provider-physical-network>]
@ -72,6 +73,20 @@ Create new network
*Network version 2 only* *Network version 2 only*
.. option:: --enable-port-security
Enable port security by default for ports created on
this network (default)
*Network version 2 only*
.. option:: --disable-port-security
Disable port security by default for ports created on
this network
*Network version 2 only*
.. option:: --subnet <subnet> .. option:: --subnet <subnet>
IPv4 subnet for fixed IPs (in CIDR notation) IPv4 subnet for fixed IPs (in CIDR notation)
@ -191,6 +206,7 @@ Set network properties
[--name <name>] [--name <name>]
[--enable | --disable] [--enable | --disable]
[--share | --no-share] [--share | --no-share]
[--enable-port-security | --disable-port-security]
[--external [--default | --no-default] | --internal] [--external [--default | --no-default] | --internal]
[--provider-network-type <provider-network-type>] [--provider-network-type <provider-network-type>]
[--provider-physical-network <provider-physical-network>] [--provider-physical-network <provider-physical-network>]
@ -218,6 +234,16 @@ Set network properties
Do not share the network between projects Do not share the network between projects
.. option:: --enable-port-security
Enable port security by default for ports created on
this network
.. option:: --disable-port-security
Disable port security by default for ports created on
this network
.. option:: --external .. option:: --external
Set this network as an external network. Set this network as an external network.

View File

@ -58,6 +58,10 @@ def _get_attrs(client_manager, parsed_args):
attrs['shared'] = True attrs['shared'] = True
if parsed_args.no_share: if parsed_args.no_share:
attrs['shared'] = False attrs['shared'] = False
if parsed_args.enable_port_security:
attrs['port_security_enabled'] = True
if parsed_args.disable_port_security:
attrs['port_security_enabled'] = False
# "network set" command doesn't support setting project. # "network set" command doesn't support setting project.
if 'project' in parsed_args and parsed_args.project is not None: if 'project' in parsed_args and parsed_args.project is not None:
@ -197,6 +201,19 @@ class CreateNetwork(common.NetworkAndComputeShowOne):
"(Network Availability Zone extension required, " "(Network Availability Zone extension required, "
"repeat option to set multiple availability zones)") "repeat option to set multiple availability zones)")
) )
port_security_group = parser.add_mutually_exclusive_group()
port_security_group.add_argument(
'--enable-port-security',
action='store_true',
help=_("Enable port security by default for ports created on "
"this network (default)")
)
port_security_group.add_argument(
'--disable-port-security',
action='store_true',
help=_("Disable port security by default for ports created on "
"this network")
)
external_router_grp = parser.add_mutually_exclusive_group() external_router_grp = parser.add_mutually_exclusive_group()
external_router_grp.add_argument( external_router_grp.add_argument(
'--external', '--external',
@ -403,6 +420,19 @@ class SetNetwork(command.Command):
action='store_true', action='store_true',
help=_("Do not share the network between projects") help=_("Do not share the network between projects")
) )
port_security_group = parser.add_mutually_exclusive_group()
port_security_group.add_argument(
'--enable-port-security',
action='store_true',
help=_("Enable port security by default for ports created on "
"this network")
)
port_security_group.add_argument(
'--disable-port-security',
action='store_true',
help=_("Disable port security by default for ports created on "
"this network")
)
external_router_grp = parser.add_mutually_exclusive_group() external_router_grp = parser.add_mutually_exclusive_group()
external_router_grp.add_argument( external_router_grp.add_argument(
'--external', '--external',

View File

@ -285,6 +285,7 @@ class FakeNetwork(object):
'availability_zones': [], 'availability_zones': [],
'availability_zone_hints': [], 'availability_zone_hints': [],
'is_default': False, 'is_default': False,
'port_security_enabled': True,
} }
# Overwrite default attributes. # Overwrite default attributes.
@ -296,6 +297,8 @@ class FakeNetwork(object):
# Set attributes with special mapping in OpenStack SDK. # Set attributes with special mapping in OpenStack SDK.
network.project_id = network_attrs['tenant_id'] network.project_id = network_attrs['tenant_id']
network.is_router_external = network_attrs['router:external'] network.is_router_external = network_attrs['router:external']
network.is_port_security_enabled = \
network_attrs['port_security_enabled']
return network return network

View File

@ -55,6 +55,7 @@ class TestCreateNetworkIdentityV3(TestNetwork):
'id', 'id',
'is_default', 'is_default',
'name', 'name',
'port_security_enabled',
'project_id', 'project_id',
'provider_network_type', 'provider_network_type',
'router:external', 'router:external',
@ -70,6 +71,7 @@ class TestCreateNetworkIdentityV3(TestNetwork):
_network.id, _network.id,
_network.is_default, _network.is_default,
_network.name, _network.name,
_network.is_port_security_enabled,
_network.project_id, _network.project_id,
_network.provider_network_type, _network.provider_network_type,
network._format_router_external(_network.is_router_external), network._format_router_external(_network.is_router_external),
@ -151,6 +153,7 @@ class TestCreateNetworkIdentityV3(TestNetwork):
"--provider-physical-network", "physnet1", "--provider-physical-network", "physnet1",
"--provider-segment", "400", "--provider-segment", "400",
"--transparent-vlan", "--transparent-vlan",
"--enable-port-security",
self._network.name, self._network.name,
] ]
verifylist = [ verifylist = [
@ -165,6 +168,7 @@ class TestCreateNetworkIdentityV3(TestNetwork):
('physical_network', 'physnet1'), ('physical_network', 'physnet1'),
('segmentation_id', '400'), ('segmentation_id', '400'),
('transparent_vlan', True), ('transparent_vlan', True),
('enable_port_security', True),
('name', self._network.name), ('name', self._network.name),
] ]
@ -183,6 +187,7 @@ class TestCreateNetworkIdentityV3(TestNetwork):
'provider:physical_network': 'physnet1', 'provider:physical_network': 'physnet1',
'provider:segmentation_id': '400', 'provider:segmentation_id': '400',
'vlan_transparent': True, 'vlan_transparent': True,
'port_security_enabled': True,
}) })
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
self.assertEqual(self.data, data) self.assertEqual(self.data, data)
@ -191,6 +196,7 @@ class TestCreateNetworkIdentityV3(TestNetwork):
arglist = [ arglist = [
"--enable", "--enable",
"--no-share", "--no-share",
"--disable-port-security",
self._network.name, self._network.name,
] ]
verifylist = [ verifylist = [
@ -198,6 +204,7 @@ class TestCreateNetworkIdentityV3(TestNetwork):
('no_share', True), ('no_share', True),
('name', self._network.name), ('name', self._network.name),
('external', False), ('external', False),
('disable_port_security', True),
] ]
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
@ -207,6 +214,7 @@ class TestCreateNetworkIdentityV3(TestNetwork):
'admin_state_up': True, 'admin_state_up': True,
'name': self._network.name, 'name': self._network.name,
'shared': False, 'shared': False,
'port_security_enabled': False,
}) })
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
self.assertEqual(self.data, data) self.assertEqual(self.data, data)
@ -226,6 +234,7 @@ class TestCreateNetworkIdentityV2(TestNetwork):
'id', 'id',
'is_default', 'is_default',
'name', 'name',
'port_security_enabled',
'project_id', 'project_id',
'provider_network_type', 'provider_network_type',
'router:external', 'router:external',
@ -241,6 +250,7 @@ class TestCreateNetworkIdentityV2(TestNetwork):
_network.id, _network.id,
_network.is_default, _network.is_default,
_network.name, _network.name,
_network.is_port_security_enabled,
_network.project_id, _network.project_id,
_network.provider_network_type, _network.provider_network_type,
network._format_router_external(_network.is_router_external), network._format_router_external(_network.is_router_external),
@ -547,6 +557,7 @@ class TestSetNetwork(TestNetwork):
'--provider-physical-network', 'physnet1', '--provider-physical-network', 'physnet1',
'--provider-segment', '400', '--provider-segment', '400',
'--no-transparent-vlan', '--no-transparent-vlan',
'--enable-port-security',
] ]
verifylist = [ verifylist = [
('network', self._network.name), ('network', self._network.name),
@ -559,6 +570,7 @@ class TestSetNetwork(TestNetwork):
('physical_network', 'physnet1'), ('physical_network', 'physnet1'),
('segmentation_id', '400'), ('segmentation_id', '400'),
('no_transparent_vlan', True), ('no_transparent_vlan', True),
('enable_port_security', True),
] ]
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
@ -574,6 +586,7 @@ class TestSetNetwork(TestNetwork):
'provider:physical_network': 'physnet1', 'provider:physical_network': 'physnet1',
'provider:segmentation_id': '400', 'provider:segmentation_id': '400',
'vlan_transparent': False, 'vlan_transparent': False,
'port_security_enabled': True,
} }
self.network.update_network.assert_called_once_with( self.network.update_network.assert_called_once_with(
self._network, **attrs) self._network, **attrs)
@ -585,12 +598,14 @@ class TestSetNetwork(TestNetwork):
'--disable', '--disable',
'--no-share', '--no-share',
'--internal', '--internal',
'--disable-port-security',
] ]
verifylist = [ verifylist = [
('network', self._network.name), ('network', self._network.name),
('disable', True), ('disable', True),
('no_share', True), ('no_share', True),
('internal', True), ('internal', True),
('disable_port_security', True),
] ]
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
@ -600,6 +615,7 @@ class TestSetNetwork(TestNetwork):
'admin_state_up': False, 'admin_state_up': False,
'shared': False, 'shared': False,
'router:external': False, 'router:external': False,
'port_security_enabled': False,
} }
self.network.update_network.assert_called_once_with( self.network.update_network.assert_called_once_with(
self._network, **attrs) self._network, **attrs)
@ -630,6 +646,7 @@ class TestShowNetwork(TestNetwork):
'id', 'id',
'is_default', 'is_default',
'name', 'name',
'port_security_enabled',
'project_id', 'project_id',
'provider_network_type', 'provider_network_type',
'router:external', 'router:external',
@ -645,6 +662,7 @@ class TestShowNetwork(TestNetwork):
_network.id, _network.id,
_network.is_default, _network.is_default,
_network.name, _network.name,
_network.is_port_security_enabled,
_network.project_id, _network.project_id,
_network.provider_network_type, _network.provider_network_type,
network._format_router_external(_network.is_router_external), network._format_router_external(_network.is_router_external),

View File

@ -4,6 +4,11 @@ features:
``port set`` commands to support JSON input for more advanced ``port set`` commands to support JSON input for more advanced
binding profile data. binding profile data.
[Blueprint :oscbp:`neutron-client`] [Blueprint :oscbp:`neutron-client`]
- Add ``--enable-port-security`` and ``--disable-port-security``
options on the ``network create`` and ``network set`` commands.
This supports setting the default port security for ports created
on a network.
[Blueprint :oscbp:`neutron-client`]
- Add ``geneve`` choice to the ``network create`` command - Add ``geneve`` choice to the ``network create`` command
``--provider-network-type`` option. ``--provider-network-type`` option.
[Blueprint :oscbp:`neutron-client`] [Blueprint :oscbp:`neutron-client`]