Sha256: f9a483f0481b385d0a7a36f295db609092ae889f2451db0d7ee1c19641ef1411

Contents?: true

Size: 1.84 KB

Versions: 40

Compression:

Stored size: 1.84 KB

Contents

require 'test/spec'

require 'rack/auth/basic'
require 'rack/mock'

context 'Rack::Auth::Basic' do

  def realm
    'WallysWorld'
  end
  
  def unprotected_app
    lambda { |env| [ 200, {'Content-Type' => 'text/plain'}, ["Hi #{env['REMOTE_USER']}"] ] }
  end
  
  def protected_app
    app = Rack::Auth::Basic.new(unprotected_app) { |username, password| 'Boss' == username }
    app.realm = realm
    app
  end

  setup do
    @request = Rack::MockRequest.new(protected_app)
  end

  def request_with_basic_auth(username, password, &block)
    request 'HTTP_AUTHORIZATION' => 'Basic ' + ["#{username}:#{password}"].pack("m*"), &block
  end

  def request(headers = {})
    yield @request.get('/', headers)
  end

  def assert_basic_auth_challenge(response)
    response.should.be.a.client_error
    response.status.should.equal 401
    response.should.include 'WWW-Authenticate'
    response.headers['WWW-Authenticate'].should =~ /Basic realm="/
    response.body.should.be.empty
  end

  specify 'should challenge correctly when no credentials are specified' do
    request do |response|
      assert_basic_auth_challenge response
    end
  end

  specify 'should rechallenge if incorrect credentials are specified' do
    request_with_basic_auth 'joe', 'password' do |response|
      assert_basic_auth_challenge response
    end
  end

  specify 'should return application output if correct credentials are specified' do
    request_with_basic_auth 'Boss', 'password' do |response|
      response.status.should.equal 200
      response.body.to_s.should.equal 'Hi Boss'
    end
  end
  
  specify 'should return 400 Bad Request if different auth scheme used' do
    request 'HTTP_AUTHORIZATION' => 'Digest params' do |response|
      response.should.be.a.client_error
      response.status.should.equal 400
      response.should.not.include 'WWW-Authenticate'
    end
  end

end

Version data entries

40 entries across 40 versions & 10 rubygems

Version Path
3mix-castronaut-0.5.0.2 vendor/rack/test/spec_rack_auth_basic.rb
kastner-rack-0.3.171 test/spec_rack_auth_basic.rb
kastner-rack-0.3.186 test/spec_rack_auth_basic.rb
masover-castronaut-0.4.4.4 vendor/rack/test/spec_rack_auth_basic.rb
masover-castronaut-0.4.4.5 vendor/rack/test/spec_rack_auth_basic.rb
masover-castronaut-0.5.0.1 vendor/rack/test/spec_rack_auth_basic.rb
p8-castronaut-0.6.1.1 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.2.0 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.2.5 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.3.0 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.3.5 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.3.6 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.4.1 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.4.2 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.4.3 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.4.4 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.4.5 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.4.6 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.5.0 vendor/rack/test/spec_rack_auth_basic.rb
relevance-castronaut-0.5.1 vendor/rack/test/spec_rack_auth_basic.rb