-
Notifications
You must be signed in to change notification settings - Fork 30.2k
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
v12.1.0 proposal #27440
v12.1.0 proposal #27440
Conversation
Allows instantiating a NodeMainInstance with an isolate whose initialization and disposal are controlled by the caller. PR-URL: #27321 Refs: #17058 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Ben Noordhuis <[email protected]>
This patch allows serializing per-isolate data into an isolate snapshot and deserializing them from an isolate snapthot. PR-URL: #27321 Refs: #17058 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Ben Noordhuis <[email protected]>
Implements a node_mksnapshot target that generates a snapshot blob from a Node.js main instance's isolate, and serializes the data blob with other additional data into a C++ file that can be embedded into the Node.js binary. PR-URL: #27321 Refs: #17058 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Ben Noordhuis <[email protected]>
Enable serializing the isolate from an isolate snapshot generated by node_mksnapshot with per-isolate data. PR-URL: #27321 Refs: #17058 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Ben Noordhuis <[email protected]>
At build time, snapshot the context after running per-context scripts in the main instance, and in the final build, deserialize the context in the main instance. This provides a ~5% in the misc/startup benchmark when the instance is launched within a process that runs test/fixtures/semicolon.js. PR-URL: #27321 Refs: #17058 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Ben Noordhuis <[email protected]>
PR-URL: #27321 Refs: #17058 Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Ben Noordhuis <[email protected]>
Split one very long sentence into three shorter sentences. PR-URL: #27348 Reviewed-By: Vse Mozhet Byt <[email protected]> Reviewed-By: Jeremiah Senkpiel <[email protected]> Reviewed-By: Colin Ihrig <[email protected]> Reviewed-By: Ruben Bridgewater <[email protected]> Reviewed-By: Anatoli Papirovski <[email protected]>
Update tools/license-builder.sh in order to work normally after jinja2 and markupsafe were moved from tools/ to tools/inspector_protocol/ in an earlier commit. Refs: #25614 PR-URL: #27362 Reviewed-By: Michaël Zasso <[email protected]> Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: Richard Lau <[email protected]>
This currently breaks `test/pummel/test-hash-seed.js` PR-URL: #27365 Refs: #27321 Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: Ujjwal Sharma <[email protected]>
PR-URL: #27368 Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: Richard Lau <[email protected]> Reviewed-By: Michaël Zasso <[email protected]>
The internal HTTParser `reinitialize()` function was removed in ece5073 and replaced with an `initialize()` function. This broke benchmark/http/bench-parser.js. This change updates the benchmark so that it runs again. PR-URL: #27359 Reviewed-By: Refael Ackermann <[email protected]> Reviewed-By: Benjamin Gruenbaum <[email protected]>
Add a test for the only uncovered code in lib/internal/dns/promises.js. PR-URL: #27330 Reviewed-By: Yongsheng Zhang <[email protected]> Reviewed-By: Ruben Bridgewater <[email protected]> Reviewed-By: Michael Dawson <[email protected]>
The function 'isConnected' is directly called by many 'Socket' instance, so we shouldn't directly use 'this' because 'this' will be the self of function itself, and we should use 'self' as the instance of 'Socket' function. PR-URL: #27338 Reviewed-By: Santiago Gimeno <[email protected]> Reviewed-By: Joyee Cheung <[email protected]> Reviewed-By: Luigi Pinca <[email protected]> Reviewed-By: Colin Ihrig <[email protected]> Reviewed-By: Franziska Hinkelmann <[email protected]> Reviewed-By: Yongsheng Zhang <[email protected]> Reviewed-By: Benjamin Gruenbaum <[email protected]>
test-worker-esm-missing-main failed in CI recently in a way that suggests that maybe the `does-not-exist.js` file did in fact exist. Maybe that isn't what happened at all, but let's rule it out by changing the use of `does-not-exist.js` from a file expected to be missing from the current working directory to a file in the temp directory, which the test will remove and recreate at the outset. PR-URL: #27340 Reviewed-By: Luigi Pinca <[email protected]> Reviewed-By: Beth Griggs <[email protected]>
Fix tests whether errors are thrown correctly because they are successful when error doesn't get thrown. PR-URL: #27333 Fixes: #26385 Reviewed-By: Ruben Bridgewater <[email protected]> Reviewed-By: Luigi Pinca <[email protected]>
Call `v8::Platform::ShutdownPlatform()` to fix a Coverity warning about the `v8::Platform` instance being deleted when it's still in use. PR-URL: #27332 Reviewed-By: Joyee Cheung <[email protected]> Reviewed-By: Richard Lau <[email protected]> Reviewed-By: Colin Ihrig <[email protected]>
This is a continuing source of confusion, attempt to make it even more clear. Fixes: #24923 PR-URL: #27282 Reviewed-By: Luigi Pinca <[email protected]> Reviewed-By: Vse Mozhet Byt <[email protected]>
PR-URL: #27264 Reviewed-By: Refael Ackermann <[email protected]>
This can be necessary for being able to call the function when no JS Context is on the stack, e.g. during GC. Refs: #27218 PR-URL: #27255 Fixes: #27218 Reviewed-By: Ben Noordhuis <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Michael Dawson <[email protected]>
Allow the function to be called during GC, which is a common use case. Fixes: #27218 PR-URL: #27255 Reviewed-By: Ben Noordhuis <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Michael Dawson <[email protected]>
Allow the destructor to be called during GC, which is a common use case. PR-URL: #27255 Fixes: #27218 Reviewed-By: Ben Noordhuis <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Michael Dawson <[email protected]>
This fixes a pull request number in `repl.md`. PR-URL: #27336 Reviewed-By: Tobias Nießen <[email protected]> Reviewed-By: Vse Mozhet Byt <[email protected]> Reviewed-By: Anna Henningsen <[email protected]> Reviewed-By: Benjamin Gruenbaum <[email protected]> Reviewed-By: Luigi Pinca <[email protected]> Reviewed-By: Yongsheng Zhang <[email protected]>
Instead of using the public AssertionError, use a simplified error that describes potential causes of these assertions and suggests the user to open an issue. PR-URL: #26635 Reviewed-By: Ruben Bridgewater <[email protected]>
Since the bootstrap does not actually use ESM at all, there is no need to create this map so early. This patch moves the initialization of the map to pre-execution, so that the only binding loaded in loaders is native_module. In addition, switch to SafeWeakMap. PR-URL: #27323 Reviewed-By: Gus Caplan <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Ruben Bridgewater <[email protected]>
Only special handle `Symbol.toStringTag` if the property is not enumerable or not the own property of the inspected object. PR-URL: #27342 Reviewed-By: Benjamin Gruenbaum <[email protected]> Reviewed-By: Anna Henningsen <[email protected]>
The function is actually a getter, not a setter. PR-URL: #27342 Reviewed-By: Benjamin Gruenbaum <[email protected]> Reviewed-By: Anna Henningsen <[email protected]>
Let .end() propogate from client, to server, and back, before considering the test complete. Also, remove the test vector and exit handling in favour of running all the tests in parallel and using common.must/mustNotCall(). PR-URL: #27300 Reviewed-By: Luigi Pinca <[email protected]> Reviewed-By: Gireesh Punathil <[email protected]>
Update the version of the bundled ICU (deps/icu-small) to ICU version 64.2 (Unicode 12, CLDR 35) Fixes: #26388 PR-URL: #27361 Reviewed-By: Richard Lau <[email protected]> Reviewed-By: Steven R Loomis <[email protected]> Reviewed-By: Michael Dawson <[email protected]>
Update the LICENSE file and tools/icu/current_ver.dep file in order to finalize the upgrade to ICU 64.2 PR-URL: #27361 Fixes: #26388 Reviewed-By: Richard Lau <[email protected]> Reviewed-By: Steven R Loomis <[email protected]> Reviewed-By: Michael Dawson <[email protected]>
This is the certdata.txt[0] from NSS 3.43, released on 2019-03-15. This is the version of NSS that will ship in Firefox 67 on 2019-03-19. [0] https://hg.mozilla.org/projects/nss/raw-file/NSS_3_43_RTM/lib/ckfw/builtins/certdata.txt PR-URL: #27374 Reviewed-By: Ben Noordhuis <[email protected]> Reviewed-By: Ruben Bridgewater <[email protected]>
RE: 50234460f9 & b44323f3de I see them already there, and they should stay together (Either both in or both out). |
@srl295 It's a crasher but IIUC it affects only ICU 64, which never was in a Node.js release, so I think we can keep it out of the notable changes. |
@refack is https://ci.nodejs.org/job/node-release-candidate ready for production? We should update the release guide if that's the case. |
You tell me... I did the best I could, now it just needs some QA. |
@mcollina is readable-stream expected to fail? The error is:
|
@targos |
@targos i wasn't sure both crashers made it into the proposal, but i see they are there. So all LGTM |
@gireeshpunathil If it doesn't land by noon UTC today, it'll have to wait for the next release. |
sure, I posted a comment in #27373 , let us see if it receives any response. |
Previously, we call the JS land `runNextTicks` implementation immediately from JS land after evaluating the main module or the input, so these synchronous JS call frames would show up in the stack trace of the async errors, which can be confusing. This patch moves those calls into C++ so that more of these internal scheduler implementation details can be hidden and the users can see a cleaner a cleaner async JS stack trace. PR-URL: #27392 Reviewed-By: Ruben Bridgewater <[email protected]> Reviewed-By: Gus Caplan <[email protected]> Reviewed-By: Minwoo Jung <[email protected]> Reviewed-By: Benjamin Gruenbaum <[email protected]>
Notable changes: * intl: * Update ICU to 64.2. This adds support for Japanese Era (Reiwa). #27361 * Fixes a bug in ICU that affected Node.js 12.0.0 in the case where `new Date().toLocaleString()` was called with a non-default locale. #27415 * C++ API: * Added an overload of `EmitAsyncDestroy` that can be used during garbage collection. #27255 PR-URL: #27440
36842d7
to
bf12414
Compare
Release build: https://ci-release.nodejs.org/job/iojs+release/4413/ |
@BridgeAR any idea how that could happen? It did not fail two days ago and I only added d00014e today. |
It passed on rebuild, weird... |
Notable changes: * intl: * Update ICU to 64.2. This adds support for Japanese Era (Reiwa). #27361 * Fixes a bug in ICU that affected Node.js 12.0.0 in the case where `new Date().toLocaleString()` was called with a non-default locale. #27415 * C++ API: * Added an overload of `EmitAsyncDestroy` that can be used during garbage collection. #27255 PR-URL: #27440
2019-04-29, Version 12.1.0 (Current), @targos
Notable changes
new Date().toLocaleString()
was called with a non-default locale (Steven R. Loomis) #27415.Environment
overload ofEmitAsyncDestroy
(Anna Henningsen) #27255.Commits
8ca110cc6f
] - benchmark: fix http bench-parser.js (Rich Trott) #273592f9bafba08
] - bootstrap: delay the instantiation of maps in per-context scripts (Joyee Cheung) #27371e7026f1428
] - build: allow icu download to use other hashes besides md5 (Steven R. Loomis) #2737050234460f9
] - build: disable custom v8 snapshot by default (Joyee Cheung) #27365b21b28f653
] - crypto: update root certificates (Sam Roberts) #273743282ccb845
] - deps: backport ICU-20575 to fix err/crasher (Steven R. Loomis) #27435e922a22725
] - deps: backport ICU-20558 to fix Intl crasher (Steven R. Loomis) #27415d852d9e904
] - deps: update ICU to 64.2 (Ujjwal Sharma) #27361ee80a210ff
] - dgram: change 'this' to 'self' for 'isConnected' (MaleDong) #273388302148c83
] - doc: add Node 12 to the first list of versions (Rivaldo Junior) #27414f6ceefa4bd
] - doc: update comment in bootstrap for primordials (Myles Borins) #273989c30806fb5
] - doc: simplify GOVERNANCE.md text (Rich Trott) #27354453510c7ef
] - doc: fix pull request number (Ruben Bridgewater) #2733636762883a0
] - doc: clarify behaviour of writeFile(fd) (Sam Roberts) #27282f70588fb67
] - doc: fix v12.0.0 changelog id (Beth Griggs) #27368a6d1fa5954
] - doc: simplify Collaborator pre-nomination text (Rich Trott) #27348dd709fc84a
] - lib: throw a special error in internal/assert (Joyee Cheung) #266354dfe54a89a
] - module: initialize module_wrap.callbackMap during pre-execution (Joyee Cheung) #273238b5d73867f
] - (SEMVER-MINOR) n-api: do not require JS Context fornapi\_async\_destroy()
(Anna Henningsen) #27255dc510fb435
] - report: print common items first for readability (gengjiawen) #273673614a00276
] - src: refactor deprecated UVException in node_file.cc (gengjiawen) #27280071300b39d
] - src: move OnMessage to node_errors.cc (Joyee Cheung) #2730481e7b49c8f
] - src: use predefined AliasedBuffer types in the code base (Joyee Cheung) #273348089d29567
] - src: apply clang-tidy modernize-deprecated-headers found by Jenkins CI (gengjiawen) #27279619c5b6eb3
] - (SEMVER-MINOR) src: do not require JS Context for\~AsyncResoure()
(Anna Henningsen) #27255809cf595eb
] - (SEMVER-MINOR) src: addEnvironment
overload ofEmitAsyncDestroy
(Anna Henningsen) #272557bc47cba2e
] - src: apply clang-tidy rule modernize-use-equals-default (gengjiawen) #27264ad42cd69cf
] - src: use std::vector<size_t> instead of IndexArray (Joyee Cheung) #27321228127fc67
] - src: enable context snapshot after running per-context scripts (Joyee Cheung) #2732145d6106129
] - src: enable snapshot with per-isolate data (Joyee Cheung) #27321631bea8fd2
] - src: implement IsolateData serialization and deserialization (Joyee Cheung) #27321a636338945
] - src: allow creating NodeMainInstance that does not own the isolate (Joyee Cheung) #2732150732c1b3f
] - test: refactor net-connect-handle-econnrefused (Luigi Pinca) #27014e9021cc498
] - test: move test-net-connect-handle-econnrefused (Luigi Pinca) #27014ebbed6047d
] - test: rework to remove flakiness, and be parallel (Sam Roberts) #27300f0b2992f5c
] - test: fix ineffective error tests (Masashi Hirano) #27333d84a6d05a1
] - test: make test-worker-esm-missing-main more robust (Rich Trott) #273408486917b9a
] - test: increase coverage in lib/internal/dns/promises.js (Rich Trott) #273306ca0270320
] - tls: include invalid method name in thrown error (Sam Roberts) #27390dcbe5b9dff
] - tools: update certdata.txt (Sam Roberts) #2737453f0ef36c0
] - tools: update LICENSE and tools/icu/current_ver.dep (Ujjwal Sharma) #27361481789c235
] - tools: fix use-after-free mkcodecache warning (Ben Noordhuis) #27332d62a3243b1
] - tools: update tools/license-builder.sh (Ujjwal Sharma) #27362b44323f3de
] - tools: implement node_mksnapshot (Joyee Cheung) #27321ae2333db65
] - util: add prototype support for boxed primitives (Ruben Bridgewater) #273518f3442809a
] - util: rename setIteratorBraces to getIteratorBraces (Ruben Bridgewater) #27342973d705aa9
] - util: improveSymbol.toStringTag
handling (Ruben Bridgewater) #27342