summaryrefslogtreecommitdiff
path: root/openstackclient/tests
diff options
context:
space:
mode:
authorHongbin Lu <hongbin.lu@huawei.com>2017-10-03 15:35:56 +0000
committerHongbin Lu <hongbin034@gmail.com>2017-10-26 15:34:04 +0000
commite3ad82164dc5c51b5f3cb75b826bc15a6778b8b0 (patch)
tree0029ba87e14707d7a6dec0754bc4eaf808f22696 /openstackclient/tests
parent8efed05e823eb76f309c0fee821fdc67a9886a3a (diff)
downloadpython-openstackclient-e3ad82164dc5c51b5f3cb75b826bc15a6778b8b0.tar.gz
Added AddNetwork command to server
Currently, if users want to add another NIC to a running instance, they need to (i) create a neutron port and (ii) add the port to the server via teh AddPort command. It would be more convenient to have a single command to achieve the equivalent. Novaclient already support adding network to an instance via the interface-attach command. This patch introduces a similar capability in OSC. Change-Id: Ia3e39c57ae7ecb96aae1b66adc52c289daccb6ec
Diffstat (limited to 'openstackclient/tests')
-rw-r--r--openstackclient/tests/unit/compute/v2/test_server.py47
1 files changed, 47 insertions, 0 deletions
diff --git a/openstackclient/tests/unit/compute/v2/test_server.py b/openstackclient/tests/unit/compute/v2/test_server.py
index a1225c30..1728d7a1 100644
--- a/openstackclient/tests/unit/compute/v2/test_server.py
+++ b/openstackclient/tests/unit/compute/v2/test_server.py
@@ -232,6 +232,53 @@ class TestServerAddPort(TestServer):
self.find_port.assert_not_called()
+class TestServerAddNetwork(TestServer):
+
+ def setUp(self):
+ super(TestServerAddNetwork, self).setUp()
+
+ # Get the command object to test
+ self.cmd = server.AddNetwork(self.app, None)
+
+ # Set add_fixed_ip method to be tested.
+ self.methods = {
+ 'interface_attach': None,
+ }
+
+ self.find_network = mock.Mock()
+ self.app.client_manager.network.find_network = self.find_network
+
+ def _test_server_add_network(self, net_id):
+ 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_attach.assert_called_once_with(
+ port_id=None, net_id=net_id, fixed_ip=None)
+ self.assertIsNone(result)
+
+ def test_server_add_network(self):
+ self._test_server_add_network(self.find_network.return_value.id)
+ self.find_network.assert_called_once_with(
+ 'fake-network', ignore_missing=False)
+
+ def test_server_add_network_no_neutron(self):
+ self.app.client_manager.network_endpoint_enabled = False
+ self._test_server_add_network('fake-network')
+ self.find_network.assert_not_called()
+
+
@mock.patch(
'openstackclient.api.compute_v2.APIv2.security_group_find'
)