-
Notifications
You must be signed in to change notification settings - Fork 29.6k
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
Investigate flaky async-hooks/test-statwatcher #21425
Comments
@nodejs/async_hooks @thlorenz |
Again on the same platform: 16:00:10 not ok 12 async-hooks/test-statwatcher
16:00:10 ---
16:00:10 duration_ms: 0.452
16:00:10 severity: fail
16:00:10 exitcode: 1
16:00:10 stack: |-
16:00:10 assert.js:80
16:00:10 throw new AssertionError(obj);
16:00:10 ^
16:00:10
16:00:10 AssertionError [ERR_ASSERTION]: Checking invocations at stage "watcher1: when unwatched second file":
16:00:10 Called "before" 2 time(s), but expected 1 invocation(s).
16:00:10 at checkHook (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:51:14)
16:00:10 at Array.forEach (<anonymous>)
16:00:10 at checkInvocations (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:28:62)
16:00:10 at Immediate.setImmediate (c:\workspace\node-test-binary-windows\test\async-hooks\test-statwatcher.js:65:9)
16:00:10 at runCallback (timers.js:664:18)
16:00:10 at tryOnImmediate (timers.js:635:5)
16:00:10 at processImmediate (timers.js:617:5)
16:00:10 ... @nodejs/testing |
So it seems like this happens only on the |
win2016 yet again... 00:41:05 not ok 12 async-hooks/test-statwatcher
00:41:05 ---
00:41:05 duration_ms: 0.468
00:41:05 severity: fail
00:41:05 exitcode: 1
00:41:05 stack: |-
00:41:05 assert.js:84
00:41:05 throw new AssertionError(obj);
00:41:05 ^
00:41:05
00:41:05 AssertionError [ERR_ASSERTION]: Checking invocations at stage "watcher1: when unwatched second file":
00:41:05 Called "before" 2 time(s), but expected 1 invocation(s).
00:41:05 at checkHook (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:51:14)
00:41:05 at Array.forEach (<anonymous>)
00:41:05 at checkInvocations (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:28:62)
00:41:05 at Immediate.setImmediate (c:\workspace\node-test-binary-windows\test\async-hooks\test-statwatcher.js:65:9)
00:41:05 at runCallback (timers.js:661:18)
00:41:05 at tryOnImmediate (timers.js:632:5)
00:41:05 at processImmediate (timers.js:614:5)
00:41:05 ... @nodejs/platform-windows |
03:44:05 not ok 12 async-hooks/test-statwatcher
03:44:05 ---
03:44:05 duration_ms: 0.473
03:44:05 severity: fail
03:44:05 exitcode: 1
03:44:05 stack: |-
03:44:05 assert.js:84
03:44:05 throw new AssertionError(obj);
03:44:05 ^
03:44:05
03:44:05 AssertionError [ERR_ASSERTION]: Checking invocations at stage "watcher1: when unwatched second file":
03:44:05 Called "before" 2 time(s), but expected 1 invocation(s).
03:44:05 at checkHook (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:51:14)
03:44:05 at Array.forEach (<anonymous>)
03:44:05 at checkInvocations (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:28:62)
03:44:05 at Immediate.setImmediate (c:\workspace\node-test-binary-windows\test\async-hooks\test-statwatcher.js:65:9)
03:44:05 at runCallback (timers.js:661:18)
03:44:05 at tryOnImmediate (timers.js:632:5)
03:44:05 at processImmediate (timers.js:614:5)
03:44:05 ... |
@nodejs/testing |
Looks like it's not windows-only. Refs: nodejs/reliability#12
|
Refs: #21425 PR-URL: #22330 Reviewed-By: Rod Vagg <[email protected]> Reviewed-By: Colin Ihrig <[email protected]> Reviewed-By: Refael Ackermann <[email protected]>
Refs: #21425 PR-URL: #22330 Reviewed-By: Rod Vagg <[email protected]> Reviewed-By: Colin Ihrig <[email protected]> Reviewed-By: Refael Ackermann <[email protected]>
Any ideas of how/where to even start with figuring out what's going on here? 03:43:07 not ok 12 async-hooks/test-statwatcher # TODO : Fix flaky test
03:43:07 ---
03:43:07 duration_ms: 0.464
03:43:07 severity: flaky
03:43:07 exitcode: 1
03:43:07 stack: |-
03:43:07 assert.js:84
03:43:07 throw new AssertionError(obj);
03:43:07 ^
03:43:07
03:43:07 AssertionError [ERR_ASSERTION]: Checking invocations at stage "watcher1: when unwatched second file":
03:43:07 Called "before" 2 time(s), but expected 1 invocation(s).
03:43:07 at checkHook (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:51:14)
03:43:07 at Array.forEach (<anonymous>)
03:43:07 at checkInvocations (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:28:62)
03:43:07 at Immediate.setImmediate (c:\workspace\node-test-binary-windows\test\async-hooks\test-statwatcher.js:65:9)
03:43:07 at runCallback (timers.js:661:18)
03:43:07 at tryOnImmediate (timers.js:632:5)
03:43:07 at processImmediate (timers.js:614:5)
03:43:07 ... |
The |
Refs: #21425 PR-URL: #22330 Reviewed-By: Rod Vagg <[email protected]> Reviewed-By: Colin Ihrig <[email protected]> Reviewed-By: Refael Ackermann <[email protected]>
Failure on 00:57:13 not ok 12 async-hooks/test-statwatcher # TODO : Fix flaky test
00:57:13 ---
00:57:13 duration_ms: 0.479
00:57:13 severity: flaky
00:57:13 exitcode: 1
00:57:13 stack: |-
00:57:13 assert.js:84
00:57:13 throw new AssertionError(obj);
00:57:13 ^
00:57:13
00:57:13 AssertionError [ERR_ASSERTION]: Checking invocations at stage "watcher1: when unwatched second file":
00:57:13 Called "before" 2 time(s), but expected 1 invocation(s).
00:57:13 at checkHook (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:51:14)
00:57:13 at Array.forEach (<anonymous>)
00:57:13 at checkInvocations (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:28:62)
00:57:13 at Immediate.setImmediate (c:\workspace\node-test-binary-windows\test\async-hooks\test-statwatcher.js:65:9)
00:57:13 at runCallback (timers.js:661:18)
00:57:13 at tryOnImmediate (timers.js:632:5)
00:57:13 at processImmediate (timers.js:614:5)
00:57:13 ... |
|
Host: test-azure_msft-win2016-x64-3 00:54:52 not ok 12 async-hooks/test-statwatcher # TODO : Fix flaky test
00:54:52 ---
00:54:52 duration_ms: 0.468
00:54:52 severity: flaky
00:54:52 exitcode: 1
00:54:52 stack: |-
00:54:52 assert.js:86
00:54:52 throw new AssertionError(obj);
00:54:52 ^
00:54:52
00:54:52 AssertionError [ERR_ASSERTION]: Checking invocations at stage "watcher1: when unwatched second file":
00:54:52 Called "before" 2 time(s), but expected 1 invocation(s).
00:54:52 at checkHook (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:51:14)
00:54:52 at Array.forEach (<anonymous>)
00:54:52 at checkInvocations (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:28:62)
00:54:52 at Immediate.setImmediate (c:\workspace\node-test-binary-windows\test\async-hooks\test-statwatcher.js:65:9)
00:54:52 at processImmediate (timers.js:632:19)
00:54:52 ... |
https://ci.nodejs.org/job/node-test-binary-windows/21022/COMPILED_BY=vs2017,RUNNER=win2016,RUN_SUBSET=0/console on test-azure_msft-win2016-x64-3 00:56:47 not ok 12 async-hooks/test-statwatcher # TODO : Fix flaky test
00:56:47 ---
00:56:47 duration_ms: 0.524
00:56:47 severity: flaky
00:56:47 exitcode: 1
00:56:47 stack: |-
00:56:47 assert.js:86
00:56:47 throw new AssertionError(obj);
00:56:47 ^
00:56:47
00:56:47 AssertionError [ERR_ASSERTION]: Checking invocations at stage "watcher1: when unwatched second file":
00:56:47 Called "before" 2 time(s), but expected 1 invocation(s).
00:56:47 at checkHook (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:51:14)
00:56:47 at Array.forEach (<anonymous>)
00:56:47 at checkInvocations (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:28:62)
00:56:47 at Immediate.setImmediate (c:\workspace\node-test-binary-windows\test\async-hooks\test-statwatcher.js:65:9)
00:56:47 at processImmediate (timers.js:632:19)
00:56:47 ... Kind of hoping the timer queue regression fix will fix this but that seems...unlikely... |
https://ci.nodejs.org/job/node-test-binary-windows/21050/COMPILED_BY=vs2017,RUNNER=win2016,RUN_SUBSET=1/console on test-azure_msft-win2016-x64-2 23:53:58 not ok 12 async-hooks/test-statwatcher # TODO : Fix flaky test
23:53:58 ---
23:53:58 duration_ms: 0.463
23:53:58 severity: flaky
23:53:58 exitcode: 1
23:53:58 stack: |-
23:53:58 assert.js:86
23:53:58 throw new AssertionError(obj);
23:53:58 ^
23:53:58
23:53:58 AssertionError [ERR_ASSERTION]: Checking invocations at stage "watcher1: when unwatched second file":
23:53:58 Called "before" 2 time(s), but expected 1 invocation(s).
23:53:58 at checkHook (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:51:14)
23:53:58 at Array.forEach (<anonymous>)
23:53:58 at checkInvocations (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:28:62)
23:53:58 at Immediate.setImmediate (c:\workspace\node-test-binary-windows\test\async-hooks\test-statwatcher.js:65:9)
23:53:58 at processImmediate (timers.js:632:19)
23:53:58 ... |
test-azure_msft-win2016-x64-4 00:52:43 not ok 12 async-hooks/test-statwatcher # TODO : Fix flaky test
00:52:43 ---
00:52:43 duration_ms: 0.478
00:52:43 severity: flaky
00:52:43 exitcode: 1
00:52:43 stack: |-
00:52:43 assert.js:86
00:52:43 throw new AssertionError(obj);
00:52:43 ^
00:52:43
00:52:43 AssertionError [ERR_ASSERTION]: Checking invocations at stage "watcher1: when unwatched second file":
00:52:43 Called "before" 2 time(s), but expected 1 invocation(s).
00:52:43 at checkHook (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:51:14)
00:52:43 at Array.forEach (<anonymous>)
00:52:43 at checkInvocations (c:\workspace\node-test-binary-windows\test\async-hooks\hook-checks.js:28:62)
00:52:43 at Immediate.setImmediate (c:\workspace\node-test-binary-windows\test\async-hooks\test-statwatcher.js:65:9)
00:52:43 at processImmediate (timers.js:632:19)
00:52:43 ... |
It's still flaky. I've seen it fail twice on CI in the last week. |
test-joyent-ubuntu1604_sharedlibs_container-x64-2 20:59:17 not ok 2463 async-hooks/test-statwatcher
20:59:17 ---
20:59:17 duration_ms: 0.463
20:59:17 severity: fail
20:59:17 exitcode: 1
20:59:17 stack: |-
20:59:17 Watcher: w1
20:59:17 current stat data: Stats {
20:59:17 dev: 64784,
20:59:17 mode: 33188,
20:59:17 nlink: 1,
20:59:17 uid: 1001,
20:59:17 gid: 1001,
20:59:17 rdev: 0,
20:59:17 blksize: 4096,
20:59:17 ino: 6826981,
20:59:17 size: 0,
20:59:17 blocks: 8,
20:59:17 atimeMs: 1567915157406.2651,
20:59:17 mtimeMs: 1567915157406.2651,
20:59:17 ctimeMs: 1567915157406.2651,
20:59:17 birthtimeMs: 1567915157406.2651,
20:59:17 atime: 2019-09-08T03:59:17.406Z,
20:59:17 mtime: 2019-09-08T03:59:17.406Z,
20:59:17 ctime: 2019-09-08T03:59:17.406Z,
20:59:17 birthtime: 2019-09-08T03:59:17.406Z
20:59:17 }
20:59:17 previous stat data: Stats {
20:59:17 dev: 64784,
20:59:17 mode: 33188,
20:59:17 nlink: 1,
20:59:17 uid: 1001,
20:59:17 gid: 1001,
20:59:17 rdev: 0,
20:59:17 blksize: 4096,
20:59:17 ino: 6826981,
20:59:17 size: 3,
20:59:17 blocks: 8,
20:59:17 atimeMs: 1567915157406.2651,
20:59:17 mtimeMs: 1567915157406.2651,
20:59:17 ctimeMs: 1567915157406.2651,
20:59:17 birthtimeMs: 1567915157406.2651,
20:59:17 atime: 2019-09-08T03:59:17.406Z,
20:59:17 mtime: 2019-09-08T03:59:17.406Z,
20:59:17 ctime: 2019-09-08T03:59:17.406Z,
20:59:17 birthtime: 2019-09-08T03:59:17.406Z
20:59:17 }
20:59:17 w1 change Stats {
20:59:17 dev: 64784,
20:59:17 mode: 33188,
20:59:17 nlink: 1,
20:59:17 uid: 1001,
20:59:17 gid: 1001,
20:59:17 rdev: 0,
20:59:17 blksize: 4096,
20:59:17 ino: 6826981,
20:59:17 size: 0,
20:59:17 blocks: 8,
20:59:17 atimeMs: 1567915157406.2651,
20:59:17 mtimeMs: 1567915157406.2651,
20:59:17 ctimeMs: 1567915157406.2651,
20:59:17 birthtimeMs: 1567915157406.2651,
20:59:17 atime: 2019-09-08T03:59:17.406Z,
20:59:17 mtime: 2019-09-08T03:59:17.406Z,
20:59:17 ctime: 2019-09-08T03:59:17.406Z,
20:59:17 birthtime: 2019-09-08T03:59:17.406Z
20:59:17 } Stats {
20:59:17 dev: 64784,
20:59:17 mode: 33188,
20:59:17 nlink: 1,
20:59:17 uid: 1001,
20:59:17 gid: 1001,
20:59:17 rdev: 0,
20:59:17 blksize: 4096,
20:59:17 ino: 6826981,
20:59:17 size: 3,
20:59:17 blocks: 8,
20:59:17 atimeMs: 1567915157406.2651,
20:59:17 mtimeMs: 1567915157406.2651,
20:59:17 ctimeMs: 1567915157406.2651,
20:59:17 birthtimeMs: 1567915157406.2651,
20:59:17 atime: 2019-09-08T03:59:17.406Z,
20:59:17 mtime: 2019-09-08T03:59:17.406Z,
20:59:17 ctime: 2019-09-08T03:59:17.406Z,
20:59:17 birthtime: 2019-09-08T03:59:17.406Z
20:59:17 }
20:59:17 Watcher: w1
20:59:17 current stat data: Stats {
20:59:17 dev: 64784,
20:59:17 mode: 33188,
20:59:17 nlink: 1,
20:59:17 uid: 1001,
20:59:17 gid: 1001,
20:59:17 rdev: 0,
20:59:17 blksize: 4096,
20:59:17 ino: 6826981,
20:59:17 size: 5,
20:59:17 blocks: 8,
20:59:17 atimeMs: 1567915157406.2651,
20:59:17 mtimeMs: 1567915157514.2625,
20:59:17 ctimeMs: 1567915157514.2625,
20:59:17 birthtimeMs: 1567915157514.2625,
20:59:17 atime: 2019-09-08T03:59:17.406Z,
20:59:17 mtime: 2019-09-08T03:59:17.514Z,
20:59:17 ctime: 2019-09-08T03:59:17.514Z,
20:59:17 birthtime: 2019-09-08T03:59:17.514Z
20:59:17 }
20:59:17 previous stat data: Stats {
20:59:17 dev: 64784,
20:59:17 mode: 33188,
20:59:17 nlink: 1,
20:59:17 uid: 1001,
20:59:17 gid: 1001,
20:59:17 rdev: 0,
20:59:17 blksize: 4096,
20:59:17 ino: 6826981,
20:59:17 size: 0,
20:59:17 blocks: 8,
20:59:17 atimeMs: 1567915157406.2651,
20:59:17 mtimeMs: 1567915157406.2651,
20:59:17 ctimeMs: 1567915157406.2651,
20:59:17 birthtimeMs: 1567915157406.2651,
20:59:17 atime: 2019-09-08T03:59:17.406Z,
20:59:17 mtime: 2019-09-08T03:59:17.406Z,
20:59:17 ctime: 2019-09-08T03:59:17.406Z,
20:59:17 birthtime: 2019-09-08T03:59:17.406Z
20:59:17 }
20:59:17 Watcher: w2
20:59:17 current stat data: Stats {
20:59:17 dev: 64784,
20:59:17 mode: 33188,
20:59:17 nlink: 1,
20:59:17 uid: 1001,
20:59:17 gid: 1001,
20:59:17 rdev: 0,
20:59:17 blksize: 4096,
20:59:17 ino: 6827007,
20:59:17 size: 5,
20:59:17 blocks: 8,
20:59:17 atimeMs: 1567915157406.2651,
20:59:17 mtimeMs: 1567915157626.2598,
20:59:17 ctimeMs: 1567915157626.2598,
20:59:17 birthtimeMs: 1567915157626.2598,
20:59:17 atime: 2019-09-08T03:59:17.406Z,
20:59:17 mtime: 2019-09-08T03:59:17.626Z,
20:59:17 ctime: 2019-09-08T03:59:17.626Z,
20:59:17 birthtime: 2019-09-08T03:59:17.626Z
20:59:17 }
20:59:17 previous stat data: Stats {
20:59:17 dev: 64784,
20:59:17 mode: 33188,
20:59:17 nlink: 1,
20:59:17 uid: 1001,
20:59:17 gid: 1001,
20:59:17 rdev: 0,
20:59:17 blksize: 4096,
20:59:17 ino: 6827007,
20:59:17 size: 3,
20:59:17 blocks: 8,
20:59:17 atimeMs: 1567915157406.2651,
20:59:17 mtimeMs: 1567915157406.2651,
20:59:17 ctimeMs: 1567915157406.2651,
20:59:17 birthtimeMs: 1567915157406.2651,
20:59:17 atime: 2019-09-08T03:59:17.406Z,
20:59:17 mtime: 2019-09-08T03:59:17.406Z,
20:59:17 ctime: 2019-09-08T03:59:17.406Z,
20:59:17 birthtime: 2019-09-08T03:59:17.406Z
20:59:17 }
20:59:17 w2 change Stats {
20:59:17 dev: 64784,
20:59:17 mode: 33188,
20:59:17 nlink: 1,
20:59:17 uid: 1001,
20:59:17 gid: 1001,
20:59:17 rdev: 0,
20:59:17 blksize: 4096,
20:59:17 ino: 6827007,
20:59:17 size: 5,
20:59:17 blocks: 8,
20:59:17 atimeMs: 1567915157406.2651,
20:59:17 mtimeMs: 1567915157626.2598,
20:59:17 ctimeMs: 1567915157626.2598,
20:59:17 birthtimeMs: 1567915157626.2598,
20:59:17 atime: 2019-09-08T03:59:17.406Z,
20:59:17 mtime: 2019-09-08T03:59:17.626Z,
20:59:17 ctime: 2019-09-08T03:59:17.626Z,
20:59:17 birthtime: 2019-09-08T03:59:17.626Z
20:59:17 } Stats {
20:59:17 dev: 64784,
20:59:17 mode: 33188,
20:59:17 nlink: 1,
20:59:17 uid: 1001,
20:59:17 gid: 1001,
20:59:17 rdev: 0,
20:59:17 blksize: 4096,
20:59:17 ino: 6827007,
20:59:17 size: 3,
20:59:17 blocks: 8,
20:59:17 atimeMs: 1567915157406.2651,
20:59:17 mtimeMs: 1567915157406.2651,
20:59:17 ctimeMs: 1567915157406.2651,
20:59:17 birthtimeMs: 1567915157406.2651,
20:59:17 atime: 2019-09-08T03:59:17.406Z,
20:59:17 mtime: 2019-09-08T03:59:17.406Z,
20:59:17 ctime: 2019-09-08T03:59:17.406Z,
20:59:17 birthtime: 2019-09-08T03:59:17.406Z
20:59:17 }
20:59:17 assert.js:89
20:59:17 throw new AssertionError(obj);
20:59:17 ^
20:59:17
20:59:17 AssertionError [ERR_ASSERTION]: Checking invocations at stage "watcher1: when unwatched second file":
20:59:17 Called "before" 2 time(s), but expected 1 invocation(s).
20:59:17 at checkHook (/home/iojs/build/workspace/node-test-commit-linux-containered/test/async-hooks/hook-checks.js:51:14)
20:59:17 at Array.forEach (<anonymous>)
20:59:17 at checkInvocations (/home/iojs/build/workspace/node-test-commit-linux-containered/test/async-hooks/hook-checks.js:28:62)
20:59:17 at Immediate._onImmediate (/home/iojs/build/workspace/node-test-commit-linux-containered/test/async-hooks/test-statwatcher.js:77:9)
20:59:17 at processImmediate (internal/timers.js:439:21) {
20:59:17 generatedMessage: false,
20:59:17 code: 'ERR_ASSERTION',
20:59:17 actual: 2,
20:59:17 expected: 1,
20:59:17 operator: 'strictEqual'
20:59:17 }
20:59:17 ... |
test-statwatcher does not appear to be failing anymore in CI. Remove "flaky" status for the test. Closes: #21425 PR-URL: #29392 Fixes: #21425 Reviewed-By: Ben Noordhuis <[email protected]> Reviewed-By: Colin Ihrig <[email protected]> Reviewed-By: Michaël Zasso <[email protected]> Reviewed-By: Jiawen Geng <[email protected]> Reviewed-By: Trivikram Kamat <[email protected]> Reviewed-By: Luigi Pinca <[email protected]> Reviewed-By: David Carlier <[email protected]>
seen again today:
|
I've seen this twice in master runs this week. Output
On: https://ci.nodejs.org/computer/test-azure_msft-win2016_vs2017-x64-3/ |
Under high load 2 types of issues arise with this test. * filesystem calls gets queued even when the 'sync' is used which leads to async_hooks being called with the events of tmpdir clean or initial file write after clean. This is solved by counting all 'change' calls while making sure there is no dependency of StatWatcher's on one another and the expected changes are waited for. * some events are getting lost with the current clean->write->write_and_watch strategy. Specifically I observed the file size going from 0 to 5 entirely skipping 3 even though the write call was there (this happened reliably on -j128). So I've changed the strategy to avoid additional write considering this still tests the hooks correctly. This may indicate some sort of bug in async_hooks though I'm not sure. Closes: nodejs#21425
Under high load 2 types of issues arise with this test. * filesystem calls gets queued even when the 'sync' is used which leads to async_hooks being called with the events of tmpdir clean or initial file write after clean. This is solved by counting all 'change' calls while making sure there is no dependency of StatWatcher's on one another and the expected changes are waited for. * some events are getting lost with the current clean->write->write_and_watch strategy. Specifically I observed the file size going from 0 to 5 entirely skipping 3 even though the write call was there (this happened reliably on -j128). So I've changed the strategy to avoid additional write considering this still tests the hooks correctly. This may indicate some sort of bug in async_hooks though I'm not sure. Closes: #21425 PR-URL: #30362 Fixes: #21425 Reviewed-By: Stephen Belanger <[email protected]> Reviewed-By: Rich Trott <[email protected]> Reviewed-By: Richard Lau <[email protected]> Reviewed-By: Vladimir de Turckheim <[email protected]>
Under high load 2 types of issues arise with this test. * filesystem calls gets queued even when the 'sync' is used which leads to async_hooks being called with the events of tmpdir clean or initial file write after clean. This is solved by counting all 'change' calls while making sure there is no dependency of StatWatcher's on one another and the expected changes are waited for. * some events are getting lost with the current clean->write->write_and_watch strategy. Specifically I observed the file size going from 0 to 5 entirely skipping 3 even though the write call was there (this happened reliably on -j128). So I've changed the strategy to avoid additional write considering this still tests the hooks correctly. This may indicate some sort of bug in async_hooks though I'm not sure. Closes: #21425 PR-URL: #30362 Fixes: #21425 Reviewed-By: Stephen Belanger <[email protected]> Reviewed-By: Rich Trott <[email protected]> Reviewed-By: Richard Lau <[email protected]> Reviewed-By: Vladimir de Turckheim <[email protected]>
Under high load 2 types of issues arise with this test. * filesystem calls gets queued even when the 'sync' is used which leads to async_hooks being called with the events of tmpdir clean or initial file write after clean. This is solved by counting all 'change' calls while making sure there is no dependency of StatWatcher's on one another and the expected changes are waited for. * some events are getting lost with the current clean->write->write_and_watch strategy. Specifically I observed the file size going from 0 to 5 entirely skipping 3 even though the write call was there (this happened reliably on -j128). So I've changed the strategy to avoid additional write considering this still tests the hooks correctly. This may indicate some sort of bug in async_hooks though I'm not sure. Closes: #21425 PR-URL: #30362 Fixes: #21425 Reviewed-By: Stephen Belanger <[email protected]> Reviewed-By: Rich Trott <[email protected]> Reviewed-By: Richard Lau <[email protected]> Reviewed-By: Vladimir de Turckheim <[email protected]>
Looks like this is still an issue.
|
This looks like |
@nodejs/async_hooks |
test-azure_msft-win2016_vs2017-x64-4
|
On Windows 2016 under high load further change events can be emitted after writing the 5 bytes is reported. Updating the mtime of the file can be reported as a separate change. This will increase the "before" count, but not the "w1HookCount" since we removed the listener. This makes the test keep the listeners until the end of the test. Fixes: nodejs#21425
On Windows 2016 under high load further change events can be emitted after writing the 5 bytes is reported. Updating the mtime of the file can be reported as a separate change. This will increase the "before" count, but not the "w1HookCount" since we removed the listener. This makes the test keep the listeners until the end of the test. Fixes: #21425 PR-URL: #32484 Reviewed-By: Michaël Zasso <[email protected]> Reviewed-By: James M Snell <[email protected]>
On Windows 2016 under high load further change events can be emitted after writing the 5 bytes is reported. Updating the mtime of the file can be reported as a separate change. This will increase the "before" count, but not the "w1HookCount" since we removed the listener. This makes the test keep the listeners until the end of the test. Fixes: #21425 PR-URL: #32484 Reviewed-By: Michaël Zasso <[email protected]> Reviewed-By: James M Snell <[email protected]>
https://ci.nodejs.org/job/node-test-binary-windows/18119/COMPILED_BY=vs2017,RUNNER=win2016,RUN_SUBSET=0/console
The text was updated successfully, but these errors were encountered: