Skip to content

Commit

Permalink
fix: avoid database reentrancy issue during parallel testing
Browse files Browse the repository at this point in the history
  • Loading branch information
FUDCo committed Sep 3, 2020
1 parent 9985dc4 commit eb2028d
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 7 deletions.
9 changes: 8 additions & 1 deletion packages/swingset-runner/src/main.js
Original file line number Diff line number Diff line change
Expand Up @@ -166,6 +166,7 @@ export async function main() {
let launchIndirectly = false;
let benchmarkRounds = 0;
let configPath = null;
let dbDir = null;

while (argv[0] && argv[0].startsWith('-')) {
const flag = argv.shift();
Expand Down Expand Up @@ -223,6 +224,9 @@ export async function main() {
dumpTag = argv.shift();
doDumps = true;
break;
case '--dbdir':
dbDir = argv.shift();
break;
case '--raw':
rawMode = true;
doDumps = true;
Expand Down Expand Up @@ -306,9 +310,12 @@ export async function main() {
if (launchIndirectly) {
config = generateIndirectConfig(config);
}
if (!dbDir) {
dbDir = basedir;
}

let store;
const kernelStateDBDir = path.join(basedir, 'swingset-kernel-state');
const kernelStateDBDir = path.join(dbDir, 'swingset-kernel-state');
switch (dbMode) {
case '--filedb':
if (forceReset) {
Expand Down
21 changes: 15 additions & 6 deletions packages/swingset-runner/test/test-demo.js
Original file line number Diff line number Diff line change
@@ -1,10 +1,16 @@
import test from 'ava';
import { spawn } from 'child_process';
import fs from 'fs';

async function innerTest(t, extraFlags) {
async function innerTest(t, extraFlags, dbdir) {
await new Promise(resolve => {
const appDir = 'demo/encouragementBot';
if (dbdir) {
dbdir = `${appDir}/${dbdir}`;
extraFlags += ` --dbdir ${dbdir}`;
}
const proc = spawn(
`node -r esm bin/runner --init ${extraFlags} run demo/encouragementBot`,
`node -r esm bin/runner --init ${extraFlags} run ${appDir}`,
{
cwd: `${__dirname}/..`,
shell: true,
Expand All @@ -22,6 +28,9 @@ async function innerTest(t, extraFlags) {
const bMsg = 'bot vat is happy';
t.not(output.indexOf(`\n${bMsg}\n`), -1, bMsg);
resolve();
if (dbdir) {
fs.rmdirSync(dbdir, { recursive: true });
}
});
});
}
Expand All @@ -31,17 +40,17 @@ test('run encouragmentBot demo with memdb', async t => {
});

test('run encouragmentBot demo with filedb', async t => {
await innerTest(t, '--filedb');
await innerTest(t, '--filedb', 'filetest');
});

test('run encouragmentBot demo with lmdb', async t => {
await innerTest(t, '--lmdb');
await innerTest(t, '--lmdb', 'lmdbtest');
});

test('run encouragmentBot demo with default', async t => {
await innerTest(t, '');
await innerTest(t, '', 'defaulttest');
});

test('run encouragmentBot demo with indirectly loaded vats', async t => {
await innerTest(t, '--indirect');
await innerTest(t, '--indirect', 'indirecttest');
});

0 comments on commit eb2028d

Please sign in to comment.