if hasattr(mapper.class_, 'c'):
del mapper.class_.c
mapper_registry.clear()
+ # TODO: either dont use ArgSingleton, or
+ # find a way to clear only ClassKey instances from it
sautil.ArgSingleton.instances.clear()
finally:
mapperlib._COMPILE_MUTEX.release()
self._overflow = 0 - pool_size
self._max_overflow = max_overflow
self._timeout = timeout
- self._overflow_lock = threading.Lock()
+ self._overflow_lock = self._max_overflow > -1 and threading.Lock() or None
def recreate(self):
self.log("Pool recreating")
try:
self._pool.put(conn, False)
except Queue.Full:
- self._overflow_lock.acquire()
- try:
+ if self._overflow_lock is None:
self._overflow -= 1
- finally:
- self._overflow_lock.release()
+ else:
+ self._overflow_lock.acquire()
+ try:
+ self._overflow -= 1
+ finally:
+ self._overflow_lock.release()
def do_get(self):
try:
return self._pool.get(self._max_overflow > -1 and self._overflow >= self._max_overflow, self._timeout)
except Queue.Empty:
- self._overflow_lock.acquire()
+ if self._overflow_lock is not None:
+ self._overflow_lock.acquire()
try:
if self._max_overflow > -1 and self._overflow >= self._max_overflow:
raise exceptions.TimeoutError("QueuePool limit of size %d overflow %d reached, connection timed out" % (self.size(), self.overflow()))
con = self.create_connection()
self._overflow += 1
finally:
- self._overflow_lock.release()
+ if self._overflow_lock is not None:
+ self._overflow_lock.release()
return con
def dispose(self):
assert int(time.time() - now) == 2
def _test_overflow(self, thread_count, max_overflow):
- # i cant really get this to fail on OSX. linux? windows ?
- p = pool.QueuePool(creator=lambda: mock_dbapi.connect('foo.db'),
+ def creator():
+ time.sleep(.05)
+ return mock_dbapi.connect('foo.db')
+
+ p = pool.QueuePool(creator=creator,
pool_size=3, timeout=2,
max_overflow=max_overflow)
peaks = []
for i in range(10):
try:
con = p.connect()
- peaks.append(p.overflow())
time.sleep(.005)
+ peaks.append(p.overflow())
con.close()
del con
except exceptions.TimeoutError: