Make sure AtMostOnceBarrier only releases once (or never) #4
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
I realized the implementation of
incr(self, key, amount, maximum, ttl)
assumes a default value of0
if the key does not exist. This means, when the backend (e.g. Redis) loses its contents, we would assume everyAtMostOnceBarrier
never ran. To fix this, the key is now created with a value of-1
(instead of0
) and we only release if by incrementing by1
we stay under the maximum of0
- which can only be true if the previous value was-1
and not with the default of0
.I also added some tests to confirm this bug existed and to confirm this PR fixes it.