You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
65 lines
1.8 KiB
65 lines
1.8 KiB
3 years ago
|
require "rails_helper"
|
||
|
require_relative "../support/devise"
|
||
|
require "rack/attack"
|
||
|
|
||
|
describe "Rack::Attack" do
|
||
|
let(:limit) { 5 }
|
||
|
let(:under_limit) { limit / 2 }
|
||
|
let(:over_limit) { limit + 1 }
|
||
|
|
||
|
let(:page) { Capybara::Node::Simple.new(response.body) }
|
||
|
let(:notify_client) { instance_double(Notifications::Client) }
|
||
|
let(:devise_notify_mailer) { DeviseNotifyMailer.new }
|
||
|
|
||
|
let(:params) { { user: { email: } } }
|
||
|
let(:user) { FactoryBot.create(:user) }
|
||
|
let(:email) { user.email }
|
||
|
|
||
|
before do
|
||
|
Rack::Attack.enabled = true
|
||
|
allow(DeviseNotifyMailer).to receive(:new).and_return(devise_notify_mailer)
|
||
|
allow(devise_notify_mailer).to receive(:notify_client).and_return(notify_client)
|
||
|
allow(notify_client).to receive(:send_email).and_return(true)
|
||
|
end
|
||
|
|
||
|
after do
|
||
|
Rack::Attack.enabled = false
|
||
|
Rack::Attack.reset!
|
||
|
end
|
||
|
|
||
|
context "when a password reset is requested" do
|
||
|
context "when the number of requests is under the throttle limit" do
|
||
|
it "does not throttle" do
|
||
|
under_limit.times do
|
||
|
post "/users/password", params: params
|
||
|
follow_redirect!
|
||
|
end
|
||
|
last_response = response
|
||
|
expect(last_response.status).to eq(200)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "when the number of requests is at the throttle limit" do
|
||
|
it "does not throttle" do
|
||
|
limit.times do
|
||
|
post "/users/password", params: params
|
||
|
follow_redirect!
|
||
|
end
|
||
|
last_response = response
|
||
|
expect(last_response.status).to eq(200)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "when the number of requests is over the throttle limit" do
|
||
|
it "throttles" do
|
||
|
over_limit.times do
|
||
|
post "/users/password", params: params
|
||
|
follow_redirect!
|
||
|
end
|
||
|
last_response = response
|
||
|
expect(last_response.status).to eq(429)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|