From f730bb9297b772be6771ca2233134a4046abb8ec Mon Sep 17 00:00:00 2001 From: Nicola Coretti Date: Fri, 21 Jun 2024 07:54:01 +0200 Subject: [PATCH] Add test for concurrent access on connection (#138) --- test/integration/concurrency_test.py | 43 ++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 test/integration/concurrency_test.py diff --git a/test/integration/concurrency_test.py b/test/integration/concurrency_test.py new file mode 100644 index 0000000..a89402d --- /dev/null +++ b/test/integration/concurrency_test.py @@ -0,0 +1,43 @@ +import pytest +import pyexasol +import threading +from pyexasol import ExaConcurrencyError + + +class QueryThread(threading.Thread): + + def __init__(self, connection, timeout): + self.connection = connection + self.seconds = timeout + self.exception = None + super().__init__() + + def run(self): + try: + # run heavy query + self.connection.execute(f'SELECT "$SLEEP"({self.seconds})') + except Exception as ex: + self.exception = ex + + def join(self, timeout=None): + threading.Thread.join(self, timeout=timeout) + if self.exception: + raise self.exception + + +@pytest.mark.exceptions +def test_concurrency_error(dsn, user, password, schema): + + # Note all timeouts and sleeps in this test case have been chosen by well-educated guesses + # TL;DR: Adjust timeouts if required/reasonable + query_time_in_seconds = 0.5 + + con = pyexasol.connect(dsn=dsn, user=user, password=password, schema=schema) + q1 = QueryThread(con, timeout=query_time_in_seconds) + q2 = QueryThread(con, timeout=query_time_in_seconds) + + with pytest.raises(ExaConcurrencyError): + q1.start() + q2.start() + q1.join() + q2.join()