mirror of
https://github.com/psycopg/psycopg2.git
synced 2024-11-22 00:46:33 +03:00
Merge pull request #1728 from romank0/fetch-notifications-on-commit
Adds notifies processing during commit
This commit is contained in:
commit
78561ac99d
1
NEWS
1
NEWS
|
@ -5,6 +5,7 @@ What's new in psycopg 2.9.10 (unreleased)
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
- Add support for Python 3.13.
|
- Add support for Python 3.13.
|
||||||
|
- Receive notifications on commit (:ticket:`#1728`).
|
||||||
- Drop support for Python 3.7.
|
- Drop support for Python 3.7.
|
||||||
- `~psycopg2.errorcodes` map and `~psycopg2.errors` classes updated to
|
- `~psycopg2.errorcodes` map and `~psycopg2.errors` classes updated to
|
||||||
PostgreSQL 17.
|
PostgreSQL 17.
|
||||||
|
|
|
@ -1344,6 +1344,11 @@ conn_set_session(connectionObject *self, int autocommit,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Py_BLOCK_THREADS;
|
||||||
|
conn_notifies_process(self);
|
||||||
|
conn_notice_process(self);
|
||||||
|
Py_UNBLOCK_THREADS;
|
||||||
|
|
||||||
if (autocommit != SRV_STATE_UNCHANGED) {
|
if (autocommit != SRV_STATE_UNCHANGED) {
|
||||||
self->autocommit = autocommit;
|
self->autocommit = autocommit;
|
||||||
}
|
}
|
||||||
|
@ -1408,6 +1413,11 @@ conn_set_client_encoding(connectionObject *self, const char *pgenc)
|
||||||
goto endlock;
|
goto endlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Py_BLOCK_THREADS;
|
||||||
|
conn_notifies_process(self);
|
||||||
|
conn_notice_process(self);
|
||||||
|
Py_UNBLOCK_THREADS;
|
||||||
|
|
||||||
endlock:
|
endlock:
|
||||||
pthread_mutex_unlock(&self->lock);
|
pthread_mutex_unlock(&self->lock);
|
||||||
Py_END_ALLOW_THREADS;
|
Py_END_ALLOW_THREADS;
|
||||||
|
|
|
@ -412,6 +412,7 @@ pq_commit(connectionObject *conn)
|
||||||
}
|
}
|
||||||
|
|
||||||
Py_BLOCK_THREADS;
|
Py_BLOCK_THREADS;
|
||||||
|
conn_notifies_process(conn);
|
||||||
conn_notice_process(conn);
|
conn_notice_process(conn);
|
||||||
Py_UNBLOCK_THREADS;
|
Py_UNBLOCK_THREADS;
|
||||||
|
|
||||||
|
@ -468,6 +469,7 @@ pq_abort(connectionObject *conn)
|
||||||
retvalue = pq_abort_locked(conn, &_save);
|
retvalue = pq_abort_locked(conn, &_save);
|
||||||
|
|
||||||
Py_BLOCK_THREADS;
|
Py_BLOCK_THREADS;
|
||||||
|
conn_notifies_process(conn);
|
||||||
conn_notice_process(conn);
|
conn_notice_process(conn);
|
||||||
Py_UNBLOCK_THREADS;
|
Py_UNBLOCK_THREADS;
|
||||||
|
|
||||||
|
@ -538,6 +540,7 @@ pq_reset(connectionObject *conn)
|
||||||
|
|
||||||
Py_BLOCK_THREADS;
|
Py_BLOCK_THREADS;
|
||||||
conn_notice_process(conn);
|
conn_notice_process(conn);
|
||||||
|
conn_notifies_process(conn);
|
||||||
Py_UNBLOCK_THREADS;
|
Py_UNBLOCK_THREADS;
|
||||||
|
|
||||||
pthread_mutex_unlock(&conn->lock);
|
pthread_mutex_unlock(&conn->lock);
|
||||||
|
|
|
@ -23,13 +23,15 @@
|
||||||
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
||||||
# License for more details.
|
# License for more details.
|
||||||
|
|
||||||
|
import os
|
||||||
import unittest
|
import unittest
|
||||||
from collections import deque
|
from collections import deque
|
||||||
|
from functools import partial
|
||||||
|
|
||||||
import psycopg2
|
import psycopg2
|
||||||
from psycopg2 import extensions
|
from psycopg2 import extensions
|
||||||
from psycopg2.extensions import Notify
|
from psycopg2.extensions import Notify
|
||||||
from .testutils import ConnectingTestCase, skip_if_crdb, slow
|
from .testutils import ConnectingTestCase, skip_if_crdb, skip_if_windows, slow
|
||||||
from .testconfig import dsn
|
from .testconfig import dsn
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
|
@ -74,7 +76,9 @@ conn.close()
|
||||||
module=psycopg2.__name__,
|
module=psycopg2.__name__,
|
||||||
dsn=dsn, sec=sec, name=name, payload=payload))
|
dsn=dsn, sec=sec, name=name, payload=payload))
|
||||||
|
|
||||||
return Popen([sys.executable, '-c', script], stdout=PIPE)
|
env = os.environ.copy()
|
||||||
|
env.pop("PSYCOPG_DEBUG", None)
|
||||||
|
return Popen([sys.executable, '-c', script], stdout=PIPE, env=env)
|
||||||
|
|
||||||
@slow
|
@slow
|
||||||
def test_notifies_received_on_poll(self):
|
def test_notifies_received_on_poll(self):
|
||||||
|
@ -126,6 +130,52 @@ conn.close()
|
||||||
self.assertEqual(pid, self.conn.notifies[0][0])
|
self.assertEqual(pid, self.conn.notifies[0][0])
|
||||||
self.assertEqual('foo', self.conn.notifies[0][1])
|
self.assertEqual('foo', self.conn.notifies[0][1])
|
||||||
|
|
||||||
|
def _test_notifies_received_on_operation(self, operation, execute_query=True):
|
||||||
|
self.listen('foo')
|
||||||
|
self.conn.commit()
|
||||||
|
if execute_query:
|
||||||
|
self.conn.cursor().execute('select 1;')
|
||||||
|
pid = int(self.notify('foo').communicate()[0])
|
||||||
|
self.assertEqual(0, len(self.conn.notifies))
|
||||||
|
operation()
|
||||||
|
self.assertEqual(1, len(self.conn.notifies))
|
||||||
|
self.assertEqual(pid, self.conn.notifies[0][0])
|
||||||
|
self.assertEqual('foo', self.conn.notifies[0][1])
|
||||||
|
|
||||||
|
@slow
|
||||||
|
@skip_if_windows
|
||||||
|
def test_notifies_received_on_commit(self):
|
||||||
|
self._test_notifies_received_on_operation(self.conn.commit)
|
||||||
|
|
||||||
|
@slow
|
||||||
|
@skip_if_windows
|
||||||
|
def test_notifies_received_on_rollback(self):
|
||||||
|
self._test_notifies_received_on_operation(self.conn.rollback)
|
||||||
|
|
||||||
|
@slow
|
||||||
|
@skip_if_windows
|
||||||
|
def test_notifies_received_on_reset(self):
|
||||||
|
self._test_notifies_received_on_operation(self.conn.reset, execute_query=False)
|
||||||
|
|
||||||
|
@slow
|
||||||
|
@skip_if_windows
|
||||||
|
def test_notifies_received_on_set_session(self):
|
||||||
|
self._test_notifies_received_on_operation(
|
||||||
|
partial(self.conn.set_session, autocommit=True, readonly=True),
|
||||||
|
execute_query=False,
|
||||||
|
)
|
||||||
|
|
||||||
|
@slow
|
||||||
|
@skip_if_windows
|
||||||
|
def test_notifies_received_on_set_client_encoding(self):
|
||||||
|
self._test_notifies_received_on_operation(
|
||||||
|
partial(
|
||||||
|
self.conn.set_client_encoding,
|
||||||
|
'LATIN1' if self.conn.encoding != 'LATIN1' else 'UTF8'
|
||||||
|
),
|
||||||
|
execute_query=False,
|
||||||
|
)
|
||||||
|
|
||||||
@slow
|
@slow
|
||||||
def test_notify_object(self):
|
def test_notify_object(self):
|
||||||
self.autocommit(self.conn)
|
self.autocommit(self.conn)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user