Skip to content

Commit

Permalink
feat(swingset-tools): [replay] support bundleIDs
Browse files Browse the repository at this point in the history
  • Loading branch information
mhofman committed Apr 17, 2023
1 parent 468b739 commit 499472e
Showing 1 changed file with 35 additions and 15 deletions.
50 changes: 35 additions & 15 deletions packages/SwingSet/misc-tools/replay-transcript.js
Original file line number Diff line number Diff line change
Expand Up @@ -196,6 +196,19 @@ async function replay(transcriptFile) {
getRelaxDurabilityRules: () => false,
});

let bundleIDs;
/** @type {import('../src/controller/bundle-handler.js').BundleHandler} */
const bundleHandler = harden({
getCurrentBundleIDs: async () => {
return bundleIDs || ['lockdown-bundle', 'supervisor-bundle'];
},
getBundle: async id => {
const rawBundle = await fs.promises.readFile(id, { encoding: 'utf-8' });
const bundle = harden(JSON.parse(rawBundle));
return bundle;
},
});

const kernelSlog =
/** @type {import('../src/types-external.js').KernelSlog} */ (
/** @type {Partial<import('../src/types-external.js').KernelSlog>} */ ({
Expand Down Expand Up @@ -285,16 +298,14 @@ async function replay(transcriptFile) {
const workers = [];

if (worker === 'xs-worker') {
/** @type {import('../src/types-external.js').Bundle[]} */
const bundles = await (argv.useSdkBundles
? Promise.all([
/** @type {Promise<*>} */ (getLockdownBundle()),
/** @type {Promise<*>} */ (getSupervisorBundle()),
])
: [
JSON.parse(fs.readFileSync('lockdown-bundle', 'utf-8')),
JSON.parse(fs.readFileSync('supervisor-bundle', 'utf-8')),
]);
/** @type {import('../src/types-external.js').Bundle[] | undefined} */
let overrideBundles;
if (argv.useSdkBundles) {
overrideBundles = await Promise.all([
/** @type {Promise<*>} */ (getLockdownBundle()),
/** @type {Promise<*>} */ (getSupervisorBundle()),
]);
}

const capturePIDSpawn = /** @type {typeof spawn} */ (
/** @param {Parameters<typeof spawn>} args */
Expand All @@ -309,8 +320,8 @@ async function replay(transcriptFile) {
spawn: capturePIDSpawn,
debug: argv.useXsnapDebug,
workerTraceRootPath: argv.recordXsnapTrace ? process.cwd() : undefined,
overrideBundles: bundles,
bundleHandler: /** @type {*} */ (undefined),
overrideBundles,
bundleHandler,
});
factory = makeXsSubprocessFactory({
allVatPowers,
Expand Down Expand Up @@ -617,6 +628,7 @@ async function replay(transcriptFile) {
};

let vatParameters;
let vatSourceBundleID;
let vatSourceBundle;

/** @param {boolean} keep */
Expand Down Expand Up @@ -648,10 +660,13 @@ async function replay(transcriptFile) {
useTranscript: true,
workerOptions: {
type: worker === 'xs-worker' ? 'xsnap' : worker,
bundleIDs: [],
bundleIDs: await bundleHandler.getCurrentBundleIDs(),
},
})
);
if (!vatSourceBundle && !loadSnapshotID) {
vatSourceBundle = await bundleHandler.getBundle(vatSourceBundleID);
}
workerData.manager = await factory.createFromBundle(
vatID,
vatSourceBundle,
Expand Down Expand Up @@ -823,8 +838,13 @@ async function replay(transcriptFile) {
`first line of transcript was not a create-vat or heap-snapshot-load`,
);
}
({ vatParameters, vatSourceBundle } = data);
vatID = data.vatID;
({
vatParameters,
vatSourceBundle,
vatSourceBundleID,
bundleIDs,
vatID,
} = data);
const { xsnapPID } = await createManager(argv.keepWorkerExplicitLoad);
console.log(
`manager created from bundle source, worker PID: ${xsnapPID}`,
Expand Down

0 comments on commit 499472e

Please sign in to comment.