Skip to content

Commit

Permalink
test(sqlite): use context managers for all sqlite connections in test…
Browse files Browse the repository at this point in the history
…ing to avoid `ResourceWarning`s starting in python 3.13
  • Loading branch information
cpcloud committed Dec 17, 2024
1 parent 2d46fbb commit 3a2c6b6
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 18 deletions.
17 changes: 8 additions & 9 deletions ibis/backends/duckdb/tests/test_io.py
Original file line number Diff line number Diff line change
Expand Up @@ -211,22 +211,21 @@ def test_read_mysql(con, mysqlurl): # pragma: no cover
def test_read_sqlite(con, tmp_path):
path = tmp_path / "test.db"

sqlite_con = sqlite3.connect(str(path))
sqlite_con.execute("CREATE TABLE t AS SELECT 1 a UNION SELECT 2 UNION SELECT 3")
with sqlite3.connect(str(path)) as sqlite_con:
sqlite_con.execute("CREATE TABLE t AS SELECT 1 a UNION SELECT 2 UNION SELECT 3")

ft = con.read_sqlite(path, table_name="t")
assert ft.count().execute()
ft = con.read_sqlite(path, table_name="t")
assert ft.count().execute()


def test_read_sqlite_no_table_name(con, tmp_path):
path = tmp_path / "test.db"

sqlite3.connect(str(path))
with sqlite3.connect(str(path)) as _:
assert path.exists()

assert path.exists()

with pytest.raises(ValueError):
con.read_sqlite(path)
with pytest.raises(ValueError):
con.read_sqlite(path)


# Because we create a new connection and the test requires loading/installing a
Expand Down
15 changes: 6 additions & 9 deletions ibis/backends/sqlite/tests/test_types.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,16 +36,14 @@
@pytest.fixture(scope="session")
def db(tmp_path_factory):
path = str(tmp_path_factory.mktemp("databases") / "formats.db")
con = sqlite3.connect(path)
con.execute("CREATE TABLE timestamps (ts TIMESTAMP)")
con.execute("CREATE TABLE timestamps_tz (ts TIMESTAMPTZ)")
con.execute("CREATE TABLE weird (str_col STRING, date_col ITSADATE)")
con.execute("CREATE TABLE basic (a INTEGER, b REAL, c BOOLEAN, d BLOB)")
with con:
with sqlite3.connect(path) as con:
con.execute("CREATE TABLE timestamps (ts TIMESTAMP)")
con.execute("CREATE TABLE timestamps_tz (ts TIMESTAMPTZ)")
con.execute("CREATE TABLE weird (str_col STRING, date_col ITSADATE)")
con.execute("CREATE TABLE basic (a INTEGER, b REAL, c BOOLEAN, d BLOB)")
con.executemany("INSERT INTO timestamps VALUES (?)", [(t,) for t in TIMESTAMPS])
con.executemany(
"INSERT INTO timestamps_tz VALUES (?)",
[(t,) for t in TIMESTAMPS_TZ],
"INSERT INTO timestamps_tz VALUES (?)", [(t,) for t in TIMESTAMPS_TZ]
)
con.executemany(
"INSERT INTO weird VALUES (?, ?)",
Expand All @@ -56,7 +54,6 @@ def db(tmp_path_factory):
("d", "2022-01-04"),
],
)
con.close()
return path


Expand Down

0 comments on commit 3a2c6b6

Please sign in to comment.