Commit 33c88f9b authored by Peter Leitzen's avatar Peter Leitzen

Improve performance of project filter_by_feature_visibility spec

Use `let_it_be_with_reload` + `update!` to avoid repetitive project
factory creations.
parent dc616b28
......@@ -4581,53 +4581,49 @@ RSpec.describe Project, factory_default: :keep do
include ProjectHelpers
let_it_be(:group) { create(:group) }
let_it_be_with_reload(:project) { create(:project, namespace: group) }
let!(:project) { create(:project, project_level, namespace: group ) }
let(:user) { create_user_from_membership(project, membership) }
context 'reporter level access' do
let(:feature) { MergeRequest }
where(:project_level, :feature_access_level, :membership, :admin_mode, :expected_count) do
permission_table_for_reporter_feature_access
end
subject { described_class.filter_by_feature_visibility(feature, user) }
with_them do
it "respects visibility" do
shared_examples 'filter respects visibility' do
it 'respects visibility' do
enable_admin_mode!(user) if admin_mode
project.update!(visibility_level: Gitlab::VisibilityLevel.level_value(project_level.to_s))
update_feature_access_level(project, feature_access_level)
expected_objects = expected_count == 1 ? [project] : []
expect(
described_class.filter_by_feature_visibility(feature, user)
).to eq(expected_objects)
end
expect(subject).to eq(expected_objects)
end
end
context 'issues' do
let(:feature) { Issue }
context 'with reporter level access' do
let(:feature) { MergeRequest }
where(:project_level, :feature_access_level, :membership, :admin_mode, :expected_count) do
permission_table_for_guest_feature_access
permission_table_for_reporter_feature_access
end
with_them do
it "respects visibility" do
enable_admin_mode!(user) if admin_mode
update_feature_access_level(project, feature_access_level)
it_behaves_like 'filter respects visibility'
end
end
expected_objects = expected_count == 1 ? [project] : []
context 'with feature issues' do
let(:feature) { Issue }
expect(
described_class.filter_by_feature_visibility(feature, user)
).to eq(expected_objects)
where(:project_level, :feature_access_level, :membership, :admin_mode, :expected_count) do
permission_table_for_guest_feature_access
end
with_them do
it_behaves_like 'filter respects visibility'
end
end
context 'wiki' do
context 'with feature wiki' do
let(:feature) { :wiki }
where(:project_level, :feature_access_level, :membership, :admin_mode, :expected_count) do
......@@ -4635,20 +4631,11 @@ RSpec.describe Project, factory_default: :keep do
end
with_them do
it "respects visibility" do
enable_admin_mode!(user) if admin_mode
update_feature_access_level(project, feature_access_level)
expected_objects = expected_count == 1 ? [project] : []
expect(
described_class.filter_by_feature_visibility(feature, user)
).to eq(expected_objects)
end
it_behaves_like 'filter respects visibility'
end
end
context 'code' do
context 'with feature code' do
let(:feature) { :repository }
where(:project_level, :feature_access_level, :membership, :admin_mode, :expected_count) do
......@@ -4656,16 +4643,7 @@ RSpec.describe Project, factory_default: :keep do
end
with_them do
it "respects visibility" do
enable_admin_mode!(user) if admin_mode
update_feature_access_level(project, feature_access_level)
expected_objects = expected_count == 1 ? [project] : []
expect(
described_class.filter_by_feature_visibility(feature, user)
).to eq(expected_objects)
end
it_behaves_like 'filter respects visibility'
end
end
end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment