mirror of
https://github.com/tursodatabase/limbo.git
synced 2025-12-23 08:21:09 +00: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:
parent
4b208f819e
commit
419ddf0cfa
9 changed files with 76 additions and 13 deletions
|
|
@ -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
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue