Fixed comments related to nonexistent keys for incr()/decr() in memcached backends.
This commit is contained in:
parent
67e4a9a4b9
commit
0cb0d59b23
|
@ -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)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue