Skip to content

Commit

Permalink
add tests to cover the ratelimiting behavior
Browse files Browse the repository at this point in the history
  • Loading branch information
shtlrs committed Mar 20, 2024
1 parent 14e4765 commit 0eded05
Showing 1 changed file with 88 additions and 0 deletions.
88 changes: 88 additions & 0 deletions test/integration/test_http_ratelimit.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
import copy
import time
import unittest.mock

import tornado.testing
import tornado.web

from pinnwand import app
from configuration import ConfigurationProvider


class RateLimitTestCase(tornado.testing.AsyncHTTPTestCase):

def get_app(self) -> tornado.web.Application:
return app.make_application()

def test_ratelimit_verification_on_endpoints(self):
with unittest.mock.patch("pinnwand.defensive.should_be_ratelimited") as patch:
patch.return_value = False

self.fetch(
"/",
method="GET",
)

patch.assert_called()
patch.reset_mock()

def test_ratelimit_application_on_one_client(self):
configuration = ConfigurationProvider.get_config()
ratelimlit_copy = copy.deepcopy(configuration._ratelimit)
ratelimlit_copy["read"]["capacity"] = 2
ratelimlit_copy["read"]["consume"] = 2
ratelimlit_copy["read"]["refill"] = 1

with unittest.mock.patch.dict("pinnwand.defensive.ConfigurationProvider._config._ratelimit", ratelimlit_copy):
response = self.fetch(
"/",
method="GET",
)

assert response.code == 200

response = self.fetch(
"/",
method="GET",
)

assert response.code == 429

def test_ratelimit_application_on_multiple_clients(self):
configuration = ConfigurationProvider.get_config()
ratelimlit_copy = copy.deepcopy(configuration._ratelimit)
ratelimlit_copy["read"]["capacity"] = 10
ratelimlit_copy["read"]["consume"] = 7
ratelimlit_copy["read"]["refill"] = 1

ip1 = "192.168.15.32"
ip2 = "10.45.134.23"

with unittest.mock.patch.dict("pinnwand.defensive.ConfigurationProvider._config._ratelimit", ratelimlit_copy):
assert should_be_ratelimited(ip1, "read") is False
assert should_be_ratelimited(ip1, "read") is True
assert should_be_ratelimited(ip2, "read") is False
assert should_be_ratelimited(ip2, "read") is True
assert should_be_ratelimited(ip2, "read") is True
time.sleep(10) # Give it enough time to replenish
assert should_be_ratelimited(ip1, "read") is False
assert should_be_ratelimited(ip2, "read") is False

def test_bucket_tokens_consumption(self):
configuration = ConfigurationProvider.get_config()
ratelimlit_copy = copy.deepcopy(configuration._ratelimit)
area = "read"
consumption = 7
capacity = 10
ratelimlit_copy[area]["capacity"] = capacity
ratelimlit_copy[area]["consume"] = consumption
ratelimlit_copy[area]["refill"] = 1

ip = "192.168.15.32"
with unittest.mock.patch.dict("pinnwand.defensive.ConfigurationProvider._config._ratelimit", ratelimlit_copy):
import defensive
defensive.should_be_ratelimited(ip, area)
limiter = defensive.ratelimit_area[area]
tokens_remaining = limiter._storage.get_token_count(ip.encode("utf-8"))
assert tokens_remaining == capacity - consumption

0 comments on commit 0eded05

Please sign in to comment.