diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2021-02-18 13:34:06 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2021-02-18 13:34:06 +0300 |
commit | 859a6fb938bb9ee2a317c46dfa4fcc1af49608f0 (patch) | |
tree | d7f2700abe6b4ffcb2dcfc80631b2d87d0609239 /spec/lib/gitlab/ci/status | |
parent | 446d496a6d000c73a304be52587cd9bbc7493136 (diff) |
Add latest changes from gitlab-org/gitlab@13-9-stable-eev13.9.0-rc42
Diffstat (limited to 'spec/lib/gitlab/ci/status')
4 files changed, 69 insertions, 2 deletions
diff --git a/spec/lib/gitlab/ci/status/bridge/factory_spec.rb b/spec/lib/gitlab/ci/status/bridge/factory_spec.rb index d27bb98ba9a..6081f104e42 100644 --- a/spec/lib/gitlab/ci/status/bridge/factory_spec.rb +++ b/spec/lib/gitlab/ci/status/bridge/factory_spec.rb @@ -117,14 +117,31 @@ RSpec.describe Gitlab::Ci::Status::Bridge::Factory do end end + context 'when bridge is waiting for resource' do + let(:bridge) { create_bridge(:waiting_for_resource, :resource_group) } + + it 'matches correct core status' do + expect(factory.core_status).to be_a Gitlab::Ci::Status::WaitingForResource + end + + it 'fabricates status with correct details' do + expect(status.text).to eq 'waiting' + expect(status.group).to eq 'waiting-for-resource' + expect(status.icon).to eq 'status_pending' + expect(status.favicon).to eq 'favicon_pending' + expect(status.illustration).to include(:image, :size, :title) + expect(status).not_to have_details + end + end + private - def create_bridge(trait) + def create_bridge(*traits) upstream_project = create(:project, :repository) downstream_project = create(:project, :repository) upstream_pipeline = create(:ci_pipeline, :running, project: upstream_project) trigger = { trigger: { project: downstream_project.full_path, branch: 'feature' } } - create(:ci_bridge, trait, options: trigger, pipeline: upstream_pipeline) + create(:ci_bridge, *traits, options: trigger, pipeline: upstream_pipeline) end end diff --git a/spec/lib/gitlab/ci/status/bridge/waiting_for_resource_spec.rb b/spec/lib/gitlab/ci/status/bridge/waiting_for_resource_spec.rb new file mode 100644 index 00000000000..3e19df28d83 --- /dev/null +++ b/spec/lib/gitlab/ci/status/bridge/waiting_for_resource_spec.rb @@ -0,0 +1,7 @@ +# frozen_string_literal: true + +require 'fast_spec_helper' + +RSpec.describe Gitlab::Ci::Status::Bridge::WaitingForResource do + it { expect(described_class).to be < Gitlab::Ci::Status::Processable::WaitingForResource } +end diff --git a/spec/lib/gitlab/ci/status/build/waiting_for_resource_spec.rb b/spec/lib/gitlab/ci/status/build/waiting_for_resource_spec.rb new file mode 100644 index 00000000000..44bd5a8611a --- /dev/null +++ b/spec/lib/gitlab/ci/status/build/waiting_for_resource_spec.rb @@ -0,0 +1,7 @@ +# frozen_string_literal: true + +require 'fast_spec_helper' + +RSpec.describe Gitlab::Ci::Status::Build::WaitingForResource do + it { expect(described_class).to be < Gitlab::Ci::Status::Processable::WaitingForResource } +end diff --git a/spec/lib/gitlab/ci/status/processable/waiting_for_resource_spec.rb b/spec/lib/gitlab/ci/status/processable/waiting_for_resource_spec.rb new file mode 100644 index 00000000000..91a9724d043 --- /dev/null +++ b/spec/lib/gitlab/ci/status/processable/waiting_for_resource_spec.rb @@ -0,0 +1,36 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe Gitlab::Ci::Status::Processable::WaitingForResource do + let(:user) { create(:user) } + + subject do + processable = create(:ci_build, :waiting_for_resource, :resource_group) + described_class.new(Gitlab::Ci::Status::Core.new(processable, user)) + end + + describe '#illustration' do + it { expect(subject.illustration).to include(:image, :size, :title) } + end + + describe '.matches?' do + subject {described_class.matches?(processable, user) } + + context 'when processable is waiting for resource' do + let(:processable) { create(:ci_build, :waiting_for_resource) } + + it 'is a correct match' do + expect(subject).to be true + end + end + + context 'when processable is not waiting for resource' do + let(:processable) { create(:ci_build) } + + it 'does not match' do + expect(subject).to be false + end + end + end +end |