summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/pool.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2006-06-26 02:06:44 +0000
committerMike Bayer <mike_mp@zzzcomputing.com>2006-06-26 02:06:44 +0000
commitdc1cc365c244a0f0c40c6b2348b868f8f98b8020 (patch)
tree35333990d77a5158d24c0003e4a33f577795ecca /lib/sqlalchemy/pool.py
parentff8458ab3e3e71c54aa8adaba6508f7def452c1f (diff)
downloadsqlalchemy-dc1cc365c244a0f0c40c6b2348b868f8f98b8020.tar.gz
when QueuePool times out it raises a TimeoutError instead of
erroneously making another connection
Diffstat (limited to 'lib/sqlalchemy/pool.py')
-rw-r--r--lib/sqlalchemy/pool.py4
1 files changed, 3 insertions, 1 deletions
diff --git a/lib/sqlalchemy/pool.py b/lib/sqlalchemy/pool.py
index a8715ee1b..b086aae9f 100644
--- a/lib/sqlalchemy/pool.py
+++ b/lib/sqlalchemy/pool.py
@@ -11,7 +11,7 @@ be managed automatically, based on module type and connect arguments,
simply by calling regular DBAPI connect() methods."""
import Queue, weakref, string, cPickle
-import util
+import util, exceptions
try:
import thread
@@ -225,6 +225,8 @@ class QueuePool(Pool):
try:
return self._pool.get(self._max_overflow > -1 and self._overflow >= self._max_overflow, self._timeout)
except Queue.Empty:
+ if self._overflow >= self._max_overflow:
+ raise exceptions.TimeoutError("QueuePool limit of size %d overflow %d reached, connection timed out" % (self.size(), self.overflow()))
self._overflow += 1
return self._creator()