summaryrefslogtreecommitdiff
path: root/spec/workers/update_highest_role_worker_spec.rb
blob: 0c8ee53da9a386b25d4568f7461cea5d5022c4fe (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
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe UpdateHighestRoleWorker, :clean_gitlab_redis_shared_state do
  include ExclusiveLeaseHelpers

  let(:worker) { described_class.new }

  describe '#perform' do
    context 'when user is not found' do
      it 'does not update or deletes any highest role', :aggregate_failures do
        expect { worker.perform(-1) }.not_to change(UserHighestRole, :count)
      end
    end

    context 'when user is found' do
      let(:active_attributes) do
        {
          state: 'active',
          user_type: nil
        }
      end

      let(:user) { create(:user, active_attributes) }

      subject { worker.perform(user.id) }

      context 'when user is active and not internal' do
        context 'when user highest role exists' do
          it 'updates the highest role for the user' do
            user_highest_role = create(:user_highest_role, user: user)
            create(:group_member, :developer, user: user)

            expect { subject }
              .to change { user_highest_role.reload.highest_access_level }
              .from(nil)
              .to(Gitlab::Access::DEVELOPER)
          end
        end

        context 'when user highest role does not exist' do
          it 'creates the highest role for the user' do
            create(:group_member, :developer, user: user)

            expect { subject }.to change { UserHighestRole.count }.by(1)
          end
        end
      end

      context 'when user is either inactive or internal' do
        using RSpec::Parameterized::TableSyntax

        where(:additional_attributes) do
          [
            { state: 'blocked' },
            { user_type: :alert_bot }
          ]
        end

        with_them do
          it 'deletes highest role' do
            user = create(:user, active_attributes.merge(additional_attributes))
            create(:user_highest_role, user: user)

            expect { worker.perform(user.id) }.to change { UserHighestRole.count }.from(1).to(0)
          end
        end

        context 'when user highest role does not exist' do
          it 'does not delete a highest role' do
            user = create(:user, state: 'blocked')

            expect { worker.perform(user.id) }.not_to change(UserHighestRole, :count)
          end
        end
      end
    end
  end
end