Welcome to mirror list, hosted at ThFree Co, Russian Federation.

build_service_shared_examples.rb « users « services « shared_examples « support « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 6a8695e178675e32e5e4c9d2f472eac56e8a203a (plain)
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
# frozen_string_literal: true

RSpec.shared_examples 'common user build items' do
  it { is_expected.to be_valid }

  it 'sets the created_by_id' do
    expect(user.created_by_id).to eq(current_user&.id)
  end

  it 'calls UpdateCanonicalEmailService' do
    expect(Users::UpdateCanonicalEmailService).to receive(:new).and_call_original

    user
  end

  context 'when user_type is provided' do
    context 'when project_bot' do
      before do
        params.merge!({ user_type: :project_bot })
      end

      it { expect(user.project_bot?).to be true }
    end

    context 'when not a project_bot' do
      before do
        params.merge!({ user_type: :alert_bot })
      end

      it { expect(user).to be_human }
    end
  end
end

RSpec.shared_examples_for 'current user not admin build items' do
  using RSpec::Parameterized::TableSyntax

  context 'with "user_default_external" application setting' do
    where(:user_default_external, :external, :email, :user_default_internal_regex, :result) do
      true  | nil   | 'fl@example.com'        | nil                     | true
      true  | true  | 'fl@example.com'        | nil                     | true
      true  | false | 'fl@example.com'        | nil                     | true # admin difference

      true  | nil   | 'fl@example.com'        | ''                      | true
      true  | true  | 'fl@example.com'        | ''                      | true
      true  | false | 'fl@example.com'        | ''                      | true # admin difference

      true  | nil   | 'fl@example.com'        | '^(?:(?!\.ext@).)*$\r?' | false
      true  | true  | 'fl@example.com'        | '^(?:(?!\.ext@).)*$\r?' | false # admin difference
      true  | false | 'fl@example.com'        | '^(?:(?!\.ext@).)*$\r?' | false

      true  | nil   | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | true
      true  | true  | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | true
      true  | false | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | true # admin difference

      false | nil   | 'fl@example.com'        | nil                     | false
      false | true  | 'fl@example.com'        | nil                     | false # admin difference
      false | false | 'fl@example.com'        | nil                     | false

      false | nil   | 'fl@example.com'        | ''                      | false
      false | true  | 'fl@example.com'        | ''                      | false # admin difference
      false | false | 'fl@example.com'        | ''                      | false

      false | nil   | 'fl@example.com'        | '^(?:(?!\.ext@).)*$\r?' | false
      false | true  | 'fl@example.com'        | '^(?:(?!\.ext@).)*$\r?' | false # admin difference
      false | false | 'fl@example.com'        | '^(?:(?!\.ext@).)*$\r?' | false

      false | nil   | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | false
      false | true  | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | false # admin difference
      false | false | 'tester.ext@domain.com' | '^(?:(?!\.ext@).)*$\r?' | false
    end

    with_them do
      before do
        stub_application_setting(user_default_external: user_default_external)
        stub_application_setting(user_default_internal_regex: user_default_internal_regex)

        params.merge!({ external: external, email: email }.compact)
      end

      it 'sets the value of Gitlab::CurrentSettings.user_default_external' do
        expect(user.external).to eq(result)
      end
    end
  end

  context 'when "send_user_confirmation_email" application setting is true' do
    before do
      stub_application_setting(send_user_confirmation_email: true, signup_enabled?: true)
    end

    it 'does not confirm the user' do
      expect(user).not_to be_confirmed
    end
  end

  context 'when "send_user_confirmation_email" application setting is false' do
    before do
      stub_application_setting(send_user_confirmation_email: false, signup_enabled?: true)
    end

    it 'confirms the user' do
      expect(user).to be_confirmed
    end
  end

  context 'with allowed params' do
    let(:params) do
      {
        email: 1,
        name: 1,
        password: 1,
        password_automatically_set: 1,
        username: 1,
        user_type: 'project_bot'
      }
    end

    it 'sets all allowed attributes' do
      expect(User).to receive(:new).with(hash_including(params)).and_call_original

      user
    end
  end
end