Skip to content

Commit

Permalink
Merge "add ips to novaclient server manager"
Browse files Browse the repository at this point in the history
  • Loading branch information
Jenkins authored and openstack-gerrit committed Jun 3, 2015
2 parents acf6d1f + de4e40a commit 072ab6c
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 0 deletions.
Empty file.
35 changes: 35 additions & 0 deletions novaclient/tests/functional/api/test_servers.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
# 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 time

from novaclient.tests.functional import base


class TestServersAPI(base.ClientTestBase):
def test_server_ips(self):
server_name = "test_server"
initial_server = self.client.servers.create(
server_name, self.image, self.flavor)
self.addCleanup(initial_server.delete)

for x in xrange(60):
server = self.client.servers.get(initial_server)
if server.status == "ACTIVE":
break
else:
time.sleep(1)
else:
self.fail("Server %s did not go ACTIVE after 60s" % server)

ips = self.client.servers.ips(server)
self.assertIn('private', ips)
10 changes: 10 additions & 0 deletions novaclient/v2/servers.py
Original file line number Diff line number Diff line change
Expand Up @@ -828,6 +828,16 @@ def unshelve(self, server):
"""
self._action('unshelve', server, None)

def ips(self, server):
"""
Return IP Addresses associated with the server.
Often a cheaper call then getting all the details for a server.
"""
_resp, body = self.api.client.get("/servers/%s/ips" %
base.getid(server))
return body['addresses']

def diagnostics(self, server):
"""Retrieve server diagnostics."""
return self.api.client.get("/servers/%s/diagnostics" %
Expand Down

0 comments on commit 072ab6c

Please sign in to comment.