-
Notifications
You must be signed in to change notification settings - Fork 30.3k
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
Proposal: provide a straight-forward approach for collecting coverage via Chrome's Profiler #16531
Comments
Just so we're on the same page: these would be flags added in V8, and AFAIK no action is necessary by Node itself. cc @hashseed |
@schuay gotcha, we could just configure them using I might keep this ticket open for a bit, and rework it a bit today, so that it instead better tracks some of the other challenges making it difficult to use v8's coverage instrumenter for an arbitrary Node.js process. |
an update: issue #715 has been created on the v8 project, proposing introducing startup & teardown events to the inspector. The idea being that:
@eugeneo, @TimothyGu, @jasnell, @Trott, having done a significant amount of work on the inspector; any thoughts about how these hooks would be integrated into Node.js' inspector lifecycle? could we figure out an elegant way to provide a closure that executes when the inspector has finished processing a given script in v8? |
I prefer solution without flags to make possible coverage and type profiling of web page and Node.js instances using the same protocol.
It definitely won't work as is and we need to tune it a little but it should be fixable. |
@ak239 amazing \o/ thanks for the work you're undertaking on v8's end to help implement this feature. I'm excited to start moving towards built-in coverage, it will help dismantle the Rube-Goldberg machine that currently facilitates most people's JavaScript test-coverage. Please feel free to loop me into patches on the v8 side of things (I would love to be a fly on the wall 😛). As discussed in puppeteer/puppeteer#1054, one feature request that I think the community has become accustomed to and will immediately request is branch-level coverage -- would this potentially be something we could move towards eventually in v8 (CC: @schuay, @mikeal). |
@ak239 sounds great, let's work out the details to be able to enable coverage before any scripts are parsed!
Can you clarify what you mean by branch-level coverage? AFAIK the linked issue discusses providing coverage information for 'a || b' constructs, which in my mind are still block coverage (i.e. a counter for each block, whatever the definition of 'block' is) and not branch coverage (a counter for each branch). We can definitely extend support to 'a || b' constructs. But since our implementation is based on block counters, branch coverage support is less likely. |
I've been doing some testing with Node.js on canary versions of v8, with a few caveats that I will discuss in other tickets, the approach outlined by @ak239 works like a charm. |
The Problem
I've been having an ongoing discussion with @bmeck and a few folks working on the V8 project (@schuay, @fhinkel) about how to move istanbul towards using v8's built-in coverage.
The biggest blocker, tracked in the v8 issue tracker here, is that we need a way to start Node with detailed coverage enabled. -- @schuay can speak better to the specifics, but as I understand it code needs to be put through a preprocessing step that introduces counters, currently we're only able to collect function-level coverage.
There are a few other blockers that I will also outline in this issue.
Collecting Detailed Coverage
--inspector
or could we still enable this post-hoc?Other Challenges
There are a few other technical challenges that will need to be addressed, to make the switch over to v8's test coverage:
process.exit
or by throwing an exception, it's hard to capture this event and output the coverage information (since talking to the inspector's socket is asynchronous); One option might be usingspawnSync
withinprocess.exit()
, but this currently has bugs.Why this is super cool
.mjs
module files, which is currently not possible since the new module system does not executerequire.extensions
.The text was updated successfully, but these errors were encountered: