Merge pull request #291 from travis-ci/ag-ar-restart-in-request-endpoint

Use new restart service on request endpoint
This commit is contained in:
Ana Rosas 2016-07-05 10:50:58 -05:00 committed by GitHub
commit 1d7bc10ed9
2 changed files with 27 additions and 2 deletions

View File

@ -28,10 +28,20 @@ class Travis::Api::App
#
# I think we need to properly deprecate this by publishing a blog post.
Metriks.meter("api.request.restart").mark
service = Travis::Enqueue::Services::RestartModel.new(current_user, { build_id: params[:build_id] })
repository_owner = service.target.repository.owner
if !Travis::Features.enabled_for_all?(:enqueue_to_hub) && !Travis::Features.owner_active?(:enqueue_to_hub, repository_owner)
respond_with service(:reset_model, params)
elsif service.respond_to?(:push)
payload = {id: params[:build_id], user_id: current_user.id}
service.push("job:restart", payload)
status 202
true
end
end
end
end
end
end

View File

@ -3,6 +3,7 @@ require 'json'
describe 'Requests', set_app: true do
let(:repo) { Factory.create(:repository) }
let(:request) { Factory.create(:request, repository: repo) }
let(:build) { Factory.create(:build, repository: repo) }
let(:user) { Factory.create(:user) }
let(:token) { Travis::Api::App::AccessToken.create(user: user, app_id: -1) }
let(:headers) { { 'HTTP_ACCEPT' => 'application/vnd.travis-ci.2+json', 'HTTP_AUTHORIZATION' => "token #{token}" } }
@ -25,4 +26,18 @@ describe 'Requests', set_app: true do
response.should deliver_json_for(request, version: 'v2', type: 'request')
end
end
describe 'POST /requests' do
it 'triggers a build request using Core code' do
response = post "/requests", { build_id: build.id }, headers
response.status.should be(200)
end
it 'triggers a build request using Hub' do
Travis::Features.activate_owner(:enqueue_to_hub, repo.owner)
response = post "/requests", { build_id: build.id }, headers
response.status.should be(202)
end
end
end