Skip to content

Commit

Permalink
Return Topic instances from 'pubsub.api.list_topics'.
Browse files Browse the repository at this point in the history
Make the return value a tuple, '([topic], next_page_token)'.
  • Loading branch information
tseaver committed Mar 31, 2015
1 parent 925ddb2 commit d8028a0
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 21 deletions.
14 changes: 10 additions & 4 deletions gcloud/pubsub/api.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@

from gcloud._helpers import get_default_project
from gcloud.pubsub._implicit_environ import get_default_connection
from gcloud.pubsub.topic import Topic


def list_topics(page_size=None, page_token=None,
Expand All @@ -42,9 +43,9 @@ def list_topics(page_size=None, page_token=None,
defaults to the connection inferred from the
environment.
:rtype: dict
:returns: keys include ``topics`` (a list of topic mappings) and
``nextPageToken`` (a string: if non-empty, indicates that
:rtype: tuple, (list, str)
:returns: list of :class:`gcloud.pubsub.topic.Topic`, plus a
"next page token" string: if not None, indicates that
more topics can be retrieved with another call (pass that
value as ``page_token``).
"""
Expand All @@ -63,7 +64,12 @@ def list_topics(page_size=None, page_token=None,
params['pageToken'] = page_token

path = '/projects/%s/topics' % project
return connection.api_request(method='GET', path=path, query_params=params)
resp = connection.api_request(method='GET', path=path, query_params=params)
topics = []
for full_name in [topic['name'] for topic in resp['topics']]:
_, t_project, _, name = full_name.split('/')
topics.append(Topic(name, t_project, connection))
return topics, resp.get('nextPageToken')


def list_subscriptions(page_size=None, page_token=None, topic_name=None,
Expand Down
39 changes: 22 additions & 17 deletions gcloud/pubsub/test_api.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,17 +22,18 @@ def _callFUT(self, *args, **kw):
return list_topics(*args, **kw)

def test_w_explicit_connection_no_paging(self):
from gcloud.pubsub.topic import Topic
TOPIC_NAME = 'topic_name'
PROJECT = 'PROJECT'
TOKEN = 'TOKEN'
returned = {'topics': [{'name': TOPIC_NAME}],
'nextPageToken': TOKEN}
TOPIC_PATH = 'projects/%s/topics/%s' % (PROJECT, TOPIC_NAME)
returned = {'topics': [{'name': TOPIC_PATH}]}
conn = _Connection(returned)
response = self._callFUT(project=PROJECT, connection=conn)
topics = response['topics']
topics, next_page_token = self._callFUT(project=PROJECT,
connection=conn)
self.assertEqual(len(topics), 1)
self.assertEqual(topics[0], {'name': TOPIC_NAME})
self.assertEqual(response['nextPageToken'], TOKEN)
self.assertTrue(isinstance(topics[0], Topic))
self.assertEqual(topics[0].name, TOPIC_NAME)
self.assertEqual(next_page_token, None)
self.assertEqual(len(conn._requested), 1)
req = conn._requested[0]
self.assertEqual(req['method'], 'GET')
Expand All @@ -42,39 +43,43 @@ def test_w_explicit_connection_no_paging(self):
def test_w_implicit_connection_and_project_wo_paging(self):
from gcloud._testing import _monkey_defaults as _monkey_base_defaults
from gcloud.pubsub._testing import _monkey_defaults
from gcloud.pubsub.topic import Topic
TOPIC_NAME = 'topic_name'
PROJECT = 'PROJECT'
TOPIC_PATH = 'projects/%s/topics/%s' % (PROJECT, TOPIC_NAME)
TOKEN = 'TOKEN'
returned = {'topics': [{'name': TOPIC_NAME}],
returned = {'topics': [{'name': TOPIC_PATH}],
'nextPageToken': TOKEN}
conn = _Connection(returned)
with _monkey_base_defaults(project=PROJECT):
with _monkey_defaults(connection=conn):
response = self._callFUT()
topics = response['topics']
topics, next_page_token = self._callFUT()
self.assertEqual(len(topics), 1)
self.assertEqual(topics[0], {'name': TOPIC_NAME})
self.assertEqual(response['nextPageToken'], TOKEN)
self.assertTrue(isinstance(topics[0], Topic))
self.assertEqual(topics[0].name, TOPIC_NAME)
self.assertEqual(next_page_token, TOKEN)
self.assertEqual(len(conn._requested), 1)
req = conn._requested[0]
self.assertEqual(req['method'], 'GET')
self.assertEqual(req['path'], '/projects/%s/topics' % PROJECT)
self.assertEqual(req['query_params'], {})

def test_w_explicit_connection_and_project_w_paging(self):
from gcloud.pubsub.topic import Topic
TOPIC_NAME = 'topic_name'
PROJECT = 'PROJECT'
TOPIC_PATH = 'projects/%s/topics/%s' % (PROJECT, TOPIC_NAME)
TOKEN1 = 'TOKEN1'
TOKEN2 = 'TOKEN2'
SIZE = 1
returned = {'topics': [{'name': TOPIC_NAME}],
returned = {'topics': [{'name': TOPIC_PATH}],
'nextPageToken': TOKEN2}
conn = _Connection(returned)
response = self._callFUT(SIZE, TOKEN1, PROJECT, conn)
topics = response['topics']
topics, next_page_token = self._callFUT(SIZE, TOKEN1, PROJECT, conn)
self.assertEqual(len(topics), 1)
self.assertEqual(topics[0], {'name': TOPIC_NAME})
self.assertEqual(response['nextPageToken'], TOKEN2)
self.assertTrue(isinstance(topics[0], Topic))
self.assertEqual(topics[0].name, TOPIC_NAME)
self.assertEqual(next_page_token, TOKEN2)
self.assertEqual(len(conn._requested), 1)
req = conn._requested[0]
self.assertEqual(req['method'], 'GET')
Expand Down

0 comments on commit d8028a0

Please sign in to comment.