summaryrefslogtreecommitdiff
path: root/openstackclient
diff options
context:
space:
mode:
authorZuul <zuul@review.openstack.org>2017-11-15 23:35:01 +0000
committerGerrit Code Review <review@openstack.org>2017-11-15 23:35:01 +0000
commit10ef6d51770f6de13776c3cc37907947a8bc3b70 (patch)
tree728c81033404a8ec55cfb0402c236b015e1d69d0 /openstackclient
parentaafbb69cfb0271f2f6ded0b4d311bc29f7dbcb17 (diff)
parent809355894fac72908869739b72d44ead1c183072 (diff)
downloadpython-openstackclient-10ef6d51770f6de13776c3cc37907947a8bc3b70.tar.gz
Merge "Add RemoveNetwork command to server"
Diffstat (limited to 'openstackclient')
-rw-r--r--openstackclient/compute/v2/server.py35
-rw-r--r--openstackclient/tests/unit/compute/v2/test_server.py51
2 files changed, 86 insertions, 0 deletions
diff --git a/openstackclient/compute/v2/server.py b/openstackclient/compute/v2/server.py
index 03419982..78c56788 100644
--- a/openstackclient/compute/v2/server.py
+++ b/openstackclient/compute/v2/server.py
@@ -1542,6 +1542,41 @@ class RemovePort(command.Command):
server.interface_detach(port_id)
+class RemoveNetwork(command.Command):
+ _description = _("Remove all ports of a network from server")
+
+ def get_parser(self, prog_name):
+ parser = super(RemoveNetwork, self).get_parser(prog_name)
+ parser.add_argument(
+ "server",
+ metavar="<server>",
+ help=_("Server to remove the port from (name or ID)"),
+ )
+ parser.add_argument(
+ "network",
+ metavar="<network>",
+ help=_("Network to remove from the server (name or ID)"),
+ )
+ return parser
+
+ def take_action(self, parsed_args):
+ compute_client = self.app.client_manager.compute
+
+ server = utils.find_resource(
+ compute_client.servers, parsed_args.server)
+
+ if self.app.client_manager.is_network_endpoint_enabled():
+ network_client = self.app.client_manager.network
+ net_id = network_client.find_network(
+ parsed_args.network, ignore_missing=False).id
+ else:
+ net_id = parsed_args.network
+
+ for inf in server.interface_list():
+ if inf.net_id == net_id:
+ server.interface_detach(inf.port_id)
+
+
class RemoveServerSecurityGroup(command.Command):
_description = _("Remove security group from server")
diff --git a/openstackclient/tests/unit/compute/v2/test_server.py b/openstackclient/tests/unit/compute/v2/test_server.py
index ad52e232..20b9532a 100644
--- a/openstackclient/tests/unit/compute/v2/test_server.py
+++ b/openstackclient/tests/unit/compute/v2/test_server.py
@@ -2380,6 +2380,57 @@ class TestServerRemovePort(TestServer):
self.find_port.assert_not_called()
+class TestServerRemoveNetwork(TestServer):
+
+ def setUp(self):
+ super(TestServerRemoveNetwork, self).setUp()
+
+ # Get the command object to test
+ self.cmd = server.RemoveNetwork(self.app, None)
+
+ # Set method to be tested.
+ self.fake_inf = mock.Mock()
+ self.methods = {
+ 'interface_list': [self.fake_inf],
+ 'interface_detach': None,
+ }
+
+ self.find_network = mock.Mock()
+ self.app.client_manager.network.find_network = self.find_network
+
+ def _test_server_remove_network(self, network_id):
+ self.fake_inf.net_id = network_id
+ self.fake_inf.port_id = 'fake-port'
+ servers = self.setup_servers_mock(count=1)
+ network = 'fake-network'
+
+ arglist = [
+ servers[0].id,
+ network,
+ ]
+ verifylist = [
+ ('server', servers[0].id),
+ ('network', network),
+ ]
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
+
+ result = self.cmd.take_action(parsed_args)
+
+ servers[0].interface_list.assert_called_once_with()
+ servers[0].interface_detach.assert_called_once_with('fake-port')
+ self.assertIsNone(result)
+
+ def test_server_remove_network(self):
+ self._test_server_remove_network(self.find_network.return_value.id)
+ self.find_network.assert_called_once_with(
+ 'fake-network', ignore_missing=False)
+
+ def test_server_remove_network_no_neutron(self):
+ self.app.client_manager.network_endpoint_enabled = False
+ self._test_server_remove_network('fake-network')
+ self.find_network.assert_not_called()
+
+
@mock.patch(
'openstackclient.api.compute_v2.APIv2.security_group_find'
)