You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
101 lines
2.8 KiB
101 lines
2.8 KiB
6 months ago
|
import sqlite3
|
||
|
|
||
|
import pytest
|
||
|
|
||
|
from playground.memory.sqlite import SQLiteDB
|
||
|
|
||
|
|
||
|
@pytest.fixture
|
||
|
def db():
|
||
|
conn = sqlite3.connect(":memory:")
|
||
|
conn.execute("CREATE TABLE test (id INTEGER PRIMARY KEY, name TEXT)")
|
||
|
conn.commit()
|
||
|
return SQLiteDB(":memory:")
|
||
|
|
||
|
|
||
|
def test_add(db):
|
||
|
db.add("INSERT INTO test (name) VALUES (?)", ("test",))
|
||
|
result = db.query("SELECT * FROM test")
|
||
|
assert result == [(1, "test")]
|
||
|
|
||
|
|
||
|
def test_delete(db):
|
||
|
db.add("INSERT INTO test (name) VALUES (?)", ("test",))
|
||
|
db.delete("DELETE FROM test WHERE name = ?", ("test",))
|
||
|
result = db.query("SELECT * FROM test")
|
||
|
assert result == []
|
||
|
|
||
|
|
||
|
def test_update(db):
|
||
|
db.add("INSERT INTO test (name) VALUES (?)", ("test",))
|
||
|
db.update("UPDATE test SET name = ? WHERE name = ?", ("new", "test"))
|
||
|
result = db.query("SELECT * FROM test")
|
||
|
assert result == [(1, "new")]
|
||
|
|
||
|
|
||
|
def test_query(db):
|
||
|
db.add("INSERT INTO test (name) VALUES (?)", ("test",))
|
||
|
result = db.query("SELECT * FROM test WHERE name = ?", ("test",))
|
||
|
assert result == [(1, "test")]
|
||
|
|
||
|
|
||
|
def test_execute_query(db):
|
||
|
db.add("INSERT INTO test (name) VALUES (?)", ("test",))
|
||
|
result = db.execute_query(
|
||
|
"SELECT * FROM test WHERE name = ?", ("test",)
|
||
|
)
|
||
|
assert result == [(1, "test")]
|
||
|
|
||
|
|
||
|
def test_add_without_params(db):
|
||
|
with pytest.raises(sqlite3.ProgrammingError):
|
||
|
db.add("INSERT INTO test (name) VALUES (?)")
|
||
|
|
||
|
|
||
|
def test_delete_without_params(db):
|
||
|
with pytest.raises(sqlite3.ProgrammingError):
|
||
|
db.delete("DELETE FROM test WHERE name = ?")
|
||
|
|
||
|
|
||
|
def test_update_without_params(db):
|
||
|
with pytest.raises(sqlite3.ProgrammingError):
|
||
|
db.update("UPDATE test SET name = ? WHERE name = ?")
|
||
|
|
||
|
|
||
|
def test_query_without_params(db):
|
||
|
with pytest.raises(sqlite3.ProgrammingError):
|
||
|
db.query("SELECT * FROM test WHERE name = ?")
|
||
|
|
||
|
|
||
|
def test_execute_query_without_params(db):
|
||
|
with pytest.raises(sqlite3.ProgrammingError):
|
||
|
db.execute_query("SELECT * FROM test WHERE name = ?")
|
||
|
|
||
|
|
||
|
def test_add_with_wrong_query(db):
|
||
|
with pytest.raises(sqlite3.OperationalError):
|
||
|
db.add("INSERT INTO wrong (name) VALUES (?)", ("test",))
|
||
|
|
||
|
|
||
|
def test_delete_with_wrong_query(db):
|
||
|
with pytest.raises(sqlite3.OperationalError):
|
||
|
db.delete("DELETE FROM wrong WHERE name = ?", ("test",))
|
||
|
|
||
|
|
||
|
def test_update_with_wrong_query(db):
|
||
|
with pytest.raises(sqlite3.OperationalError):
|
||
|
db.update(
|
||
|
"UPDATE wrong SET name = ? WHERE name = ?",
|
||
|
("new", "test"),
|
||
|
)
|
||
|
|
||
|
|
||
|
def test_query_with_wrong_query(db):
|
||
|
with pytest.raises(sqlite3.OperationalError):
|
||
|
db.query("SELECT * FROM wrong WHERE name = ?", ("test",))
|
||
|
|
||
|
|
||
|
def test_execute_query_with_wrong_query(db):
|
||
|
with pytest.raises(sqlite3.OperationalError):
|
||
|
db.execute_query("SELECT * FROM wrong WHERE name = ?", ("test",))
|