mirror of
https://github.com/zebrajr/node.git
synced 2025-12-06 12:20:27 +01:00
inspector: only write coverage in fully bootstrapped Environments
The NODE_V8_COVERAGE folder and the source map computation are setup during pre-execution since they rely on environment variables as well as JS states. Therefore, we need to give up serialization of JS coverage profiles for Environments that have not go through pre-execution. Currently this is only possible for Environments created using the embedder API CreateEnvironment(). As a result we won't have JS coverage data for most cctests, but if that proves to be necessary we could just run lib/internal/main/environment.js for these Environments created for cctests. Fixes: https://github.com/nodejs/node/issues/32912 Refs:65e18a8e9fRefs:5bf43729a48aa7ef7840PR-URL: https://github.com/nodejs/node/pull/32960 Refs:8aa7ef7840Reviewed-By: Richard Lau <riclau@uk.ibm.com> Reviewed-By: David Carlier <devnexen@gmail.com> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Franziska Hinkelmann <franziska.hinkelmann@gmail.com> Reviewed-By: Anna Henningsen <anna@addaleax.net>
This commit is contained in:
parent
d178250bb6
commit
5dc4349ad3
|
|
@ -209,6 +209,16 @@ void V8CoverageConnection::WriteProfile(Local<String> message) {
|
|||
HandleScope handle_scope(isolate);
|
||||
Context::Scope context_scope(context);
|
||||
|
||||
// This is only set up during pre-execution (when the environment variables
|
||||
// becomes available in the JS land). If it's empty, we don't have coverage
|
||||
// directory path (which is resolved in JS land at the moment) either, so
|
||||
// the best we could to is to just discard the profile and do nothing.
|
||||
// This should only happen in half-baked Environments created using the
|
||||
// embedder API.
|
||||
if (env_->source_map_cache_getter().IsEmpty()) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Get message.result from the response.
|
||||
Local<Object> result;
|
||||
if (!ParseProfile(env_, message, type()).ToLocal(&result)) {
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user