summaryrefslogtreecommitdiff
path: root/gitlab/v4/objects.py
diff options
context:
space:
mode:
authorJeroen Schutrup <jschutrup@bol.com>2019-07-11 16:25:21 +0200
committerMax Wittig <max.wittig95@gmail.com>2019-07-21 13:13:38 +0200
commit3520b453f75c9727eafe8e997ee8274933c6f0fd (patch)
tree3e1c2fc2d885fa5e7b664f20d1412174b1ca6a06 /gitlab/v4/objects.py
parentc8a7e31cb57e3be7287ba237dbda7c4efa195b29 (diff)
downloadgitlab-rebase-mr.tar.gz
feat: add mr rebase methodrebase-mr
Diffstat (limited to 'gitlab/v4/objects.py')
-rw-r--r--gitlab/v4/objects.py16
1 files changed, 16 insertions, 0 deletions
diff --git a/gitlab/v4/objects.py b/gitlab/v4/objects.py
index f72a145..c7edae6 100644
--- a/gitlab/v4/objects.py
+++ b/gitlab/v4/objects.py
@@ -2712,6 +2712,22 @@ class ProjectMergeRequest(
server_data = self.manager.gitlab.http_post(path, post_data=data, **kwargs)
self._update_attrs(server_data)
+ @cli.register_custom_action("ProjectMergeRequest")
+ @exc.on_http_error(exc.GitlabMRRebaseError)
+ def rebase(self, **kwargs):
+ """Attempt to rebase the source branch onto the target branch
+
+ Args:
+ **kwargs: Extra options to send to the server (e.g. sudo)
+
+ Raises:
+ GitlabAuthenticationError: If authentication is not correct
+ GitlabMRRebaseError: If rebasing failed
+ """
+ path = "%s/%s/rebase" % (self.manager.path, self.get_id())
+ data = {}
+ return self.manager.gitlab.http_put(path, post_data=data, **kwargs)
+
@cli.register_custom_action(
"ProjectMergeRequest",
tuple(),