-
Notifications
You must be signed in to change notification settings - Fork 595
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
Possibly unhandled error should be thrown #70
Comments
Upstream RSVP supports this, as this isn't part of the spec it is up to @jakearchibald if he wants it or not. Let me know, and i'll add it. |
This should be part of the shim for old browser. Or it could be really error-prone in practical usage. |
I strangely suspect @jakearchibald will be fine with this. |
Unhandled errors should definitely be thrown! |
I've written the following proposal about this here https://gist.github.com/benjamingr/0237932cee84712951a2 I'd love your feedback. Here's the related RSVP issue: tildeio/rsvp.js#355 |
+1, throw me them errors, please -- spent an hour tracking down what turned out to be a missing at the least, es6-promise could expose a sort of catchall error-handling API as RSVP seems to do here: https://github.com/tildeio/rsvp.js#error-handling |
Chrome currently logs unhandled errors. Firefox does it on GC. Happy to do the same as Chrome here. It should be a log rather than a throw, we'd be spec-breaking if it appeared in |
@jakearchibald node.js still don't throw anything. |
Yep. Wait, maybe you misunderstood my comment, "Chrome currently logs unhandled errors. Firefox does it on GC." was refering to native promises |
IMO its a totally different type of error, its not a synchronous error, its not like you can wrap a try-catch block round it. It should be something that should be pushed into the .catch handler, as the promise spec states, maybe logged similar to how bluebird doing it. |
@ysmood io is merging a patch for the events (my proposal) in the next version. I think you should implement this |
Is this going to be done? A |
@ollym I wrote another Promsie lib, it's smaller, faster, and more error friendly. For more details goto: https://github.com/ysmood/yaku |
@ysmood good job! Im curious if you have any enumeration/denodify benchmark examples to go with your existing benchmarks. |
@stefanpenner I'm not sure what the |
benchmarks involving |
Is there something we project consumers can do to help move this along? This is a bit painful. |
@spikebrehm You can replace promise-es6 with Yaku. Their api are the same, and yaku fixed the problem. |
when does this according to @domenic’s spec: https://github.com/cujojs/when/blob/master/docs/debug-api.md#global-rejection-events Events:
The default event handler should log. |
I'm using v2.2.0 (installed via bower from github.com/components) and I got around this issue with the following shim:
I don't see why this won't also work on the latest |
I think I should close this issue, because I solved the problem perfectly with Yaku, and I can't find any reason to keep using es6-promise any more. |
@ysmood in the interest of the greater community that does continue to use and rely on this polyfill, perhaps reopen the issue until it is actually resolved? @jakearchibald, any comment on the intent to implement this (i.e. merge it down from RSVP)? Thanks! |
@usmonster This issue has lasted half year now. There no API difference between most ES6 promise shim libs. You simply change one line of the |
@ysmood it's not only about waiting for @jakearchibald to address it, but to give visibility of the issue to anyone considering to use this library. |
@frosas You are right. If I am the author of ES6-promise, I will write a list to compare different promise libs on the README, and let people aware of the key disadvantages of each lib, include es6-promise itself. We should give people the chance to choose, not hidden the truth. |
+1 |
Chrome does not throw an error. |
Right, I think what @niondir wants is to add the behavior you specified for Chrome 49 with |
I also do not know why this polyfill takes effect in browsers where promises are implemented already. An alternative solution coud be to just not define the Polyfill where Promise already exists. Especially because ES6 modules do not allow to conditionally load a module anymore. |
A lot of browsers implement the spec incorrectly and do not allow, for example, to subclass promises. This behavior can be easily amended by implementing the unhandled rejection spec (both the browser and Node) and |
@benjamingr are you suggesting a simple monkey patch to implement the unhandled rejection spec when using the es6-promise library, or a fix to the lib itself? |
…t anyway es6-promise.polyfill() is broken for Chrome atm and replaces the native Promise and swallows unhandled errors. stefanpenner/es6-promise#70
The means to catch unhandled rejections is a part of ECMAScript 2017 Draft spec (as HostPromiseRejectionTracker). Looking forward to see it in this library! |
Ya, still trying to find time ;) It will land, I was a big proponent of the feature in the first place. |
To clarify, the only thing in the ES spec is implementation-specific hooks, and restrictions around what implementations may do. An example implementation of this hook is in whatwg, but that's not part of ECMAScript itself. |
Hi, would love to use this polyfill, but been avoiding for this reason (that the silent swallowing of all exceptions is completely unacceptable). Now that Node has a workaround for this ...
... could this polyfill also buck the (IMO lacking) standard and do something similar? |
@nilliams it will be part of 5.0, as described by the milestone assignment |
Okay that is great news thanks! (And sorry I don't find those sorts of github 'events' that interject the issue thread particularly explicit, my eyes tend to skip over them). |
I want to be open about the fact I've recommended the isomorphic-fetch module moves away from this as suggested polyfill for this reason, until it's fixed, though it's fairly likely I'm just out of the loop on this: matthew-andrews/isomorphic-fetch#111 |
@nilliams I only have so many cycles, given infinite time this would have been done already ;) |
Yes :) I know and appreciate that, and apologies ... I really don't mean to pick on your excellent project. I am just very aware that both the (There are other reasons, like - last I checked - the Personally I'm part of a small team and burned maybe 2 days of effort trying to use isomorphic-fetch, and then ripping it out a week or two later, and I don't want people to face the same pain when frankly they'd be better off with sticking to more old-school ajax libraries (again I appreciate it's not your fault these libs are recommending you, and I know you're only sticking to the spec). I've just added an even worse example to the other thread, I think that bug is actually a separate issue in your tracker -- I think there's a workaround involving using setTimeout in |
please see: #232 (comment) Just waiting patiently to pull the trigger. |
This isn't new information, I personally use a variant of this exact library which has this feature ;) I just haven't had spare cycles to port it over. Hopefully soon! |
Locking this, because no new information is possible. The constraint has been the same for some time, and that is my own time (or someones contribution to this project). At some-point, hopefully soon, I will have the spare cycles, until then please be mindful of this. Note: I do appreciate the need and concerns, and as mentioned above, this is something I intend to support. If someone has invented a way to skip sleep, and work on more OSS, please share ;) |
Node v0.10, non-harmony. Such as:
The text was updated successfully, but these errors were encountered: