Sha256: 9eac558055f966ec698ece2ec73586df223b72e4f3e9bea41a560acab8f4dc33

Contents?: true

Size: 1.32 KB

Versions: 4

Compression:

Stored size: 1.32 KB

Contents

# frozen_string_literal: true
RSpec.describe FinAppsCore::Middleware::NoEncodingBasicAuthentication do
  let(:valid_credentials) { VALID_CREDENTIALS }
  let(:key) { FinAppsCore::Middleware::NoEncodingBasicAuthentication::KEY }

  describe '#call' do
    fake_app = proc {|env| env }

    context 'when credentials were provided' do
      let(:middleware) do
        FinAppsCore::Middleware::NoEncodingBasicAuthentication.new(fake_app, VALID_CREDENTIALS[:token])
      end
      let(:expected_header) { "Basic #{valid_credentials[:token]}" }

      context 'when header was not previously set' do
        let(:request_env) { {request_headers: {}} }
        subject(:actual_header) { middleware.call(request_env)[:request_headers][key] }

        it('generates a header') { expect(actual_header).to eq(expected_header) }
      end

      context 'when header was previously set' do
        let(:existing_header) { {FinAppsCore::Middleware::NoEncodingBasicAuthentication::KEY => 'foo'} }
        let(:request_env) { {request_headers: existing_header} }
        subject(:actual_header) { middleware.call(request_env)[:request_headers][key] }

        it('does not override existing header') { expect(actual_header).to eq('foo') }
        it('does not generate a header') { expect(actual_header).to_not eq(expected_header) }
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
finapps_core-2.0.5 spec/middleware/request/no_encoding_basic_authentication_spec.rb
finapps_core-2.0.4 spec/middleware/request/no_encoding_basic_authentication_spec.rb
finapps_core-2.0.3 spec/middleware/request/no_encoding_basic_authentication_spec.rb
finapps_core-2.0.2 spec/middleware/request/no_encoding_basic_authentication_spec.rb