File: extending_request_object_spec.rb

package info (click to toggle)
ruby-rack-attack 6.8.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 384 kB
  • sloc: ruby: 2,689; makefile: 4
file content (32 lines) | stat: -rw-r--r-- 734 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
# frozen_string_literal: true

require_relative "../spec_helper"

describe "Extending the request object" do
  before do
    Rack::Attack::Request.define_method :authorized? do
      env["APIKey"] == "private-secret"
    end

    Rack::Attack.blocklist("unauthorized requests") do |request|
      !request.authorized?
    end
  end

  # We don't want the extension to leak to other test cases
  after do
    Rack::Attack::Request.undef_method :authorized?
  end

  it "forbids request if blocklist condition is true" do
    get "/"

    assert_equal 403, last_response.status
  end

  it "succeeds if blocklist condition is false" do
    get "/", {}, "APIKey" => "private-secret"

    assert_equal 200, last_response.status
  end
end