-
-
Notifications
You must be signed in to change notification settings - Fork 13
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
Support for returning promises, and async/await functions. #25
Comments
So I think that TaskGroup and Task should function as promises in the upcoming release, as well as check for promises. Ambi should not be updated. what will need to be done here is compliance with: |
What changed your mind into this path? |
Well, all functionality will be the same. The only changes it seems are having This approach wins out, over something like a The reasoning for no changes to ambi, is that if TaskGroup/Task add promise interop directly, then ambi can serve merely has the async callback wrapper - as if people have a pure promise workflow, they may want to disable ambi completely - as there is no way ambi can operate without the risk of injecting a next callback, which a promise workflow may not desire. Otherwise the updates to ambi could be the following:
That said, the power of ambi's |
pushed up the initial work for this during 2017-03-28 over at https://github.com/bevry/taskgroup/tree/feature/promise |
Aiming to tackle this soon. |
So ambi support for promises completed a while back https://github.com/bevry/ambi - all that is waiting for this is the implementation of it along with prior work if there is any As well as support for |
Promises run immediately, and thus all at once, do not catch/isolate uncaught async errors, and can lose errors if
.catch
was not specified pedantically. Tasks run when you tell them too and using domains can catch/isolate uncaught errors within a task, and will throw errors if not handled. TaskGroup can thus control the concurrency, and be configured on how to deal with error situations - continue, pause, or by default abort and clear - and again, will throw errors if not handled. These factors alone provide why TaskGroup is superior to Promises, however, nevertheless, Promises are popular, and we should provide ways of supporting them to make integration, and perhaps conversion, with that scene easier.The relevant layers of TaskGroup are:
Here are the options I can determine.
Consumption
Add promise consumption to ambi, such that one can do this:
Add promise consumption support to Task, such that one can do this:
Add promise consumption support to TaskGroup, such that one can do this:
Production
Exposing promises could be done via providing a
.promise
getter instead of.done(callback)
:I lean towards the above over having Task and TaskGroup extend the Promise class, as the promise API is an ever expanding glob or crap trying to workaround their inherent shortcomings - hence the introduction of their proposed
done
method and other official and non-official spec modifications implemented by the vast array of promise scene implementations.However, the above requires the consumer to be aware that what they are consuming is a Task or TaskGroup, rather than just a promise, which if you are writing a simple library, may not be ideal. Once could write a wrapper around Task and TaskGroup, that could swap out their excellent API for the wrose Promise API. Such as:
However, I am not sure fragmenting the TaskGroup ecosystem makes sense in this way, hence why I still lean towards a
.promise
getter.Conclusions
Other ideas and discussion are welcome.
For consumption, seems adding promise consumption to ambi makes the most sense, as adding support to Task and TaskGroup means promises fire immediately, and there will be no support for things like task args. To make things easier, such that
Task.create(new Promise(...))
is supported, ambi could check if the method is already a promise, before executing it and checking the return result. A question here, is what if a method returns a promise and accepts a callback as many interop libraries do.For production, seems doing
.promise
is the best idea. Perhaps even with a getter for.then
and.catch
to alias.promise.then
and.promise.catch
for easier interop - however I am not sure if implementing such things will pass the promise scene'sisPromise
checks:Would be interesting to see how ambi or Task handles the above case, in terms of what error or enforcement it should produce, or whether it should discard the callback or the promise.
It is also worth mentioning our Chainy project, that provides the chaining abilities of promises to the TaskGroup ecosystem, in a microjs way.
The text was updated successfully, but these errors were encountered: