Skip to content

Commit

Permalink
Merge commit 'e093c8bfd46657e6e3a0f0a67b47b27d5119a82b'
Browse files Browse the repository at this point in the history
* commit 'e093c8bfd46657e6e3a0f0a67b47b27d5119a82b':
  Fixed wrong issue reference
  Going 2.2.1
  Style fix
  Wait for a pending connection when acquiring
  • Loading branch information
friedcell committed Jul 13, 2023
2 parents 7ca9369 + e093c8b commit 3ee0e59
Show file tree
Hide file tree
Showing 5 changed files with 82 additions and 7 deletions.
7 changes: 7 additions & 0 deletions changelog.rst
Original file line number Diff line number Diff line change
@@ -1,6 +1,13 @@
Changelog
=========

2.2.1 (2015-10-13)
------------------
* Wait for pending connections during connection acquiring (`issue 122`_). Thanks to jbowes_.

.. _issue 122: https://github.com/FSX/momoko/issues/122
.. _jbowes: https://github.com/jbowes

2.2.0 (2015-09-20)
------------------
* Fixed serious flaw with connection retrials. `More details`_.
Expand Down
4 changes: 2 additions & 2 deletions docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -49,9 +49,9 @@
# built documents.
#
# The short X.Y version.
version = '2.2.0'
version = '2.2.1'
# The full version, including alpha/beta/rc tags.
release = '2.2.0'
release = '2.2.1'

# The language for content autogenerated by Sphinx. Refer to documentation
# for a list of supported languages.
Expand Down
12 changes: 9 additions & 3 deletions momoko/connection.py
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,10 @@ def add_dead(self, conn):
self.pending.discard(conn)
self.dead.add(conn)

# If everything is dead, abort anything pending.
if not self.pending:
self.abort_waiting_queue(Pool.DatabaseNotAvailable("No database connection available"))

def acquire(self):
"""Occupy free connection"""
future = Future()
Expand All @@ -84,6 +88,10 @@ def acquire(self):
log.debug("No free connections, and some are busy - put in waiting queue")
self.waiting_queue.appendleft(future)
return future
elif self.pending:
log.debug("No free connections, but some are pending - put in waiting queue")
self.waiting_queue.appendleft(future)
return future
else:
log.debug("All connections are dead")
return None
Expand Down Expand Up @@ -115,7 +123,7 @@ def shrink(self, target_size, delay_in_seconds):

@property
def all_dead(self):
return not (self.free or self.busy)
return not (self.free or self.busy or self.waiting_queue)

@property
def total(self):
Expand Down Expand Up @@ -295,8 +303,6 @@ def getconn(self, ping=True):
future = rv
else:
# Else, all connections are dead
assert len(self.conns.pending) == 0, "BUG! should be no pending connection"

future = Future()

def on_reanimate_done(fut):
Expand Down
2 changes: 1 addition & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@

setup(
name='Momoko',
version='2.2.0',
version='2.2.1',
description="Momoko wraps Psycopg2's functionality for use in Tornado.",
long_description=open('README.rst').read(),
author='Frank Smit & Zaar Hai',
Expand Down
64 changes: 63 additions & 1 deletion tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -812,9 +812,71 @@ def test_abort_waiting_queue(self):
pass
self.assertEqual(len(db.conns.waiting_queue), 0)

@gen_test
def test_execute_can_start_before_connection_is_done(self):
db = momoko.Pool(dsn=self.good_dsn, size=1, ioloop=self.io_loop)
db.connect()
cursor = yield db.execute("SELECT 1")
self.assertEqual(cursor.fetchone()[0], 1)

@gen_test
def test_execute_before_connection_is_done_will_error(self):
db = momoko.Pool(dsn=bad_dsn, size=1, ioloop=self.io_loop)
db.connect()

try:
yield db.execute("SELECT 1")

# This likely won't get hit; instead the test will timeout on
# failure.
self.fail("Exception should have been raised")
except psycopg2.DatabaseError:
pass


class MomokoPoolVolatileDbTestProxy(ProxyMixIn, MomokoPoolVolatileDbTest):
pass

@gen_test
def test_execute_can_wait_for_connection_after_disconnect(self):
db = yield self.build_pool(dsn=self.good_dsn, size=1)

f1 = db.execute("SELECT 1")
self.terminate_proxy()
try:
yield f1
except psycopg2.DatabaseError:
pass
self.start_proxy()
yield gen.sleep(db.reconnect_interval)
f2 = db.execute("SELECT 1")
f3 = db.execute("SELECT 1")

cursors = yield [f2, f3]
self.assertEqual(cursors[0].fetchone()[0], 1)
self.assertEqual(cursors[1].fetchone()[0], 1)

@gen_test
def test_execute_can_fail_after_disconnect_with_no_reconnect(self):
db = yield self.build_pool(dsn=self.good_dsn, size=1)

f1 = db.execute("SELECT 1")
self.terminate_proxy()
try:
yield f1
except psycopg2.DatabaseError:
pass

# No start proxy here!
yield gen.sleep(db.reconnect_interval)
f2 = db.execute("SELECT 1")
f3 = db.execute("SELECT 1")

try:
yield [f2, f3]
self.fail("Exception should have been raised")
except psycopg2.DatabaseError:
pass
self.assertEqual(len(db.conns.waiting_queue), 0)


class MomokoPoolPartiallyConnectedTest(PoolBaseTest):
Expand Down

0 comments on commit 3ee0e59

Please sign in to comment.