mirror of
https://github.com/aljazceru/turso.git
synced 2026-02-01 06:14:23 +01:00
antithesis-tests: Make test drivers robust when database is locked
If multiple processes access the same database file concurrently, Limbo fails with:
```
LockingError("Failed locking file. File is locked by another process
```
Make test driver robust against that.
This commit is contained in:
@@ -4,7 +4,12 @@ import limbo
|
||||
from antithesis.random import get_random
|
||||
from antithesis.assertions import always
|
||||
|
||||
con = limbo.connect("bank_test.db")
|
||||
try:
|
||||
con = limbo.connect("bank_test.db")
|
||||
except Exception as e:
|
||||
print(f"Error connecting to database: {e}")
|
||||
exit(0)
|
||||
|
||||
cur = con.cursor()
|
||||
|
||||
initial_state = cur.execute(f'''
|
||||
|
||||
@@ -4,7 +4,12 @@ import limbo
|
||||
from antithesis.random import get_random
|
||||
from antithesis.assertions import always
|
||||
|
||||
con = limbo.connect("bank_test.db")
|
||||
try:
|
||||
con = limbo.connect("bank_test.db")
|
||||
except Exception as e:
|
||||
print(f"Error connecting to database: {e}")
|
||||
exit(0)
|
||||
|
||||
cur = con.cursor()
|
||||
|
||||
initial_state = cur.execute(f'''
|
||||
|
||||
@@ -4,7 +4,12 @@ import limbo
|
||||
from antithesis.random import get_random
|
||||
from antithesis.assertions import always
|
||||
|
||||
con = limbo.connect("bank_test.db")
|
||||
try:
|
||||
con = limbo.connect("bank_test.db")
|
||||
except Exception as e:
|
||||
print(f"Error connecting to database: {e}")
|
||||
exit(0)
|
||||
|
||||
cur = con.cursor()
|
||||
|
||||
initial_state = cur.execute(f'''
|
||||
|
||||
@@ -3,7 +3,12 @@
|
||||
import limbo
|
||||
from antithesis.random import get_random
|
||||
|
||||
con = limbo.connect("bank_test.db")
|
||||
try:
|
||||
con = limbo.connect("bank_test.db")
|
||||
except Exception as e:
|
||||
print(f"Error connecting to database: {e}")
|
||||
exit(0)
|
||||
|
||||
cur = con.cursor()
|
||||
|
||||
# drop accounts table if it exists and create a new table
|
||||
|
||||
@@ -13,7 +13,12 @@ logger.setLevel(logging.INFO)
|
||||
|
||||
logger.addHandler(handler)
|
||||
|
||||
con = limbo.connect("bank_test.db")
|
||||
try:
|
||||
con = limbo.connect("bank_test.db")
|
||||
except Exception as e:
|
||||
print(f"Error connecting to database: {e}")
|
||||
exit(0)
|
||||
|
||||
cur = con.cursor()
|
||||
|
||||
length = cur.execute("SELECT num_accts FROM initial_state").fetchone()[0]
|
||||
|
||||
@@ -23,12 +23,22 @@ for f in glob.glob('*.db-wal'):
|
||||
pass
|
||||
|
||||
# store initial states in a separate db
|
||||
con_init = limbo.connect('init_state.db')
|
||||
try:
|
||||
con_init = limbo.connect('init_state.db')
|
||||
except Exception as e:
|
||||
print(f"Error connecting to database: {e}")
|
||||
exit(0)
|
||||
|
||||
cur_init = con_init.cursor()
|
||||
cur_init.execute('CREATE TABLE schemas (schema TEXT, tbl INT PRIMARY KEY)')
|
||||
cur_init.execute('CREATE TABLE tables (count INT)')
|
||||
|
||||
con = limbo.connect('stress_composer.db')
|
||||
try:
|
||||
con = limbo.connect('stress_composer.db')
|
||||
except Exception as e:
|
||||
print(f"Error connecting to database: {e}")
|
||||
exit(0)
|
||||
|
||||
cur = con.cursor()
|
||||
|
||||
tbl_count = max(1, get_random() % 10)
|
||||
|
||||
@@ -6,7 +6,12 @@ from utils import generate_random_value
|
||||
from antithesis.random import get_random
|
||||
|
||||
# Get initial state
|
||||
con_init = limbo.connect('init_state.db')
|
||||
try:
|
||||
con_init = limbo.connect('init_state.db')
|
||||
except Exception as e:
|
||||
print(f"Error connecting to database: {e}")
|
||||
exit(0)
|
||||
|
||||
cur_init = con_init.cursor()
|
||||
|
||||
tbl_len = cur_init.execute('SELECT count FROM tables').fetchone()[0]
|
||||
@@ -18,7 +23,11 @@ pk = tbl_schema['pk']
|
||||
# get non-pk columns
|
||||
cols = [f'col_{col}' for col in range(tbl_schema['colCount']) if col != pk]
|
||||
|
||||
con = limbo.connect('stress_composer.db')
|
||||
try:
|
||||
con = limbo.connect('stress_composer.db')
|
||||
except limbo.OperationalError as e:
|
||||
print(f'Failed to open stress_composer.db. Exiting... {e}')
|
||||
exit(0)
|
||||
cur = con.cursor()
|
||||
|
||||
deletions = get_random() % 100
|
||||
|
||||
@@ -7,7 +7,12 @@ from antithesis.random import get_random
|
||||
|
||||
|
||||
# Get initial state
|
||||
con_init = limbo.connect('init_state.db')
|
||||
try:
|
||||
con_init = limbo.connect('init_state.db')
|
||||
except Exception as e:
|
||||
print(f"Error connecting to database: {e}")
|
||||
exit(0)
|
||||
|
||||
cur_init = con_init.cursor()
|
||||
|
||||
tbl_len = cur_init.execute('SELECT count FROM tables').fetchone()[0]
|
||||
@@ -15,7 +20,12 @@ selected_tbl = get_random() % tbl_len
|
||||
tbl_schema = json.loads(cur_init.execute(f'SELECT schema FROM schemas WHERE tbl = {selected_tbl}').fetchone()[0])
|
||||
cols = ', '.join([f'col_{col}' for col in range(tbl_schema['colCount'])])
|
||||
|
||||
con = limbo.connect('stress_composer.db')
|
||||
try:
|
||||
con = limbo.connect('stress_composer.db')
|
||||
except limbo.OperationalError as e:
|
||||
print(f'Failed to open stress_composer.db. Exiting... {e}')
|
||||
exit(0)
|
||||
|
||||
cur = con.cursor()
|
||||
|
||||
# insert up to 100 rows in the selected table
|
||||
|
||||
@@ -6,7 +6,12 @@ from utils import generate_random_value
|
||||
from antithesis.random import get_random
|
||||
|
||||
# Get initial state
|
||||
con_init = limbo.connect('init_state.db')
|
||||
try:
|
||||
con_init = limbo.connect('init_state.db')
|
||||
except Exception as e:
|
||||
print(f"Error connecting to database: {e}")
|
||||
exit(0)
|
||||
|
||||
cur_init = con_init.cursor()
|
||||
|
||||
tbl_len = cur_init.execute('SELECT count FROM tables').fetchone()[0]
|
||||
@@ -18,7 +23,11 @@ pk = tbl_schema['pk']
|
||||
# get non-pk columns
|
||||
cols = [f'col_{col}' for col in range(tbl_schema['colCount']) if col != pk]
|
||||
# print(cols)
|
||||
con = limbo.connect('stress_composer.db')
|
||||
try:
|
||||
con = limbo.connect('stress_composer.db')
|
||||
except limbo.OperationalError as e:
|
||||
print(f'Failed to open stress_composer.db. Exiting... {e}')
|
||||
exit(0)
|
||||
cur = con.cursor()
|
||||
|
||||
# insert up to 100 rows in the selected table
|
||||
|
||||
Reference in New Issue
Block a user