From 36a59d088eca61b834191dacea009677a96c052f Mon Sep 17 00:00:00 2001 From: GitLab Bot Date: Thu, 19 May 2022 07:33:21 +0000 Subject: Add latest changes from gitlab-org/gitlab@15-0-stable-ee --- spec/finders/packages/build_infos_finder_spec.rb | 120 ++++++++++++++---- .../build_infos_for_many_packages_finder_spec.rb | 136 --------------------- 2 files changed, 96 insertions(+), 160 deletions(-) delete mode 100644 spec/finders/packages/build_infos_for_many_packages_finder_spec.rb (limited to 'spec/finders/packages') diff --git a/spec/finders/packages/build_infos_finder_spec.rb b/spec/finders/packages/build_infos_finder_spec.rb index 23425de4316..6e7f0623030 100644 --- a/spec/finders/packages/build_infos_finder_spec.rb +++ b/spec/finders/packages/build_infos_finder_spec.rb @@ -9,7 +9,20 @@ RSpec.describe ::Packages::BuildInfosFinder do let_it_be(:build_infos) { create_list(:package_build_info, 5, :with_pipeline, package: package) } let_it_be(:build_info_with_empty_pipeline) { create(:package_build_info, package: package) } - let(:finder) { described_class.new(package, params) } + let_it_be(:other_package) { create(:package) } + let_it_be(:other_build_infos) { create_list(:package_build_info, 5, :with_pipeline, package: other_package) } + let_it_be(:other_build_info_with_empty_pipeline) { create(:package_build_info, package: other_package) } + + let_it_be(:all_build_infos) { build_infos + other_build_infos } + + let(:finder) { described_class.new(packages, params) } + let(:packages) { nil } + let(:first) { nil } + let(:last) { nil } + let(:after) { nil } + let(:before) { nil } + let(:max_page_size) { nil } + let(:support_next_page) { false } let(:params) do { first: first, @@ -24,41 +37,100 @@ RSpec.describe ::Packages::BuildInfosFinder do describe '#execute' do subject { finder.execute } - where(:first, :last, :after_index, :before_index, :max_page_size, :support_next_page, :expected_build_infos_indexes) do - # F L AI BI MPS SNP - nil | nil | nil | nil | nil | false | [4, 3, 2, 1, 0] - nil | nil | nil | nil | 10 | false | [4, 3, 2, 1, 0] - nil | nil | nil | nil | 2 | false | [4, 3] - 2 | nil | nil | nil | nil | false | [4, 3] - 2 | nil | nil | nil | nil | true | [4, 3, 2] - 2 | nil | 3 | nil | nil | false | [2, 1] - 2 | nil | 3 | nil | nil | true | [2, 1, 0] - 3 | nil | 4 | nil | 2 | false | [3, 2] - 3 | nil | 4 | nil | 2 | true | [3, 2, 1] - nil | 2 | nil | nil | nil | false | [0, 1] - nil | 2 | nil | nil | nil | true | [0, 1, 2] - nil | 2 | nil | 1 | nil | false | [2, 3] - nil | 2 | nil | 1 | nil | true | [2, 3, 4] - nil | 3 | nil | 0 | 2 | false | [1, 2] - nil | 3 | nil | 0 | 2 | true | [1, 2, 3] - end - - with_them do + shared_examples 'returning the expected build infos' do let(:expected_build_infos) do expected_build_infos_indexes.map do |idx| - build_infos[idx] + all_build_infos[idx] end end let(:after) do - build_infos[after_index].pipeline_id if after_index + all_build_infos[after_index].pipeline_id if after_index end let(:before) do - build_infos[before_index].pipeline_id if before_index + all_build_infos[before_index].pipeline_id if before_index end it { is_expected.to eq(expected_build_infos) } end + + context 'with nil packages' do + let(:packages) { nil } + + it { is_expected.to be_empty } + end + + context 'with [] packages' do + let(:packages) { [] } + + it { is_expected.to be_empty } + end + + context 'with empy scope packages' do + let(:packages) { Packages::Package.none } + + it { is_expected.to be_empty } + end + + context 'with a single package' do + let(:packages) { package.id } + + # rubocop: disable Layout/LineLength + where(:first, :last, :after_index, :before_index, :max_page_size, :support_next_page, :expected_build_infos_indexes) do + # F L AI BI MPS SNP + nil | nil | nil | nil | nil | false | [4, 3, 2, 1, 0] + nil | nil | nil | nil | 10 | false | [4, 3, 2, 1, 0] + nil | nil | nil | nil | 2 | false | [4, 3] + 2 | nil | nil | nil | nil | false | [4, 3] + 2 | nil | nil | nil | nil | true | [4, 3, 2] + 2 | nil | 3 | nil | nil | false | [2, 1] + 2 | nil | 3 | nil | nil | true | [2, 1, 0] + 3 | nil | 4 | nil | 2 | false | [3, 2] + 3 | nil | 4 | nil | 2 | true | [3, 2, 1] + nil | 2 | nil | nil | nil | false | [1, 0] + nil | 2 | nil | nil | nil | true | [2, 1, 0] + nil | 2 | nil | 1 | nil | false | [3, 2] + nil | 2 | nil | 1 | nil | true | [4, 3, 2] + nil | 3 | nil | 0 | 2 | false | [2, 1] + nil | 3 | nil | 0 | 2 | true | [3, 2, 1] + end + # rubocop: enable Layout/LineLength + + with_them do + it_behaves_like 'returning the expected build infos' + end + end + + context 'with many packages' do + let(:packages) { [package.id, other_package.id] } + + # using after_index/before_index when receiving multiple packages doesn't + # make sense but we still verify here that the behavior is coherent. + # rubocop: disable Layout/LineLength + where(:first, :last, :after_index, :before_index, :max_page_size, :support_next_page, :expected_build_infos_indexes) do + # F L AI BI MPS SNP + nil | nil | nil | nil | nil | false | [9, 8, 7, 6, 5, 4, 3, 2, 1, 0] + nil | nil | nil | nil | 10 | false | [9, 8, 7, 6, 5, 4, 3, 2, 1, 0] + nil | nil | nil | nil | 2 | false | [9, 8, 4, 3] + 2 | nil | nil | nil | nil | false | [9, 8, 4, 3] + 2 | nil | nil | nil | nil | true | [9, 8, 7, 4, 3, 2] + 2 | nil | 3 | nil | nil | false | [2, 1] + 2 | nil | 3 | nil | nil | true | [2, 1, 0] + 3 | nil | 4 | nil | 2 | false | [3, 2] + 3 | nil | 4 | nil | 2 | true | [3, 2, 1] + nil | 2 | nil | nil | nil | false | [6, 5, 1, 0] + nil | 2 | nil | nil | nil | true | [7, 6, 5, 2, 1, 0] + nil | 2 | nil | 1 | nil | false | [6, 5, 3, 2] + nil | 2 | nil | 1 | nil | true | [7, 6, 5, 4, 3, 2] + nil | 3 | nil | 0 | 2 | false | [6, 5, 2, 1] + nil | 3 | nil | 0 | 2 | true | [7, 6, 5, 3, 2, 1] + end + + with_them do + it_behaves_like 'returning the expected build infos' + end + # rubocop: enable Layout/LineLength + end end end diff --git a/spec/finders/packages/build_infos_for_many_packages_finder_spec.rb b/spec/finders/packages/build_infos_for_many_packages_finder_spec.rb deleted file mode 100644 index f3c79d0c825..00000000000 --- a/spec/finders/packages/build_infos_for_many_packages_finder_spec.rb +++ /dev/null @@ -1,136 +0,0 @@ -# frozen_string_literal: true - -require 'spec_helper' - -RSpec.describe ::Packages::BuildInfosForManyPackagesFinder do - using RSpec::Parameterized::TableSyntax - - let_it_be(:package) { create(:package) } - let_it_be(:build_infos) { create_list(:package_build_info, 5, :with_pipeline, package: package) } - let_it_be(:build_info_with_empty_pipeline) { create(:package_build_info, package: package) } - - let_it_be(:other_package) { create(:package) } - let_it_be(:other_build_infos) { create_list(:package_build_info, 5, :with_pipeline, package: other_package) } - let_it_be(:other_build_info_with_empty_pipeline) { create(:package_build_info, package: other_package) } - - let_it_be(:all_build_infos) { build_infos + other_build_infos } - - let(:finder) { described_class.new(packages, params) } - let(:packages) { nil } - let(:first) { nil } - let(:last) { nil } - let(:after) { nil } - let(:before) { nil } - let(:max_page_size) { nil } - let(:support_next_page) { false } - let(:params) do - { - first: first, - last: last, - after: after, - before: before, - max_page_size: max_page_size, - support_next_page: support_next_page - } - end - - describe '#execute' do - subject { finder.execute } - - shared_examples 'returning the expected build infos' do - let(:expected_build_infos) do - expected_build_infos_indexes.map do |idx| - all_build_infos[idx] - end - end - - let(:after) do - all_build_infos[after_index].pipeline_id if after_index - end - - let(:before) do - all_build_infos[before_index].pipeline_id if before_index - end - - it { is_expected.to eq(expected_build_infos) } - end - - context 'with nil packages' do - let(:packages) { nil } - - it { is_expected.to be_empty } - end - - context 'with [] packages' do - let(:packages) { [] } - - it { is_expected.to be_empty } - end - - context 'with empy scope packages' do - let(:packages) { Packages::Package.none } - - it { is_expected.to be_empty } - end - - context 'with a single package' do - let(:packages) { package.id } - - # rubocop: disable Layout/LineLength - where(:first, :last, :after_index, :before_index, :max_page_size, :support_next_page, :expected_build_infos_indexes) do - # F L AI BI MPS SNP - nil | nil | nil | nil | nil | false | [4, 3, 2, 1, 0] - nil | nil | nil | nil | 10 | false | [4, 3, 2, 1, 0] - nil | nil | nil | nil | 2 | false | [4, 3] - 2 | nil | nil | nil | nil | false | [4, 3] - 2 | nil | nil | nil | nil | true | [4, 3, 2] - 2 | nil | 3 | nil | nil | false | [2, 1] - 2 | nil | 3 | nil | nil | true | [2, 1, 0] - 3 | nil | 4 | nil | 2 | false | [3, 2] - 3 | nil | 4 | nil | 2 | true | [3, 2, 1] - nil | 2 | nil | nil | nil | false | [1, 0] - nil | 2 | nil | nil | nil | true | [2, 1, 0] - nil | 2 | nil | 1 | nil | false | [3, 2] - nil | 2 | nil | 1 | nil | true | [4, 3, 2] - nil | 3 | nil | 0 | 2 | false | [2, 1] - nil | 3 | nil | 0 | 2 | true | [3, 2, 1] - end - # rubocop: enable Layout/LineLength - - with_them do - it_behaves_like 'returning the expected build infos' - end - end - - context 'with many packages' do - let(:packages) { [package.id, other_package.id] } - - # using after_index/before_index when receiving multiple packages doesn't - # make sense but we still verify here that the behavior is coherent. - # rubocop: disable Layout/LineLength - where(:first, :last, :after_index, :before_index, :max_page_size, :support_next_page, :expected_build_infos_indexes) do - # F L AI BI MPS SNP - nil | nil | nil | nil | nil | false | [9, 8, 7, 6, 5, 4, 3, 2, 1, 0] - nil | nil | nil | nil | 10 | false | [9, 8, 7, 6, 5, 4, 3, 2, 1, 0] - nil | nil | nil | nil | 2 | false | [9, 8, 4, 3] - 2 | nil | nil | nil | nil | false | [9, 8, 4, 3] - 2 | nil | nil | nil | nil | true | [9, 8, 7, 4, 3, 2] - 2 | nil | 3 | nil | nil | false | [2, 1] - 2 | nil | 3 | nil | nil | true | [2, 1, 0] - 3 | nil | 4 | nil | 2 | false | [3, 2] - 3 | nil | 4 | nil | 2 | true | [3, 2, 1] - nil | 2 | nil | nil | nil | false | [6, 5, 1, 0] - nil | 2 | nil | nil | nil | true | [7, 6, 5, 2, 1, 0] - nil | 2 | nil | 1 | nil | false | [6, 5, 3, 2] - nil | 2 | nil | 1 | nil | true | [7, 6, 5, 4, 3, 2] - nil | 3 | nil | 0 | 2 | false | [6, 5, 2, 1] - nil | 3 | nil | 0 | 2 | true | [7, 6, 5, 3, 2, 1] - end - - with_them do - it_behaves_like 'returning the expected build infos' - end - # rubocop: enable Layout/LineLength - end - end -end -- cgit v1.2.3