diff options
-rw-r--r-- | gitlab/v4/objects.py | 24 | ||||
-rw-r--r-- | tools/python_test_v4.py | 6 |
2 files changed, 30 insertions, 0 deletions
diff --git a/gitlab/v4/objects.py b/gitlab/v4/objects.py index e4a5447..211527d 100644 --- a/gitlab/v4/objects.py +++ b/gitlab/v4/objects.py @@ -1557,6 +1557,30 @@ class ProjectMergeRequest(SubscribableMixin, TodoMixin, TimeTrackingMixin, **kwargs) self._update_attrs(server_data) + @cli.register_custom_action('ProjectMergeRequest') + @exc.on_http_error(exc.GitlabListError) + def participants(self, **kwargs): + """List the merge request participants. + + Args: + all (bool): If True, return all the items, without pagination + per_page (int): Number of items to retrieve per request + page (int): ID of the page to return (starts with page 1) + as_list (bool): If set to False and no pagination option is + defined, return a generator instead of a list + **kwargs: Extra options to send to the server (e.g. sudo) + + Raises: + GitlabAuthenticationError: If authentication is not correct + GitlabListError: If the list could not be retrieved + + Returns: + RESTObjectList: The list of participants + """ + + path = '%s/%s/participants' % (self.manager.path, self.get_id()) + return self.manager.gitlab.http_get(path, **kwargs) + class ProjectMergeRequestManager(CRUDMixin, RESTManager): _path = '/projects/%(project_id)s/merge_requests' diff --git a/tools/python_test_v4.py b/tools/python_test_v4.py index e065020..69596b8 100644 --- a/tools/python_test_v4.py +++ b/tools/python_test_v4.py @@ -527,6 +527,12 @@ admin_project.files.create({'file_path': 'README2.rst', mr = admin_project.mergerequests.create({'source_branch': 'branch1', 'target_branch': 'master', 'title': 'MR readme2'}) + +# basic testing: only make sure that the methods exist +mr.commits() +mr.changes() +#mr.participants() # not yet available + mr.merge() admin_project.branches.delete('branch1') |