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

timers: use consistent checks for canceled timers #9685

Merged

Conversation

Fishrock123
Copy link
Contributor

@Fishrock123 Fishrock123 commented Nov 18, 2016

Checklist
  • make -j8 test (UNIX), or vcbuild test nosign (Windows) passes
  • tests and/or benchmarks are included
  • commit message follows commit guidelines
Affected core subsystem(s)

timers

Description of change

Previously not all codepaths set timer._idleTimeout = -1 for canceled
or closed timers, and not all codepaths checked it either.

Unenroll uses this to say that a timer is indeed closed and it is the
closest thing there is to an authoritative source for this.

Refs: #9606
Fixes: #9561

I think the problem originated from or became more apparent after c8c2544

CI: https://ci.nodejs.org/job/node-test-pull-request/4898/

cc @cjihrig, @misterdjules, @watson

(This patch was made live during https://www.twitch.tv/nodesource/v/101846332 if you'd like to see me working on this in retrospect. :P)

@Fishrock123 Fishrock123 added the timers Issues and PRs related to the timers subsystem / setImmediate, setInterval, setTimeout. label Nov 18, 2016
@nodejs-github-bot nodejs-github-bot added the timers Issues and PRs related to the timers subsystem / setImmediate, setInterval, setTimeout. label Nov 18, 2016

const keepOpen = setTimeout(() => {
common.fail('Test timed out.');
}, common.platformTimeout(500)); // Keep event loop open.
Copy link
Member

@Trott Trott Nov 19, 2016

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would much prefer this just keep the event loop open indefinitely and not throw:

const keepOpen = setInterval(() => {}, 9999);

(Would need to change clearTimeout() below to clearInterval().)

EDIT: Meh, forget indefinitely, better for just one tick, see below.

@nodejs/testing

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Trott I'm not clear on what benefit that would have, could you elaborate?

All the unref timers are guaranteed to fire before this, it could be just 2ms theoretically in that respect, but we do need to actually keep it open long enough for the 1ms timeouts to happen twice IIRC.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

All the unref timers are guaranteed to fire before this,

No, they are not. On a sufficiently heavily loaded machine, they will fail to fire before the common.fail(). If recent history is any guide, this test will be flaky on FreeBSD in CI.

Try this to see it fail (unless you have an absurdly well-provisioned machine):

tools/test.py -j 96 parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-intervalparallel/test-timers-unenroll-unref-interval parallel/test-timers-unenroll-unref-interval 

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I guess I'll also add/clarify that even If it seems like I'm being ridiculous and this will never ever cause problems itself, arbitrary-length timeouts in tests are a bit of an anti-pattern that have bitten us over and over. So even if it's just to set a good example for other people writing tests, it's good (IMO) to remove arbitrary-length timers.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(And last: I don't object to this landing as-is.)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That is why I suggested what I did in my last comment.

Which suggestion was that?

Copy link
Member

@Trott Trott Nov 21, 2016

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

then there is a very bad ordering bug in the timers impl when under load.

I don't think that's the correct interpretation.

If load is sufficient, the initial setTimeout() callback will fire on the same tick as all the setIntervals() callbacks (although after they run). The setImmediate() callbacks set inside the intervals will happen on the next tick, after the setTimeout() callback has thrown an error.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

All the unref timers are guaranteed to fire before this,

No, they are not.

Clarification: Yes, the unref'ed intervals will fire before the timer. However, the test will still fail if the immediates wrapped inside the unref'ed intervals don't fire before the timer, and that's what's not guaranteed.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think that's the correct interpretation.

Would it help if I set up a meeting with you to explain what actually happens with timers and why I am asserting that would be broken behavior?

Clarification: Yes, the unref'ed intervals will fire before the timer. However, the test will still fail if the immediates wrapped inside the unref'ed intervals don't fire before the timer, and that's what's not guaranteed.

Thanks, I'll fix this so that it more precisely relies on the event loop specifics.

Copy link
Member

@Trott Trott Nov 21, 2016

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks, I'll fix this so that it more precisely relies on the event loop specifics.

Here's what I'd propose, FWIW:

'use strict';

const common = require('../common');
const timers = require('timers');

setImmediate(common.mustCall(() => {})); // Keep event loop open for one tick.

{
  const interval = setInterval(common.mustCall(() => {
    clearTimeout(interval);
    setImmediate(common.mustCall(() => {}));
  }), 1).unref();
}

{
  const interval = setInterval(common.mustCall(() => {
    interval.close();
    setImmediate(common.mustCall(() => {}));
  }), 1).unref();
}

{
  const interval = setInterval(common.mustCall(() => {
    timers.unenroll(interval);
    setImmediate(common.mustCall(() => {}));
  }), 1).unref();
}

{
  const interval = setInterval(common.mustCall(() => {
    interval._idleTimeout = -1;
    setImmediate(common.mustCall(() => {}));
  }), 1).unref();
}

{
  const interval = setInterval(common.mustCall(() => {
    interval._onTimeout = null;
    setImmediate(common.mustCall(() => {}));
  }), 1).unref();
}

@watson
Copy link
Member

watson commented Nov 19, 2016

Thanks @Fishrock123 😍 And I'm on Twich! (sort of) I made it to the big times 😜

@Fishrock123 Fishrock123 force-pushed the fix-timers-cancel-in-interval branch from c11e465 to 11bb6f2 Compare November 21, 2016 21:36
@Fishrock123
Copy link
Contributor Author

Updated. I ran it under much more extreme load without issue. (Almost 1k at 1k parallization.)

New CI: https://ci.nodejs.org/job/node-test-pull-request/4926/console

@Trott could you please read the comment in the test and let me know if it makes sense?

@Fishrock123 Fishrock123 force-pushed the fix-timers-cancel-in-interval branch from 11bb6f2 to a89a08f Compare November 21, 2016 21:40
@Fishrock123
Copy link
Contributor Author

Updated with an extra comment link, CI again: https://ci.nodejs.org/job/node-test-pull-request/4927/

@Trott
Copy link
Member

Trott commented Nov 21, 2016

@Trott could you please read the comment in the test and let me know if it makes sense?

Comment and test LGTM (assuming no issues discovered in CI, of course).

// than the previous timeouts, unrefed or not.
//
// Keep the event loop alive for one timeout and then
// another. Any problems will ocurr when the second
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit: occur

@Fishrock123 Fishrock123 force-pushed the fix-timers-cancel-in-interval branch from a89a08f to 55efbfe Compare November 22, 2016 17:24
@Fishrock123 Fishrock123 force-pushed the fix-timers-cancel-in-interval branch from 55efbfe to 98fea5b Compare November 22, 2016 17:24
Previously not all codepaths set `timer._idleTimeout = -1` for canceled
or closed timers, and not all codepaths checked it either.

Unenroll uses this to say that a timer is indeed closed and it is the
closest thing there is to an authoritative source for this.

Refs: nodejs#9606
Fixes: nodejs#9561
PR-URL: nodejs#9685
Reviewed-By: Rich Trott <rtrott@gmail.com>
@Fishrock123 Fishrock123 force-pushed the fix-timers-cancel-in-interval branch from 98fea5b to 3f1e38c Compare November 22, 2016 17:28
@Fishrock123 Fishrock123 merged commit 3f1e38c into nodejs:master Nov 22, 2016
Fishrock123 added a commit that referenced this pull request Nov 22, 2016
Previously not all codepaths set `timer._idleTimeout = -1` for canceled
or closed timers, and not all codepaths checked it either.

Unenroll uses this to say that a timer is indeed closed and it is the
closest thing there is to an authoritative source for this.

Refs: #9606
Fixes: #9561
PR-URL: #9685
Reviewed-By: Rich Trott <rtrott@gmail.com>
@MylesBorins
Copy link
Contributor

@Fishrock123 should this be backported to v6?

@Fishrock123
Copy link
Contributor Author

@thealphanerd This should be backported to both. The test aborts on both LTS versions.

@Fishrock123
Copy link
Contributor Author

I'm working on a 4.x backport.

Fishrock123 added a commit to Fishrock123/node that referenced this pull request Dec 21, 2016
Previously not all codepaths set `timer._idleTimeout = -1` for canceled
or closed timers, and not all codepaths checked it either.

Unenroll uses this to say that a timer is indeed closed and it is the
closest thing there is to an authoritative source for this.

Refs: nodejs#9606
Fixes: nodejs#9561
PR-URL: nodejs#9685
Reviewed-By: Rich Trott <rtrott@gmail.com>

 Conflicts:
	lib/timers.js
@Fishrock123
Copy link
Contributor Author

@thealphanerd lands on v4.x cleanly, v4.x backport at #10365

@joyeecheung
Copy link
Member

#4303 looks similar to this one and is still open.

MylesBorins pushed a commit that referenced this pull request Dec 21, 2016
Previously not all codepaths set `timer._idleTimeout = -1` for canceled
or closed timers, and not all codepaths checked it either.

Unenroll uses this to say that a timer is indeed closed and it is the
closest thing there is to an authoritative source for this.

Refs: #9606
Fixes: #9561
PR-URL: #9685
Reviewed-By: Rich Trott <rtrott@gmail.com>

 Conflicts:
	lib/timers.js
MylesBorins pushed a commit that referenced this pull request Dec 21, 2016
Previously not all codepaths set `timer._idleTimeout = -1` for canceled
or closed timers, and not all codepaths checked it either.

Unenroll uses this to say that a timer is indeed closed and it is the
closest thing there is to an authoritative source for this.

Refs: #9606
Fixes: #9561
PR-URL: #9685
Reviewed-By: Rich Trott <rtrott@gmail.com>
MylesBorins pushed a commit that referenced this pull request Dec 21, 2016
PR-URL: #10365
Ref: #9685

Reviewed-By: Myles Borins <myles.borins@gmail.com>
MylesBorins pushed a commit that referenced this pull request Dec 21, 2016
Previously not all codepaths set `timer._idleTimeout = -1` for canceled
or closed timers, and not all codepaths checked it either.

Unenroll uses this to say that a timer is indeed closed and it is the
closest thing there is to an authoritative source for this.

Refs: #9606
Fixes: #9561
PR-URL: #9685
Reviewed-By: Rich Trott <rtrott@gmail.com>
MylesBorins pushed a commit that referenced this pull request Dec 21, 2016
Previously not all codepaths set `timer._idleTimeout = -1` for canceled
or closed timers, and not all codepaths checked it either.

Unenroll uses this to say that a timer is indeed closed and it is the
closest thing there is to an authoritative source for this.

Refs: #9606
Fixes: #9561
PR-URL: #9685
Reviewed-By: Rich Trott <rtrott@gmail.com>

 Conflicts:
	lib/timers.js
MylesBorins pushed a commit that referenced this pull request Dec 21, 2016
PR-URL: #10365
Ref: #9685

Reviewed-By: Myles Borins <myles.borins@gmail.com>
This was referenced Dec 21, 2016
MylesBorins added a commit that referenced this pull request Jan 3, 2017
This LTS release comes with 180 commits. This includes 117 which are
test related, 34 which are doc related, 15 which are build / tool
related, and 1 commit which is an update to dependencies.

Notable Changes:

* build:
  - shared library support is now working for AIX builds
    (Stewart Addison) #9675
* repl:
  - Passing options to the repl will no longer overwrite defaults
    (cjihrig) #7826
* timers:
  - Re canceling a cancelled timers will no longer throw
    (Jeremiah Senkpiel) #9685

PR-URL: #10395
MylesBorins added a commit that referenced this pull request Jan 3, 2017
This LTS release comes with 312 commits. This includes 229 that are
test related, 62 that are docs related, 17 which are build / tools
related, and 4 commits which are updates to dependencies.

Notable Changes:

* build:
  - shared library support is now working for AIX builds
    (Stewart Addison) #9675
* deps:
    - *npm*: upgrade npm to 3.10.10 (Rebecca Turner)
             #9847
    - *V8*: Destructuring of arrow function arguments via computed
            property no longer throws (Michaël Zasso)
            #10386)
* inspector:
  - /json/version returns object, not an object wrapped in an array
    (Ben Noordhuis) #9762
* module:
  - using --debug-brk and --eval together now works as expected
    (Kelvin Jin) #8876
* process:
  - improve performance of nextTick up to 20% (Evan Lucas)
    #8932
* repl:
    - the division operator will no longer be accidentally parsed as
      regex (Teddy Katz) #10103
    - improved support for generator functions (Teddy Katz)
      #9852
* timers:
  - Re canceling a cancelled timers will no longer throw
    (Jeremiah Senkpiel) #9685

PR-URL: #10394
MylesBorins added a commit that referenced this pull request Jan 3, 2017
This LTS release comes with 312 commits. This includes 229 that are
test related, 62 that are docs related, 17 which are build / tools
related, and 4 commits which are updates to dependencies.

Notable Changes:

* build:
  - shared library support is now working for AIX builds
    (Stewart Addison) #9675
* deps:
    - *npm*: upgrade npm to 3.10.10 (Rebecca Turner)
             #9847
    - *V8*: Destructuring of arrow function arguments via computed
            property no longer throws (Michaël Zasso)
            #10386)
* inspector:
  - /json/version returns object, not an object wrapped in an array
    (Ben Noordhuis) #9762
* module:
  - using --debug-brk and --eval together now works as expected
    (Kelvin Jin) #8876
* process:
  - improve performance of nextTick up to 20% (Evan Lucas)
    #8932
* repl:
    - the division operator will no longer be accidentally parsed as
      regex (Teddy Katz) #10103
    - improved support for generator functions (Teddy Katz)
      #9852
* timers:
  - Re canceling a cancelled timers will no longer throw
    (Jeremiah Senkpiel) #9685

PR-URL: #10394
MylesBorins added a commit that referenced this pull request Jan 4, 2017
This LTS release comes with 180 commits. This includes 117 which are
test related, 34 which are doc related, 15 which are build / tool
related, and 1 commit which is an update to dependencies.

Notable Changes:

* build:
  - shared library support is now working for AIX builds
    (Stewart Addison) #9675
* repl:
  - Passing options to the repl will no longer overwrite defaults
    (cjihrig) #7826
* timers:
  - Re canceling a cancelled timers will no longer throw
    (Jeremiah Senkpiel) #9685

PR-URL: #10395
imyller added a commit to imyller/meta-nodejs that referenced this pull request Mar 2, 2017
    This LTS release comes with 180 commits. This includes 117 which are
    test related, 34 which are doc related, 15 which are build / tool
    related, and 1 commit which is an update to dependencies.

    Notable Changes:

    * build:
      - shared library support is now working for AIX builds
        (Stewart Addison) nodejs/node#9675
    * repl:
      - Passing options to the repl will no longer overwrite defaults
        (cjihrig) nodejs/node#7826
    * timers:
      - Re canceling a cancelled timers will no longer throw
        (Jeremiah Senkpiel) nodejs/node#9685

    PR-URL: nodejs/node#10395

Signed-off-by: Ilkka Myller <ilkka.myller@nodefield.com>
imyller added a commit to imyller/meta-nodejs that referenced this pull request Mar 2, 2017
    This LTS release comes with 312 commits. This includes 229 that are
    test related, 62 that are docs related, 17 which are build / tools
    related, and 4 commits which are updates to dependencies.

    Notable Changes:

    * build:
      - shared library support is now working for AIX builds
        (Stewart Addison) nodejs/node#9675
    * deps:
        - *npm*: upgrade npm to 3.10.10 (Rebecca Turner)
                 nodejs/node#9847
        - *V8*: Destructuring of arrow function arguments via computed
                property no longer throws (Michaël Zasso)
                nodejs/node#10386)
    * inspector:
      - /json/version returns object, not an object wrapped in an array
        (Ben Noordhuis) nodejs/node#9762
    * module:
      - using --debug-brk and --eval together now works as expected
        (Kelvin Jin) nodejs/node#8876
    * process:
      - improve performance of nextTick up to 20% (Evan Lucas)
        nodejs/node#8932
    * repl:
        - the division operator will no longer be accidentally parsed as
          regex (Teddy Katz) nodejs/node#10103
        - improved support for generator functions (Teddy Katz)
          nodejs/node#9852
    * timers:
      - Re canceling a cancelled timers will no longer throw
        (Jeremiah Senkpiel) nodejs/node#9685

    PR-URL: nodejs/node#10394

Signed-off-by: Ilkka Myller <ilkka.myller@nodefield.com>
imyller added a commit to imyller/meta-nodejs that referenced this pull request Mar 2, 2017
    This LTS release comes with 180 commits. This includes 117 which are
    test related, 34 which are doc related, 15 which are build / tool
    related, and 1 commit which is an update to dependencies.

    Notable Changes:

    * build:
      - shared library support is now working for AIX builds
        (Stewart Addison) nodejs/node#9675
    * repl:
      - Passing options to the repl will no longer overwrite defaults
        (cjihrig) nodejs/node#7826
    * timers:
      - Re canceling a cancelled timers will no longer throw
        (Jeremiah Senkpiel) nodejs/node#9685

    PR-URL: nodejs/node#10395

Signed-off-by: Ilkka Myller <ilkka.myller@nodefield.com>
imyller added a commit to imyller/meta-nodejs that referenced this pull request Mar 2, 2017
    This LTS release comes with 312 commits. This includes 229 that are
    test related, 62 that are docs related, 17 which are build / tools
    related, and 4 commits which are updates to dependencies.

    Notable Changes:

    * build:
      - shared library support is now working for AIX builds
        (Stewart Addison) nodejs/node#9675
    * deps:
        - *npm*: upgrade npm to 3.10.10 (Rebecca Turner)
                 nodejs/node#9847
        - *V8*: Destructuring of arrow function arguments via computed
                property no longer throws (Michaël Zasso)
                nodejs/node#10386)
    * inspector:
      - /json/version returns object, not an object wrapped in an array
        (Ben Noordhuis) nodejs/node#9762
    * module:
      - using --debug-brk and --eval together now works as expected
        (Kelvin Jin) nodejs/node#8876
    * process:
      - improve performance of nextTick up to 20% (Evan Lucas)
        nodejs/node#8932
    * repl:
        - the division operator will no longer be accidentally parsed as
          regex (Teddy Katz) nodejs/node#10103
        - improved support for generator functions (Teddy Katz)
          nodejs/node#9852
    * timers:
      - Re canceling a cancelled timers will no longer throw
        (Jeremiah Senkpiel) nodejs/node#9685

    PR-URL: nodejs/node#10394

Signed-off-by: Ilkka Myller <ilkka.myller@nodefield.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
timers Issues and PRs related to the timers subsystem / setImmediate, setInterval, setTimeout.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

segfault if clearTimeout(interval)
6 participants