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

feat: add workerIdleMemoryLimit to support worker recycling in the event of node >16.11.0 memory leaks #13056

Merged
merged 51 commits into from
Aug 5, 2022
Merged
Changes from 1 commit
Commits
Show all changes
51 commits
Select commit Hold shift + click to select a range
3e4c26b
feat: process recycling
phawxby Jul 22, 2022
833e429
chore: changelog
phawxby Jul 22, 2022
7da8127
chore: remove temp files
phawxby Jul 22, 2022
40a23cf
test: more complete functional testing
phawxby Jul 25, 2022
1961d65
docs: update docs for PR review
phawxby Jul 25, 2022
d7f292f
chore: try this test config
phawxby Jul 25, 2022
8bfcd74
chore: linting
phawxby Jul 25, 2022
fd1be6f
feat: add improved error checking and promise handling
phawxby Jul 25, 2022
233477e
chore: add facebook header
phawxby Jul 25, 2022
19fb71c
fix: use os spy rather than mock to retain platform functions
phawxby Jul 25, 2022
e2a853d
fix: spying of totalmem
phawxby Jul 25, 2022
ab6554d
chore: add some logging to help debugging
phawxby Jul 25, 2022
207ae05
chore: more debugging
phawxby Jul 25, 2022
c4d2389
chore: more debugging
phawxby Jul 25, 2022
0f5c7bb
chore: check files exist
phawxby Jul 25, 2022
d35e4b9
chore: try as a specific js import
phawxby Jul 25, 2022
daee499
chore: try this
phawxby Jul 26, 2022
fd96e78
chore: remove debugging and cleanup
phawxby Jul 26, 2022
576ca63
chore: debug failing test
phawxby Jul 26, 2022
491b16c
fix: windows tests
phawxby Jul 26, 2022
479c123
chore: use verbose output to help
phawxby Jul 26, 2022
ad238f2
Merge branch 'process-recycling' of https://github.com/phawxby/jest i…
phawxby Jul 26, 2022
e3e63e4
chore: disable silent reporter
phawxby Jul 26, 2022
74ce892
chore: temporary change to allow me to see where the tests are stalling
phawxby Jul 27, 2022
8467b8b
chore: set sensible timeout
phawxby Jul 27, 2022
6338419
chore: there's an argument for what i want to do
phawxby Jul 27, 2022
d2acdc3
chore: try this
phawxby Jul 27, 2022
dea2ef2
chore: remove now I have the test order
phawxby Jul 27, 2022
44ff11d
chore: single thread to track down the failing test suite
phawxby Jul 27, 2022
6b3ba00
chore: does skipping this test make the timeouts go away?
phawxby Jul 27, 2022
f208aa9
fix: fatal but not out of memory errors should retry
phawxby Jul 27, 2022
1ca06bc
fix: out of memory test
phawxby Jul 27, 2022
c98dd32
chore: increase timeout
phawxby Jul 27, 2022
c21b48e
chore: debugging output
phawxby Jul 27, 2022
33405a2
Merge branch 'process-recycling' of https://github.com/phawxby/jest i…
phawxby Jul 27, 2022
98f5e82
chore: limit to just failing test and add logging
phawxby Jul 27, 2022
a1b647f
chore: more debugging
phawxby Jul 27, 2022
54dccb3
feat: add stderr concat
phawxby Jul 27, 2022
0f5da7d
chore: back to full tests
phawxby Jul 27, 2022
debf034
test: fix use simple count in case same pid comes up twice
phawxby Jul 27, 2022
4619055
test: add retry and increase timeout
phawxby Jul 27, 2022
da47b50
test: more retries
phawxby Jul 27, 2022
ba00b26
chore: revert changes to jest config
phawxby Jul 27, 2022
019c5d4
feat: port idle usage to thread workers
phawxby Jul 28, 2022
7239650
chore: docs
phawxby Jul 28, 2022
fdb4a66
chore: linting
phawxby Jul 28, 2022
3e3be99
feat: add shorthand idle limit parsing
phawxby Aug 1, 2022
9f9dff1
docs: copyright header
phawxby Aug 1, 2022
43f1054
chore: improve test flake
phawxby Aug 1, 2022
791b7a5
chore: fix typing
phawxby Aug 2, 2022
f3db1cc
chore: pr feedback
phawxby Aug 4, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fix: out of memory test
  • Loading branch information
