Implement "network agent set" command
Add "network agent set" command in network v2 to set network agent properties. Also add the unit test, doc, functional test and release note. Change-Id: Iebaee4c60f8c6b43f538c1b82a38b93178b9ce53 Implements: bp implement-network-agents Co-Authored-By: Michael Gugino <michael.gugino@walmart.com>
This commit is contained in:
parent
0b91368164
commit
722be75f9c
@ -36,6 +36,36 @@ List network agents
|
|||||||
|
|
||||||
os network agent list
|
os network agent list
|
||||||
|
|
||||||
|
network agent set
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
Set network agent properties
|
||||||
|
|
||||||
|
.. program:: network agent set
|
||||||
|
.. code:: bash
|
||||||
|
|
||||||
|
os network agent set
|
||||||
|
[--description <description>]
|
||||||
|
[--enable | --disable]
|
||||||
|
<network-agent>
|
||||||
|
|
||||||
|
.. option:: --description <discription>
|
||||||
|
|
||||||
|
Set network agent description
|
||||||
|
|
||||||
|
.. option:: --enable
|
||||||
|
|
||||||
|
Enable network agent
|
||||||
|
|
||||||
|
.. option:: --disable
|
||||||
|
|
||||||
|
Disable network agent
|
||||||
|
|
||||||
|
.. _network_agent_set-network-agent:
|
||||||
|
.. describe:: <network-agent>
|
||||||
|
|
||||||
|
Network agent to modify (ID only)
|
||||||
|
|
||||||
network agent show
|
network agent show
|
||||||
------------------
|
------------------
|
||||||
|
|
||||||
|
@ -30,3 +30,12 @@ class NetworkAgentTests(test.TestCase):
|
|||||||
opts = self.get_opts(self.FIELDS)
|
opts = self.get_opts(self.FIELDS)
|
||||||
raw_output = self.openstack('network agent show ' + self.IDs[0] + opts)
|
raw_output = self.openstack('network agent show ' + self.IDs[0] + opts)
|
||||||
self.assertEqual(self.IDs[0] + "\n", raw_output)
|
self.assertEqual(self.IDs[0] + "\n", raw_output)
|
||||||
|
|
||||||
|
def test_network_agent_set(self):
|
||||||
|
opts = self.get_opts(['admin_state_up'])
|
||||||
|
self.openstack('network agent set --disable ' + self.IDs[0])
|
||||||
|
raw_output = self.openstack('network agent show ' + self.IDs[0] + opts)
|
||||||
|
self.assertEqual("DOWN\n", raw_output)
|
||||||
|
self.openstack('network agent set --enable ' + self.IDs[0])
|
||||||
|
raw_output = self.openstack('network agent show ' + self.IDs[0] + opts)
|
||||||
|
self.assertEqual("UP\n", raw_output)
|
||||||
|
@ -99,6 +99,47 @@ class ListNetworkAgent(command.Lister):
|
|||||||
) for s in data))
|
) for s in data))
|
||||||
|
|
||||||
|
|
||||||
|
class SetNetworkAgent(command.Command):
|
||||||
|
"""Set network agent properties"""
|
||||||
|
|
||||||
|
def get_parser(self, prog_name):
|
||||||
|
parser = super(SetNetworkAgent, self).get_parser(prog_name)
|
||||||
|
parser.add_argument(
|
||||||
|
'network_agent',
|
||||||
|
metavar="<network-agent>",
|
||||||
|
help=(_("Network agent to modify (ID only)"))
|
||||||
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
'--description',
|
||||||
|
metavar='<description>',
|
||||||
|
help=_("Set network agent description")
|
||||||
|
)
|
||||||
|
admin_group = parser.add_mutually_exclusive_group()
|
||||||
|
admin_group.add_argument(
|
||||||
|
'--enable',
|
||||||
|
action='store_true',
|
||||||
|
help=_("Enable network agent")
|
||||||
|
)
|
||||||
|
admin_group.add_argument(
|
||||||
|
'--disable',
|
||||||
|
action='store_true',
|
||||||
|
help=_("Disable network agent")
|
||||||
|
)
|
||||||
|
return parser
|
||||||
|
|
||||||
|
def take_action(self, parsed_args):
|
||||||
|
client = self.app.client_manager.network
|
||||||
|
obj = client.get_agent(parsed_args.network_agent, ignore_missing=False)
|
||||||
|
attrs = {}
|
||||||
|
if parsed_args.description is not None:
|
||||||
|
attrs['description'] = str(parsed_args.description)
|
||||||
|
if parsed_args.enable:
|
||||||
|
attrs['admin_state_up'] = True
|
||||||
|
if parsed_args.disable:
|
||||||
|
attrs['admin_state_up'] = False
|
||||||
|
client.update_agent(obj, **attrs)
|
||||||
|
|
||||||
|
|
||||||
class ShowNetworkAgent(command.ShowOne):
|
class ShowNetworkAgent(command.ShowOne):
|
||||||
"""Display network agent details"""
|
"""Display network agent details"""
|
||||||
|
|
||||||
|
@ -160,6 +160,81 @@ class TestListNetworkAgent(TestNetworkAgent):
|
|||||||
self.assertEqual(self.data, list(data))
|
self.assertEqual(self.data, list(data))
|
||||||
|
|
||||||
|
|
||||||
|
class TestSetNetworkAgent(TestNetworkAgent):
|
||||||
|
|
||||||
|
_network_agent = (
|
||||||
|
network_fakes.FakeNetworkAgent.create_one_network_agent())
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestSetNetworkAgent, self).setUp()
|
||||||
|
self.network.update_agent = mock.Mock(return_value=None)
|
||||||
|
self.network.get_agent = mock.Mock(return_value=self._network_agent)
|
||||||
|
|
||||||
|
# Get the command object to test
|
||||||
|
self.cmd = network_agent.SetNetworkAgent(self.app, self.namespace)
|
||||||
|
|
||||||
|
def test_set_nothing(self):
|
||||||
|
arglist = [
|
||||||
|
self._network_agent.id,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('network_agent', self._network_agent.id),
|
||||||
|
]
|
||||||
|
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
result = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
attrs = {}
|
||||||
|
self.network.update_agent.assert_called_once_with(
|
||||||
|
self._network_agent, **attrs)
|
||||||
|
self.assertIsNone(result)
|
||||||
|
|
||||||
|
def test_set_all(self):
|
||||||
|
arglist = [
|
||||||
|
'--description', 'new_description',
|
||||||
|
'--enable',
|
||||||
|
self._network_agent.id,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('description', 'new_description'),
|
||||||
|
('enable', True),
|
||||||
|
('disable', False),
|
||||||
|
('network_agent', self._network_agent.id),
|
||||||
|
]
|
||||||
|
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
result = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
attrs = {
|
||||||
|
'description': 'new_description',
|
||||||
|
'admin_state_up': True,
|
||||||
|
}
|
||||||
|
self.network.update_agent.assert_called_once_with(
|
||||||
|
self._network_agent, **attrs)
|
||||||
|
self.assertIsNone(result)
|
||||||
|
|
||||||
|
def test_set_with_disable(self):
|
||||||
|
arglist = [
|
||||||
|
'--disable',
|
||||||
|
self._network_agent.id,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('enable', False),
|
||||||
|
('disable', True),
|
||||||
|
('network_agent', self._network_agent.id),
|
||||||
|
]
|
||||||
|
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
result = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
attrs = {
|
||||||
|
'admin_state_up': False,
|
||||||
|
}
|
||||||
|
self.network.update_agent.assert_called_once_with(
|
||||||
|
self._network_agent, **attrs)
|
||||||
|
self.assertIsNone(result)
|
||||||
|
|
||||||
|
|
||||||
class TestShowNetworkAgent(TestNetworkAgent):
|
class TestShowNetworkAgent(TestNetworkAgent):
|
||||||
|
|
||||||
_network_agent = (
|
_network_agent = (
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
---
|
---
|
||||||
features:
|
features:
|
||||||
- Add ``network agent delete``, ``network agent list`` and
|
- Add ``network agent delete``, ``network agent list``, ``network agent show``
|
||||||
``network agent show`` commands.
|
and ``network agent set`` commands.
|
||||||
[Blueprint `implement-network-agents <https://blueprints.launchpad.net/python-openstackclient/+spec/implement-network-agents>`_]
|
[Blueprint `implement-network-agents <https://blueprints.launchpad.net/python-openstackclient/+spec/implement-network-agents>`_]
|
||||||
|
@ -357,6 +357,7 @@ openstack.network.v2 =
|
|||||||
|
|
||||||
network_agent_delete = openstackclient.network.v2.network_agent:DeleteNetworkAgent
|
network_agent_delete = openstackclient.network.v2.network_agent:DeleteNetworkAgent
|
||||||
network_agent_list = openstackclient.network.v2.network_agent:ListNetworkAgent
|
network_agent_list = openstackclient.network.v2.network_agent:ListNetworkAgent
|
||||||
|
network_agent_set = openstackclient.network.v2.network_agent:SetNetworkAgent
|
||||||
network_agent_show = openstackclient.network.v2.network_agent:ShowNetworkAgent
|
network_agent_show = openstackclient.network.v2.network_agent:ShowNetworkAgent
|
||||||
|
|
||||||
network_create = openstackclient.network.v2.network:CreateNetwork
|
network_create = openstackclient.network.v2.network:CreateNetwork
|
||||||
|
Loading…
Reference in New Issue
Block a user