Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
a7243fc1
Commit
a7243fc1
authored
Oct 13, 2017
by
Michael Kozono
Committed by
Francisco Lopez
Nov 17, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix Rubocop offenses
parent
43a682cc
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
13 additions
and
13 deletions
+13
-13
spec/requests/rack_attack_global_spec.rb
spec/requests/rack_attack_global_spec.rb
+13
-13
No files found.
spec/requests/rack_attack_spec.rb
→
spec/requests/rack_attack_
global_
spec.rb
View file @
a7243fc1
require
'spec_helper'
require
'spec_helper'
describe
Rack
::
Attack
do
describe
'Rack Attack global throttles'
do
NUM_TRIES_FOR_REJECTION
=
3
# Flaky tests, have not figured out how to fix it
NUM_TRIES_FOR_REJECTION
=
3
# Flaky tests, have not figured out how to fix it
let
(
:settings
)
{
Gitlab
::
CurrentSettings
.
current_application_settings
}
let
(
:settings
)
{
Gitlab
::
CurrentSettings
.
current_application_settings
}
...
@@ -47,52 +47,52 @@ describe Rack::Attack do
...
@@ -47,52 +47,52 @@ describe Rack::Attack do
it
'rejects requests over the rate limit'
do
it
'rejects requests over the rate limit'
do
# At first, allow requests under the rate limit.
# At first, allow requests under the rate limit.
requests_per_period
.
times
do
requests_per_period
.
times
do
get
*
get_args
get
(
*
get_args
)
expect
(
response
).
to
have_http_status
200
expect
(
response
).
to
have_http_status
200
end
end
# the last straw
# the last straw
expect_rejection
{
get
*
get_args
}
expect_rejection
{
get
(
*
get_args
)
}
end
end
it
'allows requests after throttling and then waiting for the next period'
do
it
'allows requests after throttling and then waiting for the next period'
do
requests_per_period
.
times
do
requests_per_period
.
times
do
get
*
get_args
get
(
*
get_args
)
expect
(
response
).
to
have_http_status
200
expect
(
response
).
to
have_http_status
200
end
end
expect_rejection
{
get
*
get_args
}
expect_rejection
{
get
(
*
get_args
)
}
Timecop
.
travel
((
1
.
second
+
period
).
from_now
)
do
# Add 1 because flaky
Timecop
.
travel
((
1
.
second
+
period
).
from_now
)
do
# Add 1 because flaky
requests_per_period
.
times
do
requests_per_period
.
times
do
get
*
get_args
get
(
*
get_args
)
expect
(
response
).
to
have_http_status
200
expect
(
response
).
to
have_http_status
200
end
end
expect_rejection
{
get
*
get_args
}
expect_rejection
{
get
(
*
get_args
)
}
end
end
end
end
it
'counts requests from different users separately, even from the same IP'
do
it
'counts requests from different users separately, even from the same IP'
do
requests_per_period
.
times
do
requests_per_period
.
times
do
get
*
get_args
get
(
*
get_args
)
expect
(
response
).
to
have_http_status
200
expect
(
response
).
to
have_http_status
200
end
end
# would be over the limit if this wasn't a different user
# would be over the limit if this wasn't a different user
get
*
other_user_get_args
get
(
*
other_user_get_args
)
expect
(
response
).
to
have_http_status
200
expect
(
response
).
to
have_http_status
200
end
end
it
'counts all requests from the same user, even via different IPs'
do
it
'counts all requests from the same user, even via different IPs'
do
requests_per_period
.
times
do
requests_per_period
.
times
do
get
*
get_args
get
(
*
get_args
)
expect
(
response
).
to
have_http_status
200
expect
(
response
).
to
have_http_status
200
end
end
expect_any_instance_of
(
Rack
::
Attack
::
Request
).
to
receive
(
:ip
).
and_return
(
'1.2.3.4'
)
expect_any_instance_of
(
Rack
::
Attack
::
Request
).
to
receive
(
:ip
).
and_return
(
'1.2.3.4'
)
expect_rejection
{
get
*
get_args
}
expect_rejection
{
get
(
*
get_args
)
}
end
end
end
end
...
@@ -104,7 +104,7 @@ describe Rack::Attack do
...
@@ -104,7 +104,7 @@ describe Rack::Attack do
it
'allows requests over the rate limit'
do
it
'allows requests over the rate limit'
do
(
1
+
requests_per_period
).
times
do
(
1
+
requests_per_period
).
times
do
get
*
get_args
get
(
*
get_args
)
expect
(
response
).
to
have_http_status
200
expect
(
response
).
to
have_http_status
200
end
end
end
end
...
@@ -381,7 +381,7 @@ describe Rack::Attack do
...
@@ -381,7 +381,7 @@ describe Rack::Attack do
def
expect_rejection
(
&
block
)
def
expect_rejection
(
&
block
)
NUM_TRIES_FOR_REJECTION
.
times
do
|
i
|
NUM_TRIES_FOR_REJECTION
.
times
do
|
i
|
block
.
call
yield
break
if
response
.
status
==
429
# success
break
if
response
.
status
==
429
# success
Rails
.
logger
.
warn
"Flaky test expected HTTP status 429 but got
#{
response
.
status
}
. Will attempt again (
#{
i
+
1
}
/
#{
NUM_TRIES_FOR_REJECTION
}
)"
Rails
.
logger
.
warn
"Flaky test expected HTTP status 429 but got
#{
response
.
status
}
. Will attempt again (
#{
i
+
1
}
/
#{
NUM_TRIES_FOR_REJECTION
}
)"
end
end
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment