Skip to content

Commit

Permalink
fix(daemon): Fix provision of new, unnamed workers
Browse files Browse the repository at this point in the history
Fixes the provision of new (i.e. `NEW`) unnamed workers after #2139 broke
it. Adds a regression test for this case.
  • Loading branch information
rekmarks committed Mar 18, 2024
1 parent 772e461 commit fb2c255
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 17 deletions.
24 changes: 7 additions & 17 deletions packages/daemon/src/host.js
Original file line number Diff line number Diff line change
Expand Up @@ -128,9 +128,7 @@ export const makeHostMaker = ({
/** @type {import('./types.js').DeferredTasks<import('./types.js').WorkerDeferredTaskParams>} */
const tasks = makeDeferredTasks();
// eslint-disable-next-line no-use-before-define
const workerId = tryGetWorkerId(workerName);
// eslint-disable-next-line no-use-before-define
prepareWorkerFormulation(workerName, workerId, tasks.push);
const workerId = prepareWorkerFormulation(workerName, tasks.push);

if (workerId !== undefined) {
return /** @type {Promise<import('./types.js').EndoWorker>} */ (
Expand All @@ -145,28 +143,22 @@ export const makeHostMaker = ({

/**
* @param {string} workerName
* @returns {string | undefined}
* @param {import('./types.js').DeferredTasks<{ workerId: string }>['push']} deferTask
*/
const tryGetWorkerId = workerName => {
const prepareWorkerFormulation = (workerName, deferTask) => {
if (workerName === 'MAIN') {
return mainWorkerId;
} else if (workerName === 'NEW') {
return undefined;
}
return petStore.identifyLocal(workerName);
};

/**
* @param {string} workerName
* @param {string | undefined} workerId
* @param {import('./types.js').DeferredTasks<{ workerId: string }>['push']} deferTask
*/
const prepareWorkerFormulation = (workerName, workerId, deferTask) => {
const workerId = petStore.identifyLocal(workerName);
if (workerId === undefined) {
deferTask(identifiers =>
petStore.write(workerName, identifiers.workerId),
);
}
return workerId;
};

/**
Expand All @@ -193,8 +185,7 @@ export const makeHostMaker = ({
/** @type {import('./types.js').DeferredTasks<import('./types.js').EvalDeferredTaskParams>} */
const tasks = makeDeferredTasks();

const workerId = tryGetWorkerId(workerName);
prepareWorkerFormulation(workerName, workerId, tasks.push);
const workerId = prepareWorkerFormulation(workerName, tasks.push);

/** @type {(string | string[])[]} */
const endowmentFormulaIdsOrPaths = petNamePaths.map(
Expand Down Expand Up @@ -245,8 +236,7 @@ export const makeHostMaker = ({
/** @type {import('./types.js').DeferredTasks<import('./types.js').MakeCapletDeferredTaskParams>} */
const tasks = makeDeferredTasks();

const workerId = tryGetWorkerId(workerName);
prepareWorkerFormulation(workerName, workerId, tasks.push);
const workerId = prepareWorkerFormulation(workerName, tasks.push);

const powersId = petStore.identifyLocal(powersName);
if (powersId === undefined) {
Expand Down
22 changes: 22 additions & 0 deletions packages/daemon/test/test-endo.js
Original file line number Diff line number Diff line change
Expand Up @@ -149,6 +149,28 @@ test('anonymous spawn and evaluate', async t => {
await stop(locator);
});

test('anonymous spawn and evaluate with new worker', async t => {
const { promise: cancelled, reject: cancel } = makePromiseKit();
t.teardown(() => cancel(Error('teardown')));
const locator = makeLocator('tmp', 'spawn-eval-anon-new-worker');

await stop(locator).catch(() => {});
await purge(locator);
await start(locator);

const { getBootstrap } = await makeEndoClient(
'client',
locator.sockPath,
cancelled,
);
const bootstrap = getBootstrap();
const host = E(bootstrap).host();
const ten = await E(host).evaluate('NEW', '10', [], []);
t.is(ten, 10);

await stop(locator);
});

// Regression test for https://github.com/endojs/endo/issues/2147
test('spawning a worker does not overwrite existing non-worker name', async t => {
const { promise: cancelled, reject: cancel } = makePromiseKit();
Expand Down

0 comments on commit fb2c255

Please sign in to comment.