summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGauvain Pocentek <gauvain@pocentek.net>2015-08-21 12:33:12 +0200
committerGauvain Pocentek <gauvain@pocentek.net>2015-08-21 12:33:12 +0200
commit24d5035558dec227d2a497d7bf5be3bbaafc0c00 (patch)
tree93f8f4334e5a9faa330daec11e35b1c951380a9a
parentadbe0a4391f1e3b4d615ef7966dfa66e75b9a6fa (diff)
parent719526dc8b0fb7d577f0a5ffa80d8f0ca31a95c6 (diff)
downloadgitlab-24d5035558dec227d2a497d7bf5be3bbaafc0c00.tar.gz
Merge pull request #64 from jantman/issues/63
python-gitlab Issue #63 - implement pagination for list()
-rw-r--r--gitlab/__init__.py11
-rw-r--r--gitlab/tests/test_gitlab.py51
2 files changed, 60 insertions, 2 deletions
diff --git a/gitlab/__init__.py b/gitlab/__init__.py
index 43b139d..f61b3b4 100644
--- a/gitlab/__init__.py
+++ b/gitlab/__init__.py
@@ -189,6 +189,8 @@ class Gitlab(object):
self._url = '%s/api/v3' % url
def _construct_url(self, id_, obj, parameters):
+ if 'next_url' in parameters:
+ return parameters['next_url']
args = _sanitize_dict(parameters)
if id_ is None and obj._urlPlural is not None:
url = obj._urlPlural % args
@@ -346,8 +348,13 @@ class Gitlab(object):
if key in cls_kwargs:
del cls_kwargs[key]
- return [cls(self, item, **cls_kwargs) for item in r.json()
- if item is not None]
+ results = [cls(self, item, **cls_kwargs) for item in r.json()
+ if item is not None]
+ if 'next' in r.links and 'url' in r.links['next']:
+ args = kwargs.copy()
+ args['next_url'] = r.links['next']['url']
+ results.extend(self.list(obj_class, **args))
+ return results
else:
_raise_error_from_response(r, GitlabListError)
diff --git a/gitlab/tests/test_gitlab.py b/gitlab/tests/test_gitlab.py
index f84bf86..5530843 100644
--- a/gitlab/tests/test_gitlab.py
+++ b/gitlab/tests/test_gitlab.py
@@ -22,6 +22,7 @@ try:
import unittest
except ImportError:
import unittest2 as unittest
+import json
from httmock import HTTMock # noqa
from httmock import response # noqa
@@ -178,6 +179,56 @@ class TestGitLabMethods(unittest.TestCase):
self.assertEqual(data.project_id, 1)
self.assertEqual(data.ref, "a")
+ def test_list_next_link(self):
+ @urlmatch(scheme="http", netloc="localhost",
+ path='/api/v3/projects/1/repository/branches', method="get",
+ query=r'per_page=1')
+ def resp_one(url, request):
+ """
+ First request:
+ http://localhost/api/v3/projects/1/repository/branches?per_page=1
+ """
+ headers = {
+ 'content-type': 'application/json',
+ 'link': '<http://localhost/api/v3/projects/1/repository/branc' \
+ 'hes?page=2&per_page=0>; rel="next", <http://localhost/api/v3' \
+ '/projects/1/repository/branches?page=2&per_page=0>; rel="las' \
+ 't", <http://localhost/api/v3/projects/1/repository/branches?' \
+ 'page=1&per_page=0>; rel="first"'
+ }
+ content = ('[{"branch_name": "otherbranch", '
+ '"project_id": 1, "ref": "b"}]').encode("utf-8")
+ resp = response(200, content, headers, None, 5, request)
+ return resp
+
+ @urlmatch(scheme="http", netloc="localhost",
+ path='/api/v3/projects/1/repository/branches', method="get",
+ query=r'.*page=2.*')
+ def resp_two(url, request):
+ headers = {
+ 'content-type': 'application/json',
+ 'link': '<http://localhost/api/v3/projects/1/repository/branc' \
+ 'hes?page=1&per_page=0>; rel="prev", <http://localhost/api/v3' \
+ '/projects/1/repository/branches?page=2&per_page=0>; rel="las' \
+ 't", <http://localhost/api/v3/projects/1/repository/branches?' \
+ 'page=1&per_page=0>; rel="first"'
+ }
+ content = ('[{"branch_name": "testbranch", '
+ '"project_id": 1, "ref": "a"}]').encode("utf-8")
+ resp = response(200, content, headers, None, 5, request)
+ return resp
+
+ with HTTMock(resp_one, resp_two):
+ data = self.gl.list(ProjectBranch, project_id=1,
+ per_page=1)
+ self.assertEqual(data[1].branch_name, "testbranch")
+ self.assertEqual(data[1].project_id, 1)
+ self.assertEqual(data[1].ref, "a")
+ self.assertEqual(data[0].branch_name, "otherbranch")
+ self.assertEqual(data[0].project_id, 1)
+ self.assertEqual(data[0].ref, "b")
+ self.assertEqual(len(data), 2)
+
def test_list_401(self):
@urlmatch(scheme="http", netloc="localhost",
path="/api/v3/projects/1/repository/branches", method="get")