mirror of https://github.com/lukechilds/node.git
Browse Source
d1ba82af1c2528c71e1b6b6a57844a7519b66ccb "fixed" test-domain-exit-dispose-again by changing its logic to test that process.domain was cleared properly in case an error was thrown from a timer's callback. However, it became clear when reviewing a recent change that refactors lib/timers.js that it was not quite the intention of the original test. Thus, this change adds the original implementation of test-domain-exit-dispose-again back, with comments that make its implementation easier to understand. It also preserves the changes made by d1ba82af1c2528c71e1b6b6a57844a7519b66ccb, but it moves them to a new test file named test-timers-reset-process-domain-on-throw.js. PR: #4278 PR-URL: https://github.com/nodejs/node/pull/4278 Reviewed-By: James M Snell <jasnell@gmail.com>v0.12-staging
committed by
Myles Borins
2 changed files with 121 additions and 29 deletions
@ -0,0 +1,59 @@ |
|||||
|
// Copyright Joyent, Inc. and other Node contributors.
|
||||
|
//
|
||||
|
// Permission is hereby granted, free of charge, to any person obtaining a
|
||||
|
// copy of this software and associated documentation files (the
|
||||
|
// "Software"), to deal in the Software without restriction, including
|
||||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||||
|
// distribute, sublicense, and/or sell copies of the Software, and to permit
|
||||
|
// persons to whom the Software is furnished to do so, subject to the
|
||||
|
// following conditions:
|
||||
|
//
|
||||
|
// The above copyright notice and this permission notice shall be included
|
||||
|
// in all copies or substantial portions of the Software.
|
||||
|
//
|
||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||
|
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
|
||||
|
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
||||
|
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||
|
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
||||
|
// USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
|
|
||||
|
var common = require('../common'); |
||||
|
var assert = require('assert'); |
||||
|
var domain = require('domain'); |
||||
|
|
||||
|
// Use the same timeout value so that both timers' callbacks are called during
|
||||
|
// the same invocation of the underlying native timer's callback (listOnTimeout
|
||||
|
// in lib/timers.js).
|
||||
|
setTimeout(err, 50); |
||||
|
setTimeout(common.mustCall(secondTimer), 50); |
||||
|
|
||||
|
function err() { |
||||
|
var d = domain.create(); |
||||
|
d.on('error', handleDomainError); |
||||
|
d.run(err2); |
||||
|
|
||||
|
function err2() { |
||||
|
// this function doesn't exist, and throws an error as a result.
|
||||
|
err3(); |
||||
|
} |
||||
|
|
||||
|
function handleDomainError(e) { |
||||
|
// In the domain's error handler, the current active domain should be the
|
||||
|
// domain within which the error was thrown.
|
||||
|
assert.equal(process.domain, d); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
function secondTimer() { |
||||
|
// secondTimer was scheduled before any domain had been created, so its
|
||||
|
// callback should not have any active domain set when it runs.
|
||||
|
// Do not use assert here, as it throws errors and if a domain with an error
|
||||
|
// handler is active, then asserting wouldn't make the test fail.
|
||||
|
if (process.domain !== null) { |
||||
|
console.log('process.domain should be null, but instead is:', |
||||
|
process.domain); |
||||
|
process.exit(1); |
||||
|
} |
||||
|
} |
Loading…
Reference in new issue