-
-
Notifications
You must be signed in to change notification settings - Fork 47
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
AbortController (in Node), integration with CAF? #21
Comments
Thanks for the ping. I think I did see that recently, yes. Very glad to see it happening. The thing that comes to mind first is the need to be able to easily get a promise that resolves (or rejects!) when an a specific abort token is triggered. CAF implements this as a Do you have any thoughts on that? |
Also, more broadly, I'd like to see more (ideally, all someday) of Node's asynchronous APIs taking the For example: fs.writeFile("/path/to/file.txt", someBigContents, { encoding: "utf-8", signal }); One place that might be easy to start in terms of rolling out that support might be the Timers APIs, for example: setTimeout(
function whatever() {
// ..
},
{
delay: 2000,
signal
}
); |
Thanks for the detailed answer and feedback!
Unfortunately I don't think we are allowed (spec wise) to add methods to We do have a utility in const { once } = require('events');
const ac = new AbortController();
const { signal } = ac;
// some time later, we want to wait for the signal to abort
await once(signal, 'abort'); // Works with both EventTarget and EventEmitter, fulfills with `undefined` once the event fired One possible downside for this is that it doesn't fire if the signal already fired so the actual code would have to look like: await (signal.aborted || once(signal, 'abort')); Which might not be the most intuitive to users so the ergonomics do leave room for improvement. I have collaborated with whatwg before on related modifications (adding AbortSignal support to EventTarget for example) so I think adding Additionally we can (should we?) expose a utility for this in Node.js (we are allowed to do that without violating the spec). It can look something like: await aborted(signal); // fulfills the promise when the signal fires `abort` (or immediately if it is already aborted (As a fun tidbit -
I am very much in favour! We have been rapidly adding support for This is also true for the promises version of
Also happy to tell you that this already works (with setInterval landing less than 6 hours ago 🎉 ): import { setInterval, setTimeout /*, setImmediate*/ } from 'timers/promises'; // with "type": "module"
// const { setInterval, setTimeout, setImmediate } = require('timers/promises');
const ac = new AbortController();
const { signal } = ac;
setTimeout(500).then(() => ac.abort());
(async () => { // setInterval example
for await (const tick of setInterval(100, null, { signal })) {
console.log("interval ping")
}
})();
(async () => { // setTimeout example
console.log('before setTimeout');
try {
await setTimeout(1000, null, { signal });
console.log('timeout elapsed');
} catch (e) {
console.log('got an:', e.name);
}
console.log('after setTimeout');
})();
// Logs
// before setTimeout
// interval ping
// interval ping
// interval ping
// interval got an: AbortError
// timeout got an: AbortError
// after setTimeout Interesting times :] |
Hmm... question about the timers thing... it's passed as the third parameter? In the web, setTimeout/setInterval take optional third (and further) params and pass them as arguments to the callback. Does that break here? |
@getify it does break here - but whatwg seemed optimistic regarding adding a (future) new promises-based API and even said (and I quote):
So it seems like if (when) a promises version of setTimeout will reach the DOM it'll have AbortSignal support and no collision with the "regular" That said: Node timers and Web timers don't implement the same specification (or rather - Node timers don't follow the specification and return objects and not numbers) anyway :] (The main reason that the web timers promises version hasn't progressed is people dedicating time to working on it, I am pretty confident that if the spec was written and agreed on - browsers would implement) |
Ahhh... I hadn't looked at Node's "timers/promises" before. Yeah, the signature is different: since there's no callback there's no need to pass args. And instead, there's just a single |
I like this a lot. This would be great if Node could consider adding it: await aborted(signal); The name |
As for "compelling use case", basically I do this (via CAF) almost all the time: Promise.race([
// some work
// abort signal promise
]) |
I've opened a post regarding |
Seems like this has stalled indefinitely, so closing (for now). |
Hey Kyle 👋
Node recently(ish) shipped AbortController/AbortSignal (I believe I pinged you on one of the issues).
I just wanted to ask if there is anything Node.js should be doing differently with regards to our AbortController/AbortSignal or our usage of them in APIs or if you have an opinion regarding anything else we should do to improve the cancellation story.
The text was updated successfully, but these errors were encountered: