2020-10-12 20:18:49 +00:00
|
|
|
import pytest
|
2020-10-12 20:31:33 +00:00
|
|
|
from rrl import Tier, RateLimiter, RateLimitExceeded, _get_redis_connection
|
2020-10-12 20:18:49 +00:00
|
|
|
from freezegun import freeze_time
|
|
|
|
|
2020-10-12 20:30:32 +00:00
|
|
|
redis = _get_redis_connection()
|
2020-10-12 20:22:20 +00:00
|
|
|
simple_minute_tier = Tier("10/minute", 10, 0, 0)
|
|
|
|
simple_hour_tier = Tier("10/hour", 0, 10, 0)
|
|
|
|
simple_daily_tier = Tier("10/day", 0, 0, 10)
|
|
|
|
long_minute_short_hour_tier = Tier("long_min_short_hour", 100, 10, 0)
|
|
|
|
everything_set_short_day_tier = Tier("everything_set", 100, 100, 10)
|
2020-10-12 20:18:49 +00:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"tier,reset_time",
|
|
|
|
[
|
|
|
|
(simple_minute_tier, 60),
|
|
|
|
(simple_hour_tier, 3600),
|
|
|
|
(simple_daily_tier, 60 * 60 * 25),
|
2020-10-12 20:22:20 +00:00
|
|
|
(long_minute_short_hour_tier, 3600),
|
|
|
|
(everything_set_short_day_tier, 60 * 60 * 25),
|
2020-10-12 20:18:49 +00:00
|
|
|
],
|
|
|
|
)
|
|
|
|
def test_check_limit_per_minute(tier, reset_time):
|
|
|
|
redis.flushall()
|
|
|
|
rl = RateLimiter(tiers=[tier], use_redis_time=False)
|
|
|
|
|
|
|
|
count = 0
|
|
|
|
with freeze_time() as frozen:
|
|
|
|
# don't loop infinitely if test is failing
|
|
|
|
while count < 20:
|
|
|
|
try:
|
|
|
|
rl.check_limit("test-zone", "test-key", tier.name)
|
|
|
|
count += 1
|
|
|
|
except RateLimitExceeded as e:
|
|
|
|
print(e)
|
|
|
|
break
|
|
|
|
# assert that we broke after 10
|
|
|
|
assert count == 10
|
|
|
|
# resets after a given time
|
|
|
|
frozen.tick(reset_time)
|
|
|
|
assert rl.check_limit("test-zone", "test-key", tier.name)
|