summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/api/builds.rb22
-rw-r--r--lib/ci/api/builds.rb19
-rw-r--r--spec/requests/api/builds_spec.rb25
-rw-r--r--spec/requests/ci/api/builds_spec.rb12
4 files changed, 47 insertions, 31 deletions
diff --git a/lib/api/builds.rb b/lib/api/builds.rb
index a8bd3842ce4..06ec03fc4e0 100644
--- a/lib/api/builds.rb
+++ b/lib/api/builds.rb
@@ -115,13 +115,33 @@ module API
authorize_update_builds!
build = get_build(params[:build_id])
- return forbidden!('Build is not retryable') unless build && build.retryable?
+ return not_found!(build) unless build
+ return forbidden!('Build is not retryable') unless build.retryable?
build = Ci::Build.retry(build)
present build, with: Entities::Build,
user_can_download_artifacts: can?(current_user, :read_build, user_project)
end
+
+ # Erase build (remove artifacts and build trace)
+ #
+ # Parameters:
+ # id (required) - the id of a project
+ # build_id (required) - the id of a build
+ # example Request:
+ # delete /projects/:id/build/:build_id/content
+ delete ':id/builds/:build_id/content' do
+ authorize_manage_builds!
+
+ build = get_build(params[:build_id])
+ return not_found!(build) unless build
+ return forbidden!('Build is not eraseable!') unless build.eraseable?
+
+ build.erase!
+ present build, with: Entities::Build,
+ user_can_download_artifacts: can?(current_user, :download_build_artifacts, user_project)
+ end
end
helpers do
diff --git a/lib/ci/api/builds.rb b/lib/ci/api/builds.rb
index f37a96da93c..2e9a5d311f9 100644
--- a/lib/ci/api/builds.rb
+++ b/lib/ci/api/builds.rb
@@ -146,7 +146,7 @@ module Ci
present_file!(artifacts_file.path, artifacts_file.filename)
end
- # Remove the artifacts file from build
+ # Remove the artifacts file from build - Runners only
#
# Parameters:
# id (required) - The ID of a build
@@ -163,23 +163,6 @@ module Ci
build.remove_artifacts_file!
build.remove_artifacts_metadata!
end
-
- # Erase build (remove artifacts and build trace)
- #
- # Parameters:
- # id (required) - The ID of a build
- # token (required) - The build authorization token
- # Headers:
- # BUILD-TOKEN (required) - The build authorization token, the same as token
- # Example Request:
- # DELETE /builds/:id/content
- delete ':id/content' do
- build = Ci::Build.find_by_id(params[:id])
- not_found! unless build
- authenticate_build_token!(build)
-
- build.erase!
- end
end
end
end
diff --git a/spec/requests/api/builds_spec.rb b/spec/requests/api/builds_spec.rb
index 6c07802db8b..56ab303268f 100644
--- a/spec/requests/api/builds_spec.rb
+++ b/spec/requests/api/builds_spec.rb
@@ -169,4 +169,29 @@ describe API::API, api: true do
end
end
end
+
+ describe 'DELETE /projects/:id/builds/:build_id/content' do
+ before do
+ delete api("/projects/#{project.id}/builds/#{build.id}/content", user)
+ end
+
+ context 'build is eraseable' do
+ let(:build) { create(:ci_build_with_trace, :artifacts, :success, project: project, commit: commit) }
+
+ it 'should erase build content' do
+ expect(response.status).to eq 200
+ expect(build.trace).to be_empty
+ expect(build.artifacts_file.exists?).to be_falsy
+ expect(build.artifacts_metadata.exists?).to be_falsy
+ end
+ end
+
+ context 'build is not eraseable' do
+ let(:build) { create(:ci_build_with_trace, project: project, commit: commit) }
+
+ it 'should respond with forbidden' do
+ expect(response.status).to eq 403
+ end
+ end
+ end
end
diff --git a/spec/requests/ci/api/builds_spec.rb b/spec/requests/ci/api/builds_spec.rb
index 4246ff38fa2..8eb9881649c 100644
--- a/spec/requests/ci/api/builds_spec.rb
+++ b/spec/requests/ci/api/builds_spec.rb
@@ -156,18 +156,6 @@ describe Ci::API::API do
end
end
- describe 'DELETE /builds/:id/content' do
- let(:build) { create(:ci_build_with_trace, :artifacts, :success) }
- before { delete ci_api("/builds/#{build.id}/content"), token: build.token }
-
- it 'should erase build content' do
- expect(response.status).to eq 200
- expect(build.trace).to be_empty
- expect(build.artifacts_file.exists?).to be_falsy
- expect(build.artifacts_metadata.exists?).to be_falsy
- end
- end
-
context "Artifacts" do
let(:file_upload) { fixture_file_upload(Rails.root + 'spec/fixtures/banana_sample.gif', 'image/gif') }
let(:file_upload2) { fixture_file_upload(Rails.root + 'spec/fixtures/dk.png', 'image/gif') }