Sha256: 60a724e21f551814ed4ae3dd6386003b49357767df0cf1af1dccd68a9aed2389

Contents?: true

Size: 1.95 KB

Versions: 11

Compression:

Stored size: 1.95 KB

Contents

require 'spec_helper'

describe Rack::OAuth2::Server::Authorize::Extension::CodeAndIdToken do
  subject { response }
  let(:request)      { Rack::MockRequest.new app }
  let(:response)     { request.get("/?response_type=code%20id_token&client_id=client") }
  let(:redirect_uri) { 'http://client.example.com/callback' }
  let(:code)         { 'authorization_code' }
  let :id_token do
    OpenIDConnect::ResponseObject::IdToken.new(
      :iss => 'https://server.example.com',
      :user_id => 'user_id',
      :aud => 'client_id',
      :exp => 1313424327
    )
  end

  context "when id_token is given" do
    let :app do
      Rack::OAuth2::Server::Authorize.new do |request, response|
        response.redirect_uri = redirect_uri
        response.code = code
        response.id_token = id_token
        response.private_key = private_key
        response.approve!
      end
    end
    its(:status)   { should == 302 }
    its(:location) { should == "#{redirect_uri}?code=#{code}#id_token=#{id_token.to_jwt(private_key)}" }

    context 'when id_token is String' do
      let(:id_token) { 'id_token' }
      its(:location) { should == "#{redirect_uri}?code=#{code}#id_token=id_token" }
    end

    context 'when private_key is missing' do
      let :app do
        Rack::OAuth2::Server::Authorize.new do |request, response|
          response.redirect_uri = redirect_uri
          response.code = code
          response.id_token = id_token
          response.approve!
        end
      end
      it do
        expect { response }.should raise_error AttrRequired::AttrMissing, "'private_key' required."
      end
    end
  end

  context "otherwise" do
    let :app do
      Rack::OAuth2::Server::Authorize.new do |request, response|
        response.redirect_uri = redirect_uri
        response.code = code
        response.approve!
      end
    end
    it do
      expect { response }.should raise_error AttrRequired::AttrMissing, "'id_token', 'private_key' required."
    end
  end
end

Version data entries

11 entries across 11 versions & 1 rubygems

Version Path
openid_connect-0.0.26 spec/rack/oauth2/server/authorize/extension/code_and_id_token_spec.rb
openid_connect-0.0.25 spec/rack/oauth2/server/authorize/extension/code_and_id_token_spec.rb
openid_connect-0.0.24 spec/rack/oauth2/server/authorize/extension/code_and_id_token_spec.rb
openid_connect-0.0.23 spec/rack/oauth2/server/authorize/extension/code_and_id_token_spec.rb
openid_connect-0.0.22 spec/rack/oauth2/server/authorize/extension/code_and_id_token_spec.rb
openid_connect-0.0.21 spec/rack/oauth2/server/authorize/extension/code_and_id_token_spec.rb
openid_connect-0.0.20 spec/rack/oauth2/server/authorize/extension/code_and_id_token_spec.rb
openid_connect-0.0.19 spec/rack/oauth2/server/authorize/extension/code_and_id_token_spec.rb
openid_connect-0.0.18 spec/rack/oauth2/server/authorize/extension/code_and_id_token_spec.rb
openid_connect-0.0.17 spec/rack/oauth2/server/authorize/extension/code_and_id_token_spec.rb
openid_connect-0.0.16 spec/rack/oauth2/server/authorize/extension/code_and_id_token_spec.rb