mirror of
https://github.com/samsonjs/rack-attack.git
synced 2026-03-25 09:25:49 +00:00
Merge pull request #269 from grzuy/acceptance_tests
Adds acceptance-oriented tests
This commit is contained in:
commit
66909c6419
5 changed files with 94 additions and 1 deletions
6
Rakefile
6
Rakefile
|
|
@ -11,9 +11,13 @@ namespace :test do
|
|||
Rake::TestTask.new(:integration) do |t|
|
||||
t.pattern = "spec/integration/*_spec.rb"
|
||||
end
|
||||
|
||||
Rake::TestTask.new(:acceptance) do |t|
|
||||
t.pattern = "spec/acceptance/*_spec.rb"
|
||||
end
|
||||
end
|
||||
|
||||
desc 'Run tests'
|
||||
task :test => %w[test:units test:integration]
|
||||
task :test => %w[test:units test:integration test:acceptance]
|
||||
|
||||
task :default => :test
|
||||
|
|
|
|||
|
|
@ -33,4 +33,5 @@ Gem::Specification.new do |s|
|
|||
s.add_development_dependency 'dalli'
|
||||
s.add_development_dependency 'connection_pool'
|
||||
s.add_development_dependency 'memcache-client'
|
||||
s.add_development_dependency "timecop"
|
||||
end
|
||||
|
|
|
|||
21
spec/acceptance/blocking_spec.rb
Normal file
21
spec/acceptance/blocking_spec.rb
Normal file
|
|
@ -0,0 +1,21 @@
|
|||
require_relative "../spec_helper"
|
||||
|
||||
describe "#blocklist" do
|
||||
before do
|
||||
Rack::Attack.blocklist("block 1.2.3.4") do |request|
|
||||
request.ip == "1.2.3.4"
|
||||
end
|
||||
end
|
||||
|
||||
it "forbids request if blocklist condition is true" do
|
||||
get "/", {}, "REMOTE_ADDR" => "1.2.3.4"
|
||||
|
||||
assert_equal 403, last_response.status
|
||||
end
|
||||
|
||||
it "succeeds if blocklist condition is false" do
|
||||
get "/", {}, "REMOTE_ADDR" => "5.6.7.8"
|
||||
|
||||
assert_equal 200, last_response.status
|
||||
end
|
||||
end
|
||||
37
spec/acceptance/safelisting_spec.rb
Normal file
37
spec/acceptance/safelisting_spec.rb
Normal file
|
|
@ -0,0 +1,37 @@
|
|||
require_relative "../spec_helper"
|
||||
|
||||
describe "#safelist" do
|
||||
before do
|
||||
Rack::Attack.blocklist("block 1.2.3.4") do |request|
|
||||
request.ip == "1.2.3.4"
|
||||
end
|
||||
|
||||
Rack::Attack.safelist("safe path") do |request|
|
||||
request.path == "/safe_space"
|
||||
end
|
||||
end
|
||||
|
||||
it "forbids request if blocklist condition is true and safelist is false" do
|
||||
get "/", {}, "REMOTE_ADDR" => "1.2.3.4"
|
||||
|
||||
assert_equal 403, last_response.status
|
||||
end
|
||||
|
||||
it "succeeds if blocklist condition is false and safelist is false" do
|
||||
get "/", {}, "REMOTE_ADDR" => "5.6.7.8"
|
||||
|
||||
assert_equal 200, last_response.status
|
||||
end
|
||||
|
||||
it "succeeds request if blocklist condition is false and safelist is true" do
|
||||
get "/safe_space", {}, "REMOTE_ADDR" => "5.6.7.8"
|
||||
|
||||
assert_equal 200, last_response.status
|
||||
end
|
||||
|
||||
it "succeeds request if both blocklist and safelist conditions are true" do
|
||||
get "/safe_space", {}, "REMOTE_ADDR" => "1.2.3.4"
|
||||
|
||||
assert_equal 200, last_response.status
|
||||
end
|
||||
end
|
||||
30
spec/acceptance/throttling_spec.rb
Normal file
30
spec/acceptance/throttling_spec.rb
Normal file
|
|
@ -0,0 +1,30 @@
|
|||
require_relative "../spec_helper"
|
||||
require "timecop"
|
||||
|
||||
describe "#throttle" do
|
||||
it "allows one request per minute by IP" do
|
||||
Rack::Attack.cache.store = ActiveSupport::Cache::MemoryStore.new
|
||||
|
||||
Rack::Attack.throttle("by ip", limit: 1, period: 60) do |request|
|
||||
request.ip
|
||||
end
|
||||
|
||||
get "/", {}, "REMOTE_ADDR" => "1.2.3.4"
|
||||
|
||||
assert_equal 200, last_response.status
|
||||
|
||||
get "/", {}, "REMOTE_ADDR" => "1.2.3.4"
|
||||
|
||||
assert_equal 429, last_response.status
|
||||
|
||||
get "/", {}, "REMOTE_ADDR" => "5.6.7.8"
|
||||
|
||||
assert_equal 200, last_response.status
|
||||
|
||||
Timecop.travel(60) do
|
||||
get "/", {}, "REMOTE_ADDR" => "1.2.3.4"
|
||||
|
||||
assert_equal 200, last_response.status
|
||||
end
|
||||
end
|
||||
end
|
||||
Loading…
Reference in a new issue