Fixed comments related to nonexistent keys for incr()/decr() in memcached backends.

This commit is contained in:
Nick Pope 2020-08-14 22:58:16 +01:00 committed by Mariusz Felisiak
parent 67e4a9a4b9
commit 0cb0d59b23
1 changed files with 8 additions and 12 deletions

View File

@ -18,10 +18,8 @@ class BaseMemcachedCache(BaseCache):
else: else:
self._servers = server self._servers = server
# The exception type to catch from the underlying library for a key # Exception type raised by the underlying client library for a
# that was not found. This is a ValueError for python-memcache, # nonexistent key.
# pylibmc.NotFound for pylibmc, and cmemcache will return None without
# raising an exception.
self.LibraryValueNotFoundException = value_not_found_exception self.LibraryValueNotFoundException = value_not_found_exception
self._lib = library self._lib = library
@ -106,10 +104,8 @@ class BaseMemcachedCache(BaseCache):
try: try:
val = self._cache.incr(key, delta) val = self._cache.incr(key, delta)
# python-memcache responds to incr on nonexistent keys by # Normalize an exception raised by the underlying client library to
# raising a ValueError, pylibmc by raising a pylibmc.NotFound # ValueError in the event of a nonexistent key when calling incr().
# and Cmemcache returns None. In all cases,
# we should raise a ValueError though.
except self.LibraryValueNotFoundException: except self.LibraryValueNotFoundException:
val = None val = None
if val is None: if val is None:
@ -125,10 +121,8 @@ class BaseMemcachedCache(BaseCache):
try: try:
val = self._cache.decr(key, delta) val = self._cache.decr(key, delta)
# python-memcache responds to incr on nonexistent keys by # Normalize an exception raised by the underlying client library to
# raising a ValueError, pylibmc by raising a pylibmc.NotFound # ValueError in the event of a nonexistent key when calling decr().
# and Cmemcache returns None. In all cases,
# we should raise a ValueError though.
except self.LibraryValueNotFoundException: except self.LibraryValueNotFoundException:
val = None val = None
if val is None: if val is None:
@ -160,6 +154,8 @@ class BaseMemcachedCache(BaseCache):
class MemcachedCache(BaseMemcachedCache): class MemcachedCache(BaseMemcachedCache):
"An implementation of a cache binding using python-memcached" "An implementation of a cache binding using python-memcached"
def __init__(self, server, params): def __init__(self, server, params):
# python-memcached ≥ 1.45 returns None for a nonexistent key in
# incr/decr(), python-memcached < 1.45 raises ValueError.
import memcache import memcache
super().__init__(server, params, library=memcache, value_not_found_exception=ValueError) super().__init__(server, params, library=memcache, value_not_found_exception=ValueError)