Skip to content
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

undefined error issue #69

Open
rahulreddy opened this issue Mar 24, 2016 · 5 comments
Open

undefined error issue #69

rahulreddy opened this issue Mar 24, 2016 · 5 comments

Comments

@rahulreddy
Copy link
Collaborator

Making sure this issue gets logged so that we don't forget about this. While fixing Vault with pr https://github.com/scality/IronMan-Vault/pull/228
we noticed that if we mess up the case(uppercase/lowercase) of the arsenal error property, we just return undefined back to the calling function. Now we don't know if we got undefined because there was no error or if the Arsenal error property does not exist.

@ghost
Copy link

ghost commented Mar 24, 2016

I guess the only way to properly solve this is to use the following ES6 technique, following this Stack Overflow post:
http://stackoverflow.com/questions/20147081/javascript-catch-access-to-property-of-object
and
http://wiki.ecmascript.org/doku.php?id=harmony%3adirect_proxies

Edit: The sad thing is that it's not supported by Node.JS at the moment. We might want to take a look into Babel's way of translating this feature; so that we can do it on our own in Arsenal, without relying on babel.
Edit: Even sadder... support cannot be brought through observing Babel:

Unsupported feature
Due to the limitations of ES5, Proxies cannot be transpiled or polyfilled. See support in various JavaScript engines.

I wanna cry :'(

@ghost ghost added the enhancement label Mar 24, 2016
@rahulreddy
Copy link
Collaborator Author

😞 that hurts.
We wouldn't want to mess with Object's prototype chain either.

@ghost
Copy link

ghost commented Mar 25, 2016

I'm completely not against such kind of metaprogramming, and that's the only way I see that would have allowed to keep the current API, while ensuring that using an undefined error name would have used either a "default error" or failed early.

That might be my dark metaprogrammer side talking here, but I love simple APIs that are powerful :D

@ghost
Copy link

ghost commented Mar 25, 2016

This is where static analysis is supposed to shine. I'll try to look into that in my free time.

@ghost
Copy link

ghost commented Mar 25, 2016

Indeed, it's yet another track to follow, but still, this means setting up a tool in all projects to ensure that this one is used properly. I'd rather have it self contained with black magic ^^'

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant