diff options
author | Max Wittig <max.wittig95@gmail.com> | 2019-09-08 15:04:05 +0200 |
---|---|---|
committer | Max Wittig <max.wittig95@gmail.com> | 2019-09-08 15:13:13 +0200 |
commit | 77155678a5d8dbbf11d00f3586307694042d3227 (patch) | |
tree | 58ff9e09f453a18f97ee23d2d5866b760d487911 /gitlab/tests/test_gitlab.py | |
parent | fef085dca35d6b60013d53a3723b4cbf121ab2ae (diff) | |
download | gitlab-77155678a5d8dbbf11d00f3586307694042d3227.tar.gz |
test(todo): add unittests
Diffstat (limited to 'gitlab/tests/test_gitlab.py')
-rw-r--r-- | gitlab/tests/test_gitlab.py | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/gitlab/tests/test_gitlab.py b/gitlab/tests/test_gitlab.py index 318ac17..ed5556d 100644 --- a/gitlab/tests/test_gitlab.py +++ b/gitlab/tests/test_gitlab.py @@ -21,6 +21,7 @@ from __future__ import print_function import os import pickle import tempfile +import json try: import unittest @@ -671,6 +672,51 @@ class TestGitlab(unittest.TestCase): self.assertEqual(status.message, "test") self.assertEqual(status.emoji, "thumbsup") + def test_todo(self): + todo_content = open(os.path.dirname(__file__) + "/data/todo.json", "r").read() + json_content = json.loads(todo_content) + + @urlmatch(scheme="http", netloc="localhost", path="/api/v4/todos", method="get") + def resp_get_todo(url, request): + headers = {"content-type": "application/json"} + content = todo_content.encode("utf-8") + return response(200, content, headers, None, 5, request) + + @urlmatch( + scheme="http", + netloc="localhost", + path="/api/v4/todos/102/mark_as_done", + method="post", + ) + def resp_mark_as_done(url, request): + headers = {"content-type": "application/json"} + single_todo = json.dumps(json_content[0]) + content = single_todo.encode("utf-8") + return response(200, content, headers, None, 5, request) + + with HTTMock(resp_get_todo): + todo = self.gl.todos.list()[0] + self.assertEqual(type(todo), Todo) + self.assertEqual(todo.id, 102) + self.assertEqual(todo.target_type, "MergeRequest") + self.assertEqual(todo.target["assignee"]["username"], "root") + with HTTMock(resp_mark_as_done): + todo.mark_as_done() + + def test_todo_mark_all_as_done(self): + @urlmatch( + scheme="http", + netloc="localhost", + path="/api/v4/todos/mark_as_done", + method="post", + ) + def resp_mark_all_as_done(url, request): + headers = {"content-type": "application/json"} + return response(204, {}, headers, None, 5, request) + + with HTTMock(resp_mark_all_as_done): + self.gl.todos.mark_all_as_done() + def _default_config(self): fd, temp_path = tempfile.mkstemp() os.write(fd, valid_config) |