This is not well maintained
This is not traditional RPC, but it is like it
yarn add @ch1/rpc-worker
Slightly easier API than in the raw @ch1/rpc
Main JS Script
import * as wrpc from '@ch1/rpc-worker';
const w = new Worker(TEST_FILE);
const rpc = wrpc.create({ worker: w });
rpc.ready
.then(() => rpc.remote.foo())
.then(result => {
expect(result).toBe(7);
done();
})
.catch(done);
Worker JS
import * as wrpc from '@ch1/rpc-worker';
wrpc.create(undefined, {
foo: () => new Promise(resolve => resolve(7)),
});
- Individual remote function calls handle their own errors through their own async interfaces
- Global errors related specifically to the workers trigger
onDestroy
- Calling
RPC<RemoteType>.destroy()
will call terminate on the worker
import * as wrpc from '@ch1/rpc-worker';
const w = new Worker(TEST_FILE);
const rpc = wrpc.create({ worker: w });
rpc.ready
.then(() => rpc.remote.foo())
.then(result => {
expect(result).toBe(7);
done();
})
.catch(done);
// handle onDestroy here
rpc.onDestroy((reason?: string) => {
// cleanup, restart, whatever
});
The worker extension is pretty much as described above. For more information
on the RPC<RemoteType>
object see the
@ch1/rpc docs