File: destroy_secure_file_service_spec.rb

package info (click to toggle)
gitlab 17.6.5-19
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 629,368 kB
  • sloc: ruby: 1,915,304; javascript: 557,307; sql: 60,639; xml: 6,509; sh: 4,567; makefile: 1,239; python: 406
file content (32 lines) | stat: -rw-r--r-- 1,064 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe ::Ci::DestroySecureFileService, feature_category: :continuous_integration do
  let_it_be(:maintainer_user) { create(:user) }
  let_it_be(:developer_user) { create(:user) }
  let_it_be(:project) { create(:project) }
  let_it_be(:secure_file) { create(:ci_secure_file, project: project) }
  let_it_be(:project_member) { create(:project_member, :maintainer, user: maintainer_user, project: project) }
  let_it_be(:project_member2) { create(:project_member, :developer, user: developer_user, project: project) }

  subject { described_class.new(project, user).execute(secure_file) }

  context 'user is a maintainer' do
    let(:user) { maintainer_user }

    it 'destroys the secure file' do
      subject

      expect { secure_file.reload }.to raise_error(ActiveRecord::RecordNotFound)
    end
  end

  context 'user is a developer' do
    let(:user) { developer_user }

    it 'raises an exception' do
      expect { subject }.to raise_error(Gitlab::Access::AccessDeniedError)
    end
  end
end