Software /
code /
prosody
File
tests/test_util_throttle.lua @ 7174:d350e475f94e
util.sql: Raw query debug logging (needs to be explicitly enabled by a plugin)
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Sun, 21 Feb 2016 19:25:01 +0100 |
parent | 7024:8ce592e376ff |
child | 8262:e6f3e440c843 |
line wrap: on
line source
local now = 0; -- wibbly-wobbly... timey-wimey... stuff local function predictable_gettime() return now; end local function later(n) now = now + n; -- time passes at a different rate end local function override_gettime(throttle) local i = 0; repeat i = i + 1; local name = debug.getupvalue(throttle.update, i); if name then debug.setupvalue(throttle.update, i, predictable_gettime); return throttle; end until not name; end function create(create) local a = override_gettime( create(3, 10) ); assert_equal(a:poll(1), true); -- 3 -> 2 assert_equal(a:poll(1), true); -- 2 -> 1 assert_equal(a:poll(1), true); -- 1 -> 0 assert_equal(a:poll(1), false); -- MEEP, out of credits! later(1); -- ... what about assert_equal(a:poll(1), false); -- now? - Still no! later(9); -- Later that day assert_equal(a:poll(1), true); -- Should be back at 3 credits ... 2 end