c8
c8 copied to clipboard
feat: exclude unexpected file in sourcemap result
Checklist
- [x]
npm test
, tests passing - [x]
npm run test:snap
(to update the snapshot) - [x] tests and/or benchmarks are included
Background
Sometimes we need to do coverage on the bundled code file, which contains a lot of useless code, for example node_modules
.
Feature
This PR ensure useless files are remove by this.exclude
.
Such as test case in my PR, which try run c8 bundle.js
, and its output only contains index.js
.
If we do not exclude
, the result will contains index.js
and node_modules/path-exists
:
@bvanjoi if I'm understanding correctly, this specifically addresses the issue of 1:many
source maps, where a single bundled file might expand out into a few files, some of which are excluded?
@bvanjoi if I'm understanding correctly, this specifically addresses the issue of
1:many
source maps, where a single bundled file might expand out into a few files, some of which are excluded?
Yeah, It is. Maybe I need to update snapshot.
Differents node version had differents branch
coverage.
-
<= 12
tag branch coverage is 0. - but
>= 14
tag it is 100.
This is probably due to the coverage file generated by node(left is node 14, and right is node12)
@bvanjoi the culprit is the
between the closing }
and the catch
on line 55
.
> code.slice(1936, 1949)
' catch (err) '
@glromeo I don't suppose any of the work you've been doing in v8-to-istanbul
happens to solve this edge-case? (I don't expect it does, since the problem is mid-line).
@bcoe I checked out @bvanjoi branch and I verified that my https://github.com/istanbuljs/v8-to-istanbul/pull/179 fixes that failing test. Also https://github.com/istanbuljs/v8-to-istanbul/pull/180 fixes that error but for a different reason (in general it goes one character short and picks the previous sourcemapped point if one is absent...which tends to happen for closing brackets)
@bvanjoi could I bother you to update to the latest version of v8-to-istanbul
on your branch, to see if it addresses some of your failing tests.
@bvanjoi could I bother you to update to the latest version of
v8-to-istanbul
on your branch, to see if it addresses some of your failing tests.
I had upgrade v8-to-istanbul
to 8.1.1
, but it still failed in node 12
, succeed in node14
, node16
:
data:image/s3,"s3://crabby-images/b6de4/b6de4cb167df4333a322f021202631ef236cf1ff" alt="image"
@bvanjoi give things a shot with the latest fixes to v8-to-istanbul
?
@bvanjoi give things a shot with the latest fixes to
v8-to-istanbul
?
It still had some problems in node 10
and node 12
😢
data:image/s3,"s3://crabby-images/7ddf9/7ddf9048810e617abc482951ccdec48c2d29e67c" alt="image"
data:image/s3,"s3://crabby-images/34d9e/34d9e83c883923a5505b611f05b0522171a2e7d4" alt="image"
@bvanjoi, it seems like @glromeo's upstream tweaks might be necessary for this PR to work on both Node 12 and Node 10.