1
0
Fork 0
harlequin-postgres/tests/conftest.py

41 lines
1 KiB
Python
Raw Permalink Normal View History

from __future__ import annotations
import sys
from typing import Generator
import psycopg
import pytest
from harlequin_postgres.adapter import (
HarlequinPostgresAdapter,
HarlequinPostgresConnection,
)
if sys.version_info < (3, 10):
pass
else:
pass
TEST_DB_CONN = "postgresql://postgres:for-testing@localhost:5432"
@pytest.fixture
def connection() -> Generator[HarlequinPostgresConnection, None, None]:
pgconn = psycopg.connect(conninfo=TEST_DB_CONN, dbname="postgres")
pgconn.autocommit = True
cur = pgconn.cursor()
cur.execute("drop database if exists test;")
cur.execute("create database test;")
cur.close()
pgconn.close()
conn = HarlequinPostgresAdapter(
conn_str=(f"{TEST_DB_CONN}",), dbname="test"
).connect()
yield conn
conn.close()
pgconn = psycopg.connect(conninfo=TEST_DB_CONN, dbname="postgres")
pgconn.autocommit = True
cur = pgconn.cursor()
cur.execute("drop database if exists test;")
cur.close()
pgconn.close()