Sha256: bb8de6e8e3a9ba212c6827d610452d25ae0253d1d716ea383fca9ec3f06c91cf

Contents?: true

Size: 1.18 KB

Versions: 3

Compression:

Stored size: 1.18 KB

Contents

require "logger"

RSpec.describe Rails::Auth::ACL::Middleware do
  let(:request)     { Rack::MockRequest.env_for("https://www.example.com") }
  let(:app)         { ->(env) { [200, env, "Hello, world!"] } }
  let(:acl)         { instance_double(Rails::Auth::ACL, match: authorized) }
  let(:middleware)  { described_class.new(app, acl: acl) }

  context "authorized" do
    let(:authorized) { true }

    it "allows authorized requests" do
      expect(middleware.call(request)[0]).to eq 200
    end
  end

  context "unauthorized" do
    let(:authorized) { false }

    it "raises Rails::Auth::NotAuthorizedError for unauthorized requests" do
      expect { expect(middleware.call(request)) }.to raise_error(Rails::Auth::NotAuthorizedError)
    end
  end

  context "externally authorized requests" do
    let(:authorized) { false }
    let(:external_middleware) do
      Class.new do
        def initialize(app)
          @app = app
        end

        def call(env)
          Rails::Auth.authorized!(env)
          @app.call(env)
        end
      end
    end

    it "allows externally authorized requests" do
      expect(external_middleware.new(middleware).call(request)[0]).to eq 200
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
rails-auth-1.3.0 spec/rails/auth/acl/middleware_spec.rb
rails-auth-1.2.0 spec/rails/auth/acl/middleware_spec.rb
rails-auth-1.1.0 spec/rails/auth/acl/middleware_spec.rb