chore(js): allow unhandledRejection plugin to be loaded more than once #1172
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Status
READY
Description
Part of #1163
This PR makes it safe to load the unhandledRejection plugin more than once.
If loaded with enableUnhandledRejection true, it will add a listener if one has not already been added
If loaded with enableUnhandledRejection false, it will remove the listener if it exists
However, the client itself still only loads the plugin once, so this PR should not cause any user-facing change in behavior.
Related PRs
#1170 does the same with unhandledException
Todos
Steps to Test or Reproduce
Unit tests mostly cover it, however I also tested manually using the
sails
example app. Any node-based example app would be fine, you just need to trigger a promise rejection where the middleware will not pick it up. egI tested with
enableUnhandledRejection: true
andfalse
.