Sha256: c89081d413297b1af4d0e4b5fa0dc92bbdcba080930586ab77be619f4d43ad94

Contents?: true

Size: 1.04 KB

Versions: 6

Compression:

Stored size: 1.04 KB

Contents

# frozen_string_literal: true

RSpec.describe Rails::Auth::ErrorPage::DebugMiddleware do
  let(:request) { Rack::MockRequest.env_for("https://www.example.com") }

  let(:example_config) { fixture_path("example_acl.yml").read }

  let(:example_acl) do
    Rails::Auth::ACL.from_yaml(
      example_config,
      matchers: {
        allow_x509_subject: Rails::Auth::X509::Matcher,
        allow_claims:       ClaimsMatcher
      }
    )
  end

  subject(:middleware) { described_class.new(app, acl: example_acl) }

  context "access granted" do
    let(:code) { 200 }
    let(:app)  { ->(env) { [code, env, "Hello, world!"] } }

    it "renders the expected response" do
      response = middleware.call(request)
      expect(response.first).to eq code
    end
  end

  context "access denied" do
    let(:app) { ->(_env) { raise(Rails::Auth::NotAuthorizedError, "not authorized!") } }

    it "renders the error page" do
      code, _env, body = middleware.call(request)
      expect(code).to eq 403
      expect(body.join).to include("Access Denied")
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
rails-auth-3.2.0 spec/rails/auth/error_page/debug_middleware_spec.rb
rails-auth-3.1.0 spec/rails/auth/error_page/debug_middleware_spec.rb
rails-auth-3.0.0 spec/rails/auth/error_page/debug_middleware_spec.rb
rails-auth-2.2.2 spec/rails/auth/error_page/debug_middleware_spec.rb
rails-auth-2.2.1 spec/rails/auth/error_page/debug_middleware_spec.rb
rails-auth-2.2.0 spec/rails/auth/error_page/debug_middleware_spec.rb