summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBen Bangert <ben@groovie.org>2017-05-31 14:48:07 -0700
committerGitHub <noreply@github.com>2017-05-31 14:48:07 -0700
commitc2db1e99a35fcb81610781a5b69ac3748a5b8d90 (patch)
treec44808fc4a14dbc1ef29470ef851662e9bf50142
parent4f0a742599433be2d07cc989716d6af0d3e4f57a (diff)
parentb7aff3fb63625b992fc36df937ff545ec89155fe (diff)
downloadkazoo-c2db1e99a35fcb81610781a5b69ac3748a5b8d90.tar.gz
Merge pull request #397 from paperlessreceipts/counter-pre-post-values
Counter: expose the previous and changed values.
-rw-r--r--kazoo/recipe/counter.py13
-rw-r--r--kazoo/tests/test_counter.py12
2 files changed, 23 insertions, 2 deletions
diff --git a/kazoo/recipe/counter.py b/kazoo/recipe/counter.py
index 2299742..a2768a3 100644
--- a/kazoo/recipe/counter.py
+++ b/kazoo/recipe/counter.py
@@ -34,10 +34,14 @@ class Counter(object):
counter += 2
counter -= 1
counter.value == 1
+ counter.pre_value == 2
+ counter.post_value == 1
counter = zk.Counter("/float", default=1.0)
counter += 2.0
counter.value == 3.0
+ counter.pre_value == 1.0
+ counter.post_value == 3.0
"""
def __init__(self, client, path, default=0):
@@ -53,6 +57,8 @@ class Counter(object):
self.default = default
self.default_type = type(default)
self._ensured_path = False
+ self.pre_value = None
+ self.post_value = None
def _ensure_node(self):
if not self._ensured_path:
@@ -79,12 +85,15 @@ class Counter(object):
return self
def _inner_change(self, value):
- data, version = self._value()
- data = repr(data + value).encode('ascii')
+ self.pre_value, version = self._value()
+ post_value = self.pre_value + value
+ data = repr(post_value).encode('ascii')
try:
self.client.set(self.path, data, version=version)
except BadVersionError: # pragma: nocover
+ self.post_value = None
raise ForceRetryError()
+ self.post_value = post_value
def __add__(self, value):
"""Add value to counter."""
diff --git a/kazoo/tests/test_counter.py b/kazoo/tests/test_counter.py
index d582a45..50095a2 100644
--- a/kazoo/tests/test_counter.py
+++ b/kazoo/tests/test_counter.py
@@ -33,3 +33,15 @@ class KazooCounterTests(KazooTestCase):
counter = self._makeOne()
self.assertRaises(TypeError, counter.__add__, 2.1)
self.assertRaises(TypeError, counter.__add__, b"a")
+
+ def test_pre_post_values(self):
+ counter = self._makeOne()
+ eq_(counter.value, 0)
+ eq_(counter.pre_value, None)
+ eq_(counter.post_value, None)
+ counter += 2
+ eq_(counter.pre_value, 0)
+ eq_(counter.post_value, 2)
+ counter -= 3
+ eq_(counter.pre_value, 2)
+ eq_(counter.post_value, -1)