Add more specs for /job/:job_id/debug
We now rely on https://github.com/travis-ci/travis-core/pull/519.
This commit is contained in:
parent
d944fe347a
commit
73f724c58c
2
Gemfile
2
Gemfile
|
@ -5,7 +5,7 @@ ruby '2.1.7' if ENV.key?('DYNO')
|
||||||
|
|
||||||
gem 's3', github: 'travis-ci/s3'
|
gem 's3', github: 'travis-ci/s3'
|
||||||
|
|
||||||
gem 'travis-core', github: 'travis-ci/travis-core'
|
gem 'travis-core', github: 'travis-ci/travis-core', branch: 'ha-feature-debug-endpoint'
|
||||||
gem 'travis-support', github: 'travis-ci/travis-support'
|
gem 'travis-support', github: 'travis-ci/travis-support'
|
||||||
gem 'travis-config', '~> 0.1.0'
|
gem 'travis-config', '~> 0.1.0'
|
||||||
gem 'travis-sidekiqs', github: 'travis-ci/travis-sidekiqs', require: nil
|
gem 'travis-sidekiqs', github: 'travis-ci/travis-sidekiqs', require: nil
|
||||||
|
|
|
@ -50,7 +50,8 @@ GIT
|
||||||
|
|
||||||
GIT
|
GIT
|
||||||
remote: git://github.com/travis-ci/travis-core.git
|
remote: git://github.com/travis-ci/travis-core.git
|
||||||
revision: 96ee8c449ebe305c5c95633cea13eb88fe978abb
|
revision: 501f31a40af589b5ea8a677e7f8b067949a322b2
|
||||||
|
branch: ha-feature-debug-endpoint
|
||||||
specs:
|
specs:
|
||||||
travis-core (0.0.1)
|
travis-core (0.0.1)
|
||||||
actionmailer (~> 3.2.19)
|
actionmailer (~> 3.2.19)
|
||||||
|
@ -193,9 +194,9 @@ GEM
|
||||||
httparty (0.11.0)
|
httparty (0.11.0)
|
||||||
multi_json (~> 1.0)
|
multi_json (~> 1.0)
|
||||||
multi_xml (>= 0.5.2)
|
multi_xml (>= 0.5.2)
|
||||||
httpclient (2.7.0.1)
|
httpclient (2.7.1)
|
||||||
i18n (0.7.0)
|
i18n (0.7.0)
|
||||||
ice_nine (0.11.1)
|
ice_nine (0.11.2)
|
||||||
jemalloc (1.0.1)
|
jemalloc (1.0.1)
|
||||||
journey (1.0.4)
|
journey (1.0.4)
|
||||||
json (1.8.3)
|
json (1.8.3)
|
||||||
|
|
|
@ -2,8 +2,12 @@ require 'spec_helper'
|
||||||
|
|
||||||
describe Travis::API::V3::Services::Job::Debug do
|
describe Travis::API::V3::Services::Job::Debug do
|
||||||
let(:repo) { Travis::API::V3::Models::Repository.where(owner_name: 'svenfuchs', name: 'minimal').first }
|
let(:repo) { Travis::API::V3::Models::Repository.where(owner_name: 'svenfuchs', name: 'minimal').first }
|
||||||
let(:sidekiq_payload) { JSON.load(Sidekiq::Client.last['args'].last[:payload]).deep_symbolize_keys }
|
let(:owner_type) { repo.owner_type.constantize }
|
||||||
let(:sidekiq_params) { Sidekiq::Client.last['args'].last.deep_symbolize_keys }
|
let(:owner) { owner_type.find(repo.owner_id)}
|
||||||
|
let(:build) { repo.builds.last }
|
||||||
|
let(:jobs) { Travis::API::V3::Models::Build.find(build.id).jobs }
|
||||||
|
let(:job) { jobs.last }
|
||||||
|
|
||||||
before { repo.requests.each(&:delete) }
|
before { repo.requests.each(&:delete) }
|
||||||
|
|
||||||
before do
|
before do
|
||||||
|
@ -11,6 +15,8 @@ describe Travis::API::V3::Services::Job::Debug do
|
||||||
@original_sidekiq = Sidekiq::Client
|
@original_sidekiq = Sidekiq::Client
|
||||||
Sidekiq.send(:remove_const, :Client) # to avoid a warning
|
Sidekiq.send(:remove_const, :Client) # to avoid a warning
|
||||||
Sidekiq::Client = []
|
Sidekiq::Client = []
|
||||||
|
|
||||||
|
Travis.config.stubs(:debug_tools_enabled).returns true
|
||||||
end
|
end
|
||||||
|
|
||||||
after do
|
after do
|
||||||
|
@ -18,7 +24,8 @@ describe Travis::API::V3::Services::Job::Debug do
|
||||||
Sidekiq::Client = @original_sidekiq
|
Sidekiq::Client = @original_sidekiq
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "not authenticated" do
|
describe "#run" do
|
||||||
|
context "when unauthenticated" do
|
||||||
before { post("/v3/job/#{job.id}/debug") }
|
before { post("/v3/job/#{job.id}/debug") }
|
||||||
example { expect(last_response.status).to be == 403 }
|
example { expect(last_response.status).to be == 403 }
|
||||||
example { expect(JSON.load(body)).to be == {
|
example { expect(JSON.load(body)).to be == {
|
||||||
|
@ -28,4 +35,36 @@ describe Travis::API::V3::Services::Job::Debug do
|
||||||
}}
|
}}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context "when authenticated" do
|
||||||
|
let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) }
|
||||||
|
let(:headers) {{ 'HTTP_AUTHORIZATION' => "token #{token}" }}
|
||||||
|
|
||||||
|
context "without sufficient authorization" do
|
||||||
|
before { post("/v3/job/#{job.id}/debug", {}, headers) }
|
||||||
|
|
||||||
|
example { expect(last_response.status).to be == 403 }
|
||||||
|
example { expect(JSON.load(body)).to include(
|
||||||
|
"@type" => "error",
|
||||||
|
"error_type" => "insufficient_access",
|
||||||
|
"error_message" => "operation requires debug access to job",
|
||||||
|
"resource_type" => "job",
|
||||||
|
)}
|
||||||
|
end
|
||||||
|
|
||||||
|
context "with sufficient authorization" do
|
||||||
|
let(:params) {{}}
|
||||||
|
|
||||||
|
before { Travis::API::V3::Models::Permission.create(repository: repo, user: repo.owner, push: true) }
|
||||||
|
before { post("/v3/job/#{job.id}/debug", {}, headers) }
|
||||||
|
|
||||||
|
example { expect(last_response.status).to be == 202 }
|
||||||
|
|
||||||
|
example { expect(job.reload.debug_options).to include(
|
||||||
|
stage: "before_install",
|
||||||
|
created_by: owner.login,
|
||||||
|
quiet: false
|
||||||
|
) }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
Loading…
Reference in New Issue
Block a user