summaryrefslogtreecommitdiff
path: root/spec/lib/gitlab/mailgun/webhook_processors/member_invites_spec.rb
blob: 3bd364b0d15eb2034601da4e7b15ff1fe7b069ed (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
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Gitlab::Mailgun::WebhookProcessors::MemberInvites do
  describe '#execute', :aggregate_failures do
    let_it_be(:member) { create(:project_member, :invited) }

    let(:raw_invite_token) { member.raw_invite_token }
    let(:payload) do
      {
        'event' => 'failed',
        'severity' => 'permanent',
        'tags' => [Members::Mailgun::INVITE_EMAIL_TAG],
        'user-variables' => { ::Members::Mailgun::INVITE_EMAIL_TOKEN_KEY => raw_invite_token }
      }
    end

    subject(:service) { described_class.new(payload).execute }

    it 'marks the member invite email success as false' do
      expect(Gitlab::AppLogger).to receive(:info).with(
        message: /^UPDATED MEMBER INVITE_EMAIL_SUCCESS/,
        event: 'updated_member_invite_email_success'
      ).and_call_original

      expect { service }.to change { member.reload.invite_email_success }.from(true).to(false)
    end

    context 'when invite token is not found in payload' do
      before do
        payload.delete('user-variables')
      end

      it 'does not change member status and logs an error' do
        expect(Gitlab::AppLogger).not_to receive(:info)
        expect(Gitlab::ErrorTracking).to receive(:track_exception).with(
          an_instance_of(described_class::ProcessWebhookServiceError))

        expect { service }.not_to change { member.reload.invite_email_success }
      end
    end

    shared_examples 'does nothing' do
      it 'does not change member status' do
        expect(Gitlab::AppLogger).not_to receive(:info)

        expect { service }.not_to change { member.reload.invite_email_success }
      end
    end

    context 'when member can not be found' do
      let(:raw_invite_token) { '_foobar_' }

      it_behaves_like 'does nothing'
    end

    context 'when failure is temporary' do
      before do
        payload['severity'] = 'temporary'
      end

      it_behaves_like 'does nothing'
    end

    context 'when email is not a member invite' do
      before do
        payload.delete('tags')
      end

      it_behaves_like 'does nothing'
    end
  end
end