summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorAnatoli Papirovski <apapirovski@mac.com>2017-12-10 13:11:18 -0500
committerAnatoli Papirovski <apapirovski@mac.com>2017-12-13 09:33:27 -0500
commit04ae4862e670a8849454e6d8db4d8f73d0492190 (patch)
tree37e1dfe921dd61c37e5dd2178f844e430511ebe9 /test
parent47edfd9c3c80ba70e0633d755c6aed111a3569d6 (diff)
downloadnode-new-04ae4862e670a8849454e6d8db4d8f73d0492190.tar.gz
domain: fix error emit handling
Fix an issue where error is never emitted on the original EventEmitter in situations where a listener for error does exist. Refactor to eliminate unnecessary try/catch/finally block. PR-URL: https://github.com/nodejs/node/pull/17588 Refs: https://github.com/nodejs/node/pull/17403 Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de> Reviewed-By: James M Snell <jasnell@gmail.com>
Diffstat (limited to 'test')
-rw-r--r--test/parallel/test-domain-ee-error-listener.js20
1 files changed, 20 insertions, 0 deletions
diff --git a/test/parallel/test-domain-ee-error-listener.js b/test/parallel/test-domain-ee-error-listener.js
new file mode 100644
index 0000000000..69041c7523
--- /dev/null
+++ b/test/parallel/test-domain-ee-error-listener.js
@@ -0,0 +1,20 @@
+'use strict';
+
+const common = require('../common');
+const assert = require('assert');
+const domain = require('domain').create();
+const EventEmitter = require('events');
+
+domain.on('error', common.mustNotCall());
+
+const ee = new EventEmitter();
+
+const plainObject = { justAn: 'object' };
+ee.once('error', common.mustCall((err) => {
+ assert.deepStrictEqual(err, plainObject);
+}));
+ee.emit('error', plainObject);
+
+const err = new Error('test error');
+ee.once('error', common.expectsError(err));
+ee.emit('error', err);