summaryrefslogtreecommitdiff
path: root/spec/services/users/signup_service_spec.rb
blob: ef532e01d0bb81286e692fa226ad9aa58ec10c6b (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
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Users::SignupService do
  let(:user) { create(:user, setup_for_company: true) }

  describe '#execute' do
    context 'when updating name' do
      it 'updates the name attribute' do
        result = update_user(user, name: 'New Name')

        expect(result.success?).to be(true)
        expect(user.reload.name).to eq('New Name')
      end

      it 'returns an error result when name is missing' do
        result = update_user(user, name: '')

        expect(user.reload.name).not_to be_blank
        expect(result.success?).to be(false)
        expect(result.message).to include("Name can't be blank")
      end
    end

    context 'when updating role' do
      it 'updates the role attribute' do
        result = update_user(user, role: 'development_team_lead')

        expect(result.success?).to be(true)
        expect(user.reload.role).to eq('development_team_lead')
      end

      it 'returns an error result when role is missing' do
        result = update_user(user, role: '')

        expect(user.reload.role).not_to be_blank
        expect(result.success?).to be(false)
        expect(result.message).to eq("Role can't be blank")
      end
    end

    context 'when updating setup_for_company' do
      it 'updates the setup_for_company attribute' do
        result = update_user(user, setup_for_company: 'false')

        expect(result.success?).to be(true)
        expect(user.reload.setup_for_company).to be(false)
      end

      context 'when on .com' do
        before do
          allow(Gitlab).to receive(:com?).and_return(true)
        end

        it 'returns an error result when setup_for_company is missing' do
          result = update_user(user, setup_for_company: '')

          expect(user.reload.setup_for_company).not_to be_blank
          expect(result.success?).to be(false)
          expect(result.message).to eq("Setup for company can't be blank")
        end
      end

      context 'when not on .com' do
        it 'returns success when setup_for_company is blank' do
          result = update_user(user, setup_for_company: '')

          expect(result.success?).to be(true)
          expect(user.reload.setup_for_company).to be(nil)
        end
      end
    end

    def update_user(user, opts)
      described_class.new(user, opts).execute
    end
  end
end