aboutsummaryrefslogtreecommitdiffstats
path: root/tests/internals/test_rate_limiter.c
diff options
context:
space:
mode:
authorMartin Pärtel <martin.partel@gmail.com>2014-06-30 22:50:14 +0100
committerMartin Pärtel <martin.partel@gmail.com>2014-06-30 22:50:14 +0100
commit9bf3ec8cd48c835e02ff96cd97d1581b2f9ba5b3 (patch)
tree05e8bfc74fdb13c1724991e3ee57308c7cf4a9a7 /tests/internals/test_rate_limiter.c
parent3f7daee57d1e57ef522447fd601805971bb358c8 (diff)
downloadbindfs-9bf3ec8cd48c835e02ff96cd97d1581b2f9ba5b3.tar.gz
Implemented rate limiter.
Fixes #12.
Diffstat (limited to 'tests/internals/test_rate_limiter.c')
-rw-r--r--tests/internals/test_rate_limiter.c68
1 files changed, 68 insertions, 0 deletions
diff --git a/tests/internals/test_rate_limiter.c b/tests/internals/test_rate_limiter.c
new file mode 100644
index 0000000..93cdda5
--- /dev/null
+++ b/tests/internals/test_rate_limiter.c
@@ -0,0 +1,68 @@
+
+#include "test_common.h"
+#include "rate_limiter.h"
+
+static const double epsilon = 0.000000000001;
+
+static volatile double time_now = 123123.0;
+
+double test_clock()
+{
+ return time_now;
+}
+
+void computes_correct_sleep_times()
+{
+ time_now = 123123.0;
+ RateLimiter limiter;
+ rate_limiter_init(&limiter, 10, &test_clock);
+
+ double sleep_time = rate_limiter_wait_nosleep(&limiter, 30);
+ TEST_ASSERT(NEAR(3.0 + rate_limiter_idle_credit, sleep_time, epsilon));
+ sleep_time = rate_limiter_wait_nosleep(&limiter, 20);
+ TEST_ASSERT(NEAR(5.0 + rate_limiter_idle_credit, sleep_time, epsilon));
+
+ time_now += 0.5;
+ sleep_time = rate_limiter_wait_nosleep(&limiter, 30);
+ TEST_ASSERT(NEAR(7.5 + rate_limiter_idle_credit, sleep_time, epsilon));
+
+ rate_limiter_destroy(&limiter);
+}
+
+void works_after_being_idle()
+{
+ time_now = 123123.0;
+ RateLimiter limiter;
+ rate_limiter_init(&limiter, 10, &test_clock);
+
+ double sleep_time = rate_limiter_wait_nosleep(&limiter, 30);
+ TEST_ASSERT(NEAR(3.0 + rate_limiter_idle_credit, sleep_time, epsilon));
+ time_now += 100;
+
+ sleep_time = rate_limiter_wait_nosleep(&limiter, 20);
+ TEST_ASSERT(NEAR(2 + rate_limiter_idle_credit, sleep_time, epsilon));
+
+ rate_limiter_destroy(&limiter);
+}
+
+void sleeps_correct_amount()
+{
+ RateLimiter limiter;
+ rate_limiter_init(&limiter, 10, &gettimeofday_clock);
+
+ double start = gettimeofday_clock();
+ rate_limiter_wait(&limiter, 5);
+ double elapsed = gettimeofday_clock() - start;
+ TEST_ASSERT(NEAR(0.5, elapsed, 0.2));
+
+ rate_limiter_destroy(&limiter);
+}
+
+void rate_limiter_suite()
+{
+ computes_correct_sleep_times();
+ works_after_being_idle();
+ sleeps_correct_amount();
+}
+
+TEST_MAIN(rate_limiter_suite);