1# frozen_string_literal: true 2 3require 'spec_helper' 4 5RSpec.describe BlobPolicy do 6 include_context 'ProjectPolicyTable context' 7 include ProjectHelpers 8 using RSpec::Parameterized::TableSyntax 9 10 let(:project) { create(:project, :repository, project_level) } 11 let(:user) { create_user_from_membership(project, membership) } 12 let(:blob) { project.repository.blob_at(SeedRepo::FirstCommit::ID, 'README.md') } 13 14 subject(:policy) { described_class.new(user, blob) } 15 16 where(:project_level, :feature_access_level, :membership, :admin_mode, :expected_count) do 17 permission_table_for_guest_feature_access_and_non_private_project_only 18 end 19 20 with_them do 21 it "grants permission" do 22 enable_admin_mode!(user) if admin_mode 23 update_feature_access_level(project, feature_access_level) 24 25 if expected_count == 1 26 expect(policy).to be_allowed(:read_blob) 27 else 28 expect(policy).to be_disallowed(:read_blob) 29 end 30 end 31 end 32end 33