summaryrefslogtreecommitdiff
path: root/gitlab/objects.py
diff options
context:
space:
mode:
authorGauvain Pocentek <gauvain@pocentek.net>2016-06-07 21:39:15 +0200
committerGauvain Pocentek <gauvain@pocentek.net>2016-06-07 21:39:15 +0200
commitb3e0974451b49ab64866dc131bff59e5471ea620 (patch)
tree4d1408496b407d00a3bc86e9a9ca0612e00fb779 /gitlab/objects.py
parent422b163075189eca466077c7320b466ab39f331e (diff)
downloadgitlab-issue-122.tar.gz
Add support for build artifacts and traceissue-122
Fixes #122
Diffstat (limited to 'gitlab/objects.py')
-rw-r--r--gitlab/objects.py34
1 files changed, 32 insertions, 2 deletions
diff --git a/gitlab/objects.py b/gitlab/objects.py
index 313ed96..e522acc 100644
--- a/gitlab/objects.py
+++ b/gitlab/objects.py
@@ -806,18 +806,48 @@ class ProjectBuild(GitlabObject):
canUpdate = False
canCreate = False
- def cancel(self):
+ def cancel(self, **kwargs):
"""Cancel the build."""
url = '/projects/%s/builds/%s/cancel' % (self.project_id, self.id)
r = self.gitlab._raw_post(url)
raise_error_from_response(r, GitlabBuildCancelError, 201)
- def retry(self):
+ def retry(self, **kwargs):
"""Retry the build."""
url = '/projects/%s/builds/%s/retry' % (self.project_id, self.id)
r = self.gitlab._raw_post(url)
raise_error_from_response(r, GitlabBuildRetryError, 201)
+ def artifacts(self, **kwargs):
+ """Get the build artifacts.
+
+ Returns:
+ str: The artifacts.
+
+ Raises:
+ GitlabConnectionError: If the server cannot be reached.
+ GitlabGetError: If the artifacts are not available.
+ """
+ url = '/projects/%s/builds/%s/artifacts' % (self.project_id, self.id)
+ r = self.gitlab._raw_get(url)
+ raise_error_from_response(r, GitlabGetError, 200)
+ return r.content
+
+ def trace(self, **kwargs):
+ """Get the build trace.
+
+ Returns:
+ str: The trace.
+
+ Raises:
+ GitlabConnectionError: If the server cannot be reached.
+ GitlabGetError: If the trace is not available.
+ """
+ url = '/projects/%s/builds/%s/trace' % (self.project_id, self.id)
+ r = self.gitlab._raw_get(url)
+ raise_error_from_response(r, GitlabGetError, 200)
+ return r.content
+
class ProjectBuildManager(BaseManager):
obj_cls = ProjectBuild