Commit a70fba4
committed
fix: force-close StaticPool DBAPI connection to release SQLite locks
StaticPool._close_connection() is a no-op, so engine.dispose() alone
never closes the underlying sqlite3 connection. On Windows, this leaves
mandatory file locks in place, causing PermissionError when tests try
to delete the database file.
Use Connection.invalidate() which bypasses the pool's _close_connection
and calls dialect.do_close() directly to actually close the DBAPI
connection. Also add gc.collect() in initialize_storage to ensure any
lingering references are cleaned up before file removal.1 parent 089b09e commit a70fba4
2 files changed
Lines changed: 24 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
378 | 378 | | |
379 | 379 | | |
380 | 380 | | |
| 381 | + | |
| 382 | + | |
| 383 | + | |
| 384 | + | |
| 385 | + | |
| 386 | + | |
| 387 | + | |
| 388 | + | |
381 | 389 | | |
382 | 390 | | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
383 | 394 | | |
384 | 395 | | |
385 | 396 | | |
| |||
Lines changed: 13 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
93 | 93 | | |
94 | 94 | | |
95 | 95 | | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
96 | 109 | | |
97 | 110 | | |
98 | 111 | | |
| |||
0 commit comments