Fix flaky token bucket CI (#338)

This commit is contained in:
Tanguy 2023-01-18 16:02:00 +01:00 committed by GitHub
parent c65cc4c136
commit 4ada7fc0e1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -28,25 +28,28 @@ suite "Token Bucket":
bucket.tryConsume(100) == false
test "Async test":
var bucket = TokenBucket.new(1000, 1.seconds)
var bucket = TokenBucket.new(1000, 500.milliseconds)
check: bucket.tryConsume(1000) == true
var toWait = newSeq[Future[void]]()
for _ in 0..<150:
toWait.add(bucket.consume(10))
for _ in 0..<15:
toWait.add(bucket.consume(100))
let start = Moment.now()
waitFor(allFutures(toWait))
let duration = Moment.now() - start
check: duration in 1400.milliseconds .. 1600.milliseconds
check: duration in 700.milliseconds .. 1100.milliseconds
test "Over budget async":
var bucket = TokenBucket.new(100, 10.milliseconds)
# Consume 10* the budget cap
let beforeStart = Moment.now()
waitFor(bucket.consume(1000).wait(1.seconds))
check Moment.now() - beforeStart in 80.milliseconds .. 120.milliseconds
when not defined(macosx):
# CI's macos scheduler is so jittery that this tests sometimes takes >500ms
# the test will still fail if it's >1 seconds
check Moment.now() - beforeStart in 90.milliseconds .. 150.milliseconds
test "Sync manual replenish":
var bucket = TokenBucket.new(1000, 0.seconds)
@ -104,12 +107,11 @@ suite "Token Bucket":
# to tick one. Check that we can eventually
# consume, even if we update multiple time
# before that
waitFor(sleepAsync(200.milliseconds))
check bucket.tryConsume(1) == false
waitFor(sleepAsync(200.milliseconds))
check bucket.tryConsume(1) == false
waitFor(sleepAsync(200.milliseconds))
check bucket.tryConsume(1) == true
let start = Moment.now()
while Moment.now() - start >= 514.milliseconds:
check bucket.tryConsume(1) == false
waitFor(sleepAsync(10.milliseconds))
check bucket.tryConsume(1) == false
test "Short replenish":