Sha256: d17d637a4ef2990b325a807898328afd6aa0eefa748daf41f22c3a6185ea1701

Contents?: true

Size: 1.3 KB

Versions: 4

Compression:

Stored size: 1.3 KB

Contents

require 'spec_helper.rb'

describe Rack::OAuth2::Server::Token::AuthorizationCode do
  subject { response }
  let(:request) { Rack::MockRequest.new app }
  let :response do
    request.post('/', :params => {
      :grant_type => 'authorization_code',
      :client_id => 'client_id',
      :code => 'authorization_code',
      :redirect_uri => 'http://client.example.com/callback'
    })
  end
  let :id_token do
    OpenIDConnect::ResponseObject::IdToken.new(
      :iss => 'https://server.example.com',
      :user_id => 'user_id',
      :aud => 'client_id',
      :exp => 1313424327,
      :secret => 'secret'
    )
  end

  context "when id_token is given" do
    let :app do
      Rack::OAuth2::Server::Token.new do |request, response|
        response.access_token = Rack::OAuth2::AccessToken::Bearer.new(:access_token => 'access_token')
        response.id_token = id_token
      end
    end
    its(:status) { should == 200 }
    its(:body)   { should include "\"id_token\":\"#{id_token.to_jwt}\"" }
  end

  context "otherwise" do
    let :app do
      Rack::OAuth2::Server::Token.new do |request, response|
        response.access_token = Rack::OAuth2::AccessToken::Bearer.new(:access_token => 'access_token')
      end
    end
    its(:status) { should == 200 }
    its(:body)   { should_not include "id_token" }
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
openid_connect-0.0.11 spec/rack/oauth2/server/token/authorization_code_spec.rb
openid_connect-0.0.10 spec/rack/oauth2/server/token/authorization_code_spec.rb
openid_connect-0.0.9 spec/rack/oauth2/server/token/authorization_code_spec.rb
openid_connect-0.0.8 spec/rack/oauth2/server/token/authorization_code_spec.rb