diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-09-19 04:45:44 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-09-19 04:45:44 +0300 |
commit | 85dc423f7090da0a52c73eb66faf22ddb20efff9 (patch) | |
tree | 9160f299afd8c80c038f08e1545be119f5e3f1e1 /spec/lib/gitlab/ci/status | |
parent | 15c2c8c66dbe422588e5411eee7e68f1fa440bb8 (diff) |
Add latest changes from gitlab-org/gitlab@13-4-stable-ee
Diffstat (limited to 'spec/lib/gitlab/ci/status')
-rw-r--r-- | spec/lib/gitlab/ci/status/bridge/common_spec.rb | 49 | ||||
-rw-r--r-- | spec/lib/gitlab/ci/status/composite_spec.rb | 51 |
2 files changed, 79 insertions, 21 deletions
diff --git a/spec/lib/gitlab/ci/status/bridge/common_spec.rb b/spec/lib/gitlab/ci/status/bridge/common_spec.rb new file mode 100644 index 00000000000..92600b21afc --- /dev/null +++ b/spec/lib/gitlab/ci/status/bridge/common_spec.rb @@ -0,0 +1,49 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe Gitlab::Ci::Status::Bridge::Common do + let_it_be(:user) { create(:user) } + let_it_be(:bridge) { create(:ci_bridge) } + let_it_be(:downstream_pipeline) { create(:ci_pipeline) } + + before_all do + create(:ci_sources_pipeline, + source_pipeline: bridge.pipeline, + source_project: bridge.pipeline.project, + source_job: bridge, + pipeline: downstream_pipeline, + project: downstream_pipeline.project) + end + + subject do + Gitlab::Ci::Status::Core + .new(bridge, user) + .extend(described_class) + end + + describe '#details_path' do + context 'when user has access to read downstream pipeline' do + before do + downstream_pipeline.project.add_developer(user) + end + + it { expect(subject).to have_details } + it { expect(subject.details_path).to include "pipelines/#{downstream_pipeline.id}" } + + context 'when ci_bridge_pipeline_details is disabled' do + before do + stub_feature_flags(ci_bridge_pipeline_details: false) + end + + it { expect(subject).not_to have_details } + it { expect(subject.details_path).to be_nil } + end + end + + context 'when user does not have access to read downstream pipeline' do + it { expect(subject).not_to have_details } + it { expect(subject.details_path).to be_nil } + end + end +end diff --git a/spec/lib/gitlab/ci/status/composite_spec.rb b/spec/lib/gitlab/ci/status/composite_spec.rb index e1dcd05373f..bcfb9f19792 100644 --- a/spec/lib/gitlab/ci/status/composite_spec.rb +++ b/spec/lib/gitlab/ci/status/composite_spec.rb @@ -20,7 +20,7 @@ RSpec.describe Gitlab::Ci::Status::Composite do shared_examples 'compares status and warnings' do let(:composite_status) do - described_class.new(all_statuses) + described_class.new(all_statuses, dag: dag) end it 'returns status and warnings?' do @@ -30,21 +30,29 @@ RSpec.describe Gitlab::Ci::Status::Composite do end context 'allow_failure: false' do - where(:build_statuses, :result, :has_warnings) do - %i(skipped) | 'skipped' | false - %i(skipped success) | 'success' | false - %i(created) | 'created' | false - %i(preparing) | 'preparing' | false - %i(canceled success skipped) | 'canceled' | false - %i(pending created skipped) | 'pending' | false - %i(pending created skipped success) | 'running' | false - %i(running created skipped success) | 'running' | false - %i(success waiting_for_resource) | 'waiting_for_resource' | false - %i(success manual) | 'manual' | false - %i(success scheduled) | 'scheduled' | false - %i(created preparing) | 'preparing' | false - %i(created success pending) | 'running' | false - %i(skipped success failed) | 'failed' | false + where(:build_statuses, :dag, :result, :has_warnings) do + %i(skipped) | false | 'skipped' | false + %i(skipped success) | false | 'success' | false + %i(skipped success) | true | 'skipped' | false + %i(created) | false | 'created' | false + %i(preparing) | false | 'preparing' | false + %i(canceled success skipped) | false | 'canceled' | false + %i(canceled success skipped) | true | 'skipped' | false + %i(pending created skipped) | false | 'pending' | false + %i(pending created skipped success) | false | 'running' | false + %i(running created skipped success) | false | 'running' | false + %i(pending created skipped) | true | 'skipped' | false + %i(pending created skipped success) | true | 'skipped' | false + %i(running created skipped success) | true | 'skipped' | false + %i(success waiting_for_resource) | false | 'waiting_for_resource' | false + %i(success manual) | false | 'manual' | false + %i(success scheduled) | false | 'scheduled' | false + %i(created preparing) | false | 'preparing' | false + %i(created success pending) | false | 'running' | false + %i(skipped success failed) | false | 'failed' | false + %i(skipped success failed) | true | 'skipped' | false + %i(success manual) | true | 'pending' | false + %i(success failed created) | true | 'pending' | false end with_them do @@ -57,11 +65,12 @@ RSpec.describe Gitlab::Ci::Status::Composite do end context 'allow_failure: true' do - where(:build_statuses, :result, :has_warnings) do - %i(manual) | 'skipped' | false - %i(skipped failed) | 'success' | true - %i(created failed) | 'created' | true - %i(preparing manual) | 'preparing' | false + where(:build_statuses, :dag, :result, :has_warnings) do + %i(manual) | false | 'skipped' | false + %i(skipped failed) | false | 'success' | true + %i(skipped failed) | true | 'skipped' | true + %i(created failed) | false | 'created' | true + %i(preparing manual) | false | 'preparing' | false end with_them do |