66 lines
1.6 KiB
Ruby
66 lines
1.6 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe Gitlab::Ci::Status::External::Common do
|
|
let(:user) { create(:user) }
|
|
let(:project) { external_status.project }
|
|
let(:external_target_url) { 'http://example.gitlab.com/status' }
|
|
let(:external_description) { 'my description' }
|
|
|
|
let(:external_status) do
|
|
create(:generic_commit_status, target_url: external_target_url, description: external_description)
|
|
end
|
|
|
|
subject do
|
|
Gitlab::Ci::Status::Success
|
|
.new(external_status, user)
|
|
.extend(described_class)
|
|
end
|
|
|
|
describe '#label' do
|
|
it 'returns description' do
|
|
expect(subject.label).to eq external_description
|
|
end
|
|
|
|
context 'when description is nil' do
|
|
let(:external_description) { nil }
|
|
|
|
it 'uses core status label' do
|
|
expect(subject.label).to eq('passed')
|
|
end
|
|
end
|
|
|
|
context 'when description is empty string' do
|
|
let(:external_description) { '' }
|
|
|
|
it 'uses core status label' do
|
|
expect(subject.label).to eq('passed')
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#has_action?' do
|
|
it { is_expected.not_to have_action }
|
|
end
|
|
|
|
describe '#has_details?' do
|
|
context 'when user has access to read commit status' do
|
|
before do
|
|
project.add_developer(user)
|
|
end
|
|
|
|
it { is_expected.to have_details }
|
|
end
|
|
|
|
context 'when user does not have access to read commit status' do
|
|
it { is_expected.not_to have_details }
|
|
end
|
|
end
|
|
|
|
describe '#details_path' do
|
|
it 'links to the external target URL' do
|
|
expect(subject.details_path).to eq external_target_url
|
|
end
|
|
end
|
|
end
|