File: protected_tag_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 (69 lines) | stat: -rw-r--r-- 2,400 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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe ProtectedTag, feature_category: :source_code_management do
  it_behaves_like 'protected ref', :protected_tag
  it_behaves_like 'protected ref with access levels for', :create

  describe 'Associations' do
    it { is_expected.to belong_to(:project).touch(true) }
    it { is_expected.to have_many(:create_access_levels).inverse_of(:protected_tag) }
  end

  describe 'Validation' do
    it { is_expected.to validate_presence_of(:project) }
  end

  describe '#protected?' do
    let(:project) { create(:project, :repository) }

    it 'returns true when the tag matches a protected tag via direct match' do
      create(:protected_tag, project: project, name: 'foo')

      expect(described_class.protected?(project, 'foo')).to eq(true)
    end

    it 'returns true when the tag matches a protected tag via wildcard match' do
      create(:protected_tag, project: project, name: 'production/*')

      expect(described_class.protected?(project, 'production/some-tag')).to eq(true)
    end

    it 'returns false when the tag does not match a protected tag via direct match' do
      expect(described_class.protected?(project, 'foo')).to eq(false)
    end

    it 'returns false when the tag does not match a protected tag via wildcard match' do
      create(:protected_tag, project: project, name: 'production/*')

      expect(described_class.protected?(project, 'staging/some-tag')).to eq(false)
    end

    it 'returns false when tag name is nil' do
      expect(described_class.protected?(project, nil)).to eq(false)
    end

    context 'with caching', :request_store do
      let_it_be(:project) { create(:project, :repository) }
      let_it_be(:protected_tag) { create(:protected_tag, project: project, name: 'foo') }

      it 'correctly invalidates a cache' do
        expect(described_class.protected?(project, 'foo')).to eq(true)
        expect(described_class.protected?(project, 'bar')).to eq(false)

        create(:protected_tag, project: project, name: 'bar')

        expect(described_class.protected?(project, 'bar')).to eq(true)
      end

      it 'correctly uses the cached version' do
        expect(project).to receive(:protected_tags).once.and_call_original

        2.times do
          expect(described_class.protected?(project, protected_tag.name)).to eq(true)
        end
      end
    end
  end
end