require 'spec_helper' describe Travis::API::V3::Services::Repository::Disable do let(:repo) { Travis::API::V3::Models::Repository.where(owner_name: 'svenfuchs', name: 'minimal').first } let(:sidekiq_payload) { JSON.load(Sidekiq::Client.last['args'].last.to_json) } let(:sidekiq_params) { Sidekiq::Client.last['args'].last.deep_symbolize_keys } before do repo.update_attributes!(active: true) Travis::Features.stubs(:owner_active?).returns(true) @original_sidekiq = Sidekiq::Client Sidekiq.send(:remove_const, :Client) # to avoid a warning Sidekiq::Client = [] end after do Sidekiq.send(:remove_const, :Client) # to avoid a warning Sidekiq::Client = @original_sidekiq end describe "not authenticated" do before { post("/v3/repo/#{repo.id}/disable") } example { expect(last_response.status).to be == 403 } example { expect(JSON.load(body)).to be == { "@type" => "error", "error_type" => "login_required", "error_message" => "login required" }} end describe "missing repo, authenticated" do let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) } let(:headers) {{ 'HTTP_AUTHORIZATION' => "token #{token}" }} before { post("/v3/repo/9999999999/disable", {}, headers) } example { expect(last_response.status).to be == 404 } example { expect(JSON.load(body)).to be == { "@type" => "error", "error_type" => "not_found", "error_message" => "repository not found (or insufficient access)", "resource_type" => "repository" }} end describe "existing repository, no push access" do let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) } let(:headers) {{ 'HTTP_AUTHORIZATION' => "token #{token}" }} before { post("/v3/repo/#{repo.id}/disable", {}, headers) } example { expect(last_response.status).to be == 403 } example { expect(JSON.load(body).to_s).to include( "@type", "error_type", "insufficient_access", "error_message", "operation requires disable access to repository", "resource_type", "repository", "permission", "disable") } end describe "private repository, no access" do let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) } let(:headers) {{ 'HTTP_AUTHORIZATION' => "token #{token}" }} before { repo.update_attribute(:private, true) } before { post("/v3/repo/#{repo.id}/disable", {}, headers) } after { repo.update_attribute(:private, false) } example { expect(last_response.status).to be == 404 } example { expect(JSON.load(body)).to be == { "@type" => "error", "error_type" => "not_found", "error_message" => "repository not found (or insufficient access)", "resource_type" => "repository" }} end describe "existing repository, push access" do let(:params) {{}} let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) } let(:headers) {{ 'HTTP_AUTHORIZATION' => "token #{token}" }} before { Travis::API::V3::Models::Permission.create(repository: repo, user: repo.owner, push: true) } before { post("/v3/repo/#{repo.id}/cancel", params, headers) } example { expect(last_response.status).to be == 202 } example { expect(JSON.load(body).to_s).to include( "@type", "job", "@href", "@representation", "minimal", "cancel", "id", "state_change") } example { expect(sidekiq_payload).to be == { "id" => "#{job.id}", "user_id"=> repo.owner_id, "source" => "api"} } example { expect(Sidekiq::Client.last['queue']).to be == 'job_cancellations' } example { expect(Sidekiq::Client.last['class']).to be == 'Travis::Sidekiq::JobCancellation' } describe "setting id has no effect" do let(:params) {{ id: 42 }} example { expect(sidekiq_payload).to be == { "id" => "#{job.id}", "user_id"=> repo.owner_id, "source" => "api"} } end end end