summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gitlab/objects.py14
-rw-r--r--gitlab/tests/test_manager.py26
-rw-r--r--tools/python_test.py9
3 files changed, 49 insertions, 0 deletions
diff --git a/gitlab/objects.py b/gitlab/objects.py
index 7a679fc..8e94cb2 100644
--- a/gitlab/objects.py
+++ b/gitlab/objects.py
@@ -573,6 +573,20 @@ class UserManager(BaseManager):
url = self.obj_cls._url + '?search=' + query
return self._custom_list(url, self.obj_cls, **kwargs)
+ def get_by_username(self, username, **kwargs):
+ """Get a user by its username.
+
+ Returns a User object or None if the named user does not
+ exist.
+ """
+ url = self.obj_cls._url + '?username=' + username
+ results = self._custom_list(url, self.obj_cls, **kwargs)
+ assert len(results) in (0, 1)
+ try:
+ return results[0]
+ except IndexError:
+ raise GitlabGetError('no such user: ' + username)
+
class CurrentUserKey(GitlabObject):
_url = '/user/keys'
diff --git a/gitlab/tests/test_manager.py b/gitlab/tests/test_manager.py
index 1b808a9..59987a7 100644
--- a/gitlab/tests/test_manager.py
+++ b/gitlab/tests/test_manager.py
@@ -258,6 +258,32 @@ class TestGitlabManager(unittest.TestCase):
self.assertEqual(data[0].id, 1)
self.assertEqual(data[1].id, 2)
+ def test_user_manager_get_by_username(self):
+ mgr = UserManager(self.gitlab)
+
+ @urlmatch(scheme="http", netloc="localhost", path="/api/v3/users",
+ query="username=foo", method="get")
+ def resp_get_username(url, request):
+ headers = {'content-type': 'application/json'}
+ content = '[{"name": "foo", "id": 1}]'.encode("utf-8")
+ return response(200, content, headers, None, 5, request)
+
+ with HTTMock(resp_get_username):
+ data = mgr.get_by_username('foo')
+ self.assertEqual(type(data), User)
+ self.assertEqual(data.name, "foo")
+ self.assertEqual(data.id, 1)
+
+ @urlmatch(scheme="http", netloc="localhost", path="/api/v3/users",
+ query="username=foo", method="get")
+ def resp_get_username_nomatch(url, request):
+ headers = {'content-type': 'application/json'}
+ content = '[]'.encode("utf-8")
+ return response(200, content, headers, None, 5, request)
+
+ with HTTMock(resp_get_username_nomatch):
+ self.assertRaises(GitlabGetError, mgr.get_by_username, 'foo')
+
def test_group_manager_search(self):
mgr = GroupManager(self.gitlab)
diff --git a/tools/python_test.py b/tools/python_test.py
index a2e0b15..d32dccd 100644
--- a/tools/python_test.py
+++ b/tools/python_test.py
@@ -54,6 +54,15 @@ actual = sorted(gl.users.search('foo'), cmp=usercmp)
assert expected == actual
assert gl.users.search('asdf') == []
+assert gl.users.get_by_username('foobar') == foobar_user
+assert gl.users.get_by_username('foo') == new_user
+try:
+ gl.users.get_by_username('asdf')
+except gitlab.GitlabGetError:
+ pass
+else:
+ assert False
+
# SSH keys
key = new_user.keys.create({'title': 'testkey', 'key': SSH_KEY})
assert(len(new_user.keys.list()) == 1)