close db after checkAllegedGristDoc (#482)

This closes a file left open during importing, not by the import itself, but by a SQLite integrity check. This was causing imports to fail on Windows (see https://github.com/gristlabs/grist-electron/issues/3)
This commit is contained in:
Paul Fitzpatrick 2023-04-04 15:59:26 -04:00 committed by GitHub
parent 600f699b81
commit 903c81d348
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -136,12 +136,16 @@ export function getDatabaseUrl(options: ConnectionOptions, includeCredentials: b
*/ */
export async function checkAllegedGristDoc(docSession: OptDocSession, fname: string) { export async function checkAllegedGristDoc(docSession: OptDocSession, fname: string) {
const db = await SQLiteDB.openDBRaw(fname, OpenMode.OPEN_READONLY); const db = await SQLiteDB.openDBRaw(fname, OpenMode.OPEN_READONLY);
const integrityCheckResults = await db.all('PRAGMA integrity_check'); try {
if (integrityCheckResults.length !== 1 || integrityCheckResults[0].integrity_check !== 'ok') { const integrityCheckResults = await db.all('PRAGMA integrity_check');
const uuid = uuidv4(); if (integrityCheckResults.length !== 1 || integrityCheckResults[0].integrity_check !== 'ok') {
log.info('Integrity check failure on import', {uuid, integrityCheckResults, const uuid = uuidv4();
...getLogMetaFromDocSession(docSession)}); log.info('Integrity check failure on import', {uuid, integrityCheckResults,
throw new Error(`Document failed integrity checks - is it corrupted? Event ID: ${uuid}`); ...getLogMetaFromDocSession(docSession)});
throw new Error(`Document failed integrity checks - is it corrupted? Event ID: ${uuid}`);
}
} finally {
await db.close();
} }
} }