Asana/ruby-asana

View on GitHub
spec/asana/authentication/oauth2/access_token_authentication_spec.rb

Summary

Maintainability
A
0 mins
Test Coverage
# frozen_string_literal: true

RSpec.describe Asana::Authentication::OAuth2::AccessTokenAuthentication do
  describe described_class do
    let(:auth) { described_class.new(token) }

    context 'if the token is not expired' do
      let(:token) do
        instance_double(OAuth2::AccessToken, expired?: false, token: 'TOKEN')
      end

      it 'configures Faraday to use OAuth2 with an access token' do
        allow(token).to receive(:refresh!)
        conn = Faraday.new do |builder|
          auth.configure(builder)
        end
        expect(token).not_to have_received(:refresh!)
        expect(conn.builder.handlers).to include(Faraday::Request::Authorization)
      end
    end

    context 'if the token is expired' do
      let(:token) do
        instance_double(OAuth2::AccessToken, expired?: true, token: 'TOKEN')
      end

      it 'refreshes the token and uses the new one' do
        allow(token).to receive(:refresh!) { token }
        conn = Faraday.new do |builder|
          auth.configure(builder)
        end
        expect(token).to have_received(:refresh!)
        expect(conn.builder.handlers).to include(Faraday::Request::Authorization)
      end
    end
  end
end