Skip to content

Commit

Permalink
Merge Connection and RawConnection
Browse files Browse the repository at this point in the history
Also added blocking pool (single-connection only), and fixed all tests
to use client instead of connection.
  • Loading branch information
fantix committed Jan 7, 2022
1 parent 11cb497 commit 053ab77
Show file tree
Hide file tree
Showing 22 changed files with 922 additions and 1,281 deletions.
3 changes: 2 additions & 1 deletion edgedb/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,8 @@
AsyncIOClient
)

from .blocking_con import connect, BlockingIOConnection
from .blocking_con import connect_raw, BlockingIOConnection
from .blocking_pool import create_client, Client
from .options import RetryCondition, IsolationLevel, default_backoff
from .options import RetryOptions, TransactionOptions

Expand Down
85 changes: 53 additions & 32 deletions edgedb/_testbase.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@
import unittest

import edgedb
from edgedb import asyncio_pool


log = logging.getLogger(__name__)
Expand Down Expand Up @@ -163,18 +164,19 @@ def _start_cluster(*, cleanup_atexit=True):
else:
con_args['tls_ca_file'] = data['tls_cert_file']

con = edgedb.connect(password='test', **con_args)
client = edgedb.create_client(password='test', **con_args)
client.ensure_connected()
_default_cluster = {
'proc': p,
'con': con,
'client': client,
'con_args': con_args,
}

if 'tls_cert_file' in data:
# Keep the temp dir which we also copied the cert from WSL
_default_cluster['_tmpdir'] = tmpdir

atexit.register(con.close)
atexit.register(client.close)
except Exception as e:
_default_cluster = e
raise e
Expand Down Expand Up @@ -225,7 +227,7 @@ def wrapper(self, *args, __meth__=meth, **kwargs):
if try_no == 3:
raise
else:
self.loop.run_until_complete(self.con.execute(
self.loop.run_until_complete(self.client.execute(
'ROLLBACK;'
))
try_no += 1
Expand Down Expand Up @@ -319,17 +321,37 @@ def setUpClass(cls):
cls.cluster = _start_cluster(cleanup_atexit=True)


class TestClient(edgedb.AsyncIOClient):
@property
def connection(self):
return self._impl._holders[0]._con

@property
def dbname(self):
return self._impl._working_params.database


class ConnectedTestCaseMixin:

@classmethod
async def connect(cls, *,
cluster=None,
database='edgedb',
user='edgedb',
password='test'):
def test_client(
cls, *,
cluster=None,
database='edgedb',
user='edgedb',
password='test',
connection_class=asyncio_pool.PoolConnection,
):
conargs = cls.get_connect_args(
cluster=cluster, database=database, user=user, password=password)
return await edgedb.async_connect_raw(**conargs)
return TestClient(
connection_class=connection_class,
concurrency=1,
on_acquire=None,
on_release=None,
on_connect=None,
**conargs,
)

@classmethod
def get_connect_args(cls, *,
Expand Down Expand Up @@ -362,29 +384,29 @@ class DatabaseTestCase(ClusterTestCase, ConnectedTestCaseMixin):
def setUp(self):
if self.INTERNAL_TESTMODE:
self.loop.run_until_complete(
self.con.execute(
self.client.execute(
'CONFIGURE SESSION SET __internal_testmode := true;'))

if self.SETUP_METHOD:
self.loop.run_until_complete(
self.con.execute(self.SETUP_METHOD))
self.client.execute(self.SETUP_METHOD))

super().setUp()

def tearDown(self):
try:
if self.TEARDOWN_METHOD:
self.loop.run_until_complete(
self.con.execute(self.TEARDOWN_METHOD))
self.client.execute(self.TEARDOWN_METHOD))
finally:
try:
if self.con.is_in_transaction():
if self.client.connection.is_in_transaction():
raise AssertionError(
'test connection is still in transaction '
'*after* the test')

self.loop.run_until_complete(
self.con.execute('RESET ALIAS *;'))
self.client.execute('RESET ALIAS *;'))

finally:
super().tearDown()
Expand All @@ -394,26 +416,25 @@ def setUpClass(cls):
super().setUpClass()
dbname = cls.get_database_name()

cls.admin_conn = None
cls.con = None
cls.admin_client = None

class_set_up = os.environ.get('EDGEDB_TEST_CASES_SET_UP')

# Only open an extra admin connection if necessary.
if not class_set_up:
script = f'CREATE DATABASE {dbname};'
cls.admin_conn = cls.loop.run_until_complete(cls.connect())
cls.loop.run_until_complete(cls.admin_conn.execute(script))
cls.admin_client = cls.test_client()
cls.loop.run_until_complete(cls.admin_client.execute(script))

cls.con = cls.loop.run_until_complete(cls.connect(database=dbname))
cls.client = cls.test_client(database=dbname)

if not class_set_up:
script = cls.get_setup_script()
if script:
# The setup is expected to contain a CREATE MIGRATION,
# which needs to be wrapped in a transaction.
async def execute():
async for tr in cls.con.transaction():
async for tr in cls.client.transaction():
async with tr:
await tr.execute(script)
cls.loop.run_until_complete(execute())
Expand Down Expand Up @@ -482,27 +503,27 @@ def tearDownClass(cls):
try:
if script:
cls.loop.run_until_complete(
cls.con.execute(script))
cls.client.execute(script))
finally:
try:
cls.loop.run_until_complete(cls.con.aclose())
cls.loop.run_until_complete(cls.client.aclose())

if not class_set_up:
dbname = cls.get_database_name()
script = f'DROP DATABASE {dbname};'

cls.loop.run_until_complete(
cls.admin_conn.execute(script))
cls.admin_client.execute(script))

except Exception:
log.exception('error running teardown')
# skip the exception so that original error is shown instead
# of finalizer error
finally:
try:
if cls.admin_conn is not None:
if cls.admin_client is not None:
cls.loop.run_until_complete(
cls.admin_conn.aclose())
cls.admin_client.aclose())
finally:
super().tearDownClass()

Expand All @@ -518,18 +539,18 @@ def setUp(self):
super().setUp()

cls = type(self)
cls.async_con = cls.con
cls.async_client = cls.client

conargs = cls.get_connect_args().copy()
conargs.update(dict(database=cls.async_con.dbname))
conargs.update(dict(database=cls.async_client.dbname))

cls.con = edgedb.connect(**conargs)
cls.client = edgedb.create_client(**conargs)

def tearDown(self):
cls = type(self)
cls.con.close()
cls.con = cls.async_con
del cls.async_con
cls.client.close()
cls.client = cls.async_client
del cls.async_client


_lock_cnt = 0
Expand Down
Loading

0 comments on commit 053ab77

Please sign in to comment.