summaryrefslogtreecommitdiff
path: root/spec/initializers/100_patch_omniauth_oauth2_spec.rb
blob: 0c436e4ef4594c04444957424ff8711c99280bc4 (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
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe 'OmniAuth::Strategies::OAuth2', type: :strategy do
  let(:strategy) { [OmniAuth::Strategies::OAuth2] }

  it 'verifies the gem version' do
    current_version = OmniAuth::OAuth2::VERSION
    expected_version = '1.7.1'

    expect(current_version).to eq(expected_version), <<~EOF
      New version #{current_version} of the `omniauth-oauth2` gem detected!

      Please check if the monkey patches in `config/initializers_before_autoloader/100_patch_omniauth_oauth2.rb`
      are still needed, and either update/remove them, or bump the version in this spec.

    EOF
  end

  context 'when a custom error message is passed from an OAuth2 provider' do
    let(:message) { 'Please go to https://evil.com' }
    let(:state) { 'secret' }
    let(:callback_path) { '/users/auth/oauth2/callback' }
    let(:params) { { state: state, error: 'evil_key', error_description: message } }
    let(:error) { last_request.env['omniauth.error'] }

    before do
      env('rack.session', { 'omniauth.state' => state })
    end

    it 'returns the custom error message if the state is valid' do
      get callback_path, **params

      expect(error.message).to eq("evil_key | #{message}")
    end

    it 'returns the custom `error_reason` message if the `error_description` is blank' do
      get callback_path, **params.merge(error_description: ' ', error_reason: 'custom reason')

      expect(error.message).to eq('evil_key | custom reason')
    end

    it 'returns a CSRF error if the state is invalid' do
      get callback_path, **params.merge(state: 'invalid')

      expect(error.message).to eq('csrf_detected | CSRF detected')
    end

    it 'returns a CSRF error if the state is missing' do
      get callback_path, **params.without(:state)

      expect(error.message).to eq('csrf_detected | CSRF detected')
    end
  end
end