phawxby committed Jul 27, 2022
commit 1ca06bc6b6d14cf291d5be600ef26de07dcf67c3
Original file line number Diff line number Diff line change
Expand Up @@ -411,13 +411,38 @@ it('when out of memory occurs the worker is killed and exits', async () => {
expect(onProcessEnd).not.toHaveBeenCalled();
expect(onCustomMessage).not.toHaveBeenCalled();

forkInterface.stderr.emit(
'data',
`<--- Last few GCs --->

[20048:0x7fa356200000] 349 ms: Mark-sweep (reduce) 49.2 (80.6) -> 49.0 (51.6) MB, 6.8 / 0.0 ms (+ 59.5 ms in 35 steps since start of marking, biggest step 2.3 ms, walltime since start of marking 68 ms) (average mu = 0.679, current mu = 0.679) finali[20048:0x7fa356200000] 418 ms: Mark-sweep 50.0 (51.6) -> 49.9 (55.6) MB, 67.8 / 0.0 ms (average mu = 0.512, current mu = 0.004) allocation failure scavenge might not succeed


<--- JS stacktrace --->

FATAL ERROR: Reached heap limit Allocation failed - JavaScript heap out of memory
1: 0x10da153a5 node::Abort() (.cold.1) [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
2: 0x10c6f09b9 node::Abort() [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
3: 0x10c6f0b2f node::OnFatalError(char const*, char const*) [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
4: 0x10c86ff37 v8::Utils::ReportOOMFailure(v8::internal::Isolate*, char const*, bool) [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
5: 0x10c86fed3 v8::internal::V8::FatalProcessOutOfMemory(v8::internal::Isolate*, char const*, bool) [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
6: 0x10ca2eed5 v8::internal::Heap::FatalProcessOutOfMemory(char const*) [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
7: 0x10ca2d8f6 v8::internal::Heap::CollectGarbage(v8::internal::AllocationSpace, v8::internal::GarbageCollectionReason, v8::GCCallbackFlags) [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
8: 0x10ca39e30 v8::internal::Heap::AllocateRawWithLightRetrySlowPath(int, v8::internal::AllocationType, v8::internal::AllocationOrigin, v8::internal::AllocationAlignment) [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
9: 0x10ca39eb1 v8::internal::Heap::AllocateRawWithRetryOrFailSlowPath(int, v8::internal::AllocationType, v8::internal::AllocationOrigin, v8::internal::AllocationAlignment) [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
10: 0x10ca070d7 v8::internal::Factory::NewFillerObject(int, bool, v8::internal::AllocationType, v8::internal::AllocationOrigin) [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
11: 0x10cdb896e v8::internal::Runtime_AllocateInYoungGeneration(int, unsigned long*, v8::internal::Isolate*) [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
12: 0x10d157ed9 Builtins_CEntry_Return1_DontSaveFPRegs_ArgvOnStack_NoBuiltinExit [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
13: 0x10d158e0f Builtins_StringAdd_CheckNone [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]
14: 0x10d1b5740 Builtins_StringRepeat [/Users/paul/.nvm/versions/node/v16.10.0/bin/node]`,
);
forkInterface.emit('exit', null, 'SIGABRT');

// We don't want it to try and restart.
expect(childProcess.fork).toHaveBeenCalledTimes(1);
expect(onProcessEnd).toHaveBeenCalledTimes(1);
expect(onProcessEnd).toHaveBeenCalledWith(
new Error('Process exited unexpectedly: SIGABRT'),
new Error('Jest worker ran out of memory and crashed'),
null,
);

Expand Down