Sha256: 6f71454a27e779a684faccd79caccd34e76032f3fbf1e73dc696bb7e589ec74c
Contents?: true
Size: 1.78 KB
Versions: 12
Compression:
Stored size: 1.78 KB
Contents
require 'spec_helper' describe Rack::OAuth2::Server::Authorize::Extension::IdToken do subject { response } let(:request) { Rack::MockRequest.new app } let(:response) { request.get("/?response_type=id_token&client_id=client") } let(:redirect_uri) { 'http://client.example.com/callback' } 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.id_token = id_token response.private_key = private_key response.approve! end end its(:status) { should == 302 } its(:location) { should == "#{redirect_uri}#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}#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.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.approve! end end it do expect { response }.should raise_error AttrRequired::AttrMissing, "'id_token', 'private_key' required." end end end
Version data entries
12 entries across 12 versions & 1 rubygems