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

Exclude test files from coverage report #53508

Closed
rozzilla opened this issue Jun 19, 2024 · 15 comments · Fixed by #53553
Closed

Exclude test files from coverage report #53508

rozzilla opened this issue Jun 19, 2024 · 15 comments · Fixed by #53553
Labels
coverage Issues and PRs related to native coverage support. feature request Issues that request new features to be added to Node.js. test_runner Issues and PRs related to the test runner subsystem.

Comments

@rozzilla
Copy link

rozzilla commented Jun 19, 2024

What is the problem this feature will solve?

Hey folks! 👋🏼
I know that as by doc it's currently not possible to exclude specific files or directories from the coverage report.

The problem I face right now is that the coverage includes all of the test files.

For instance, if I have the following file:

// index.js
export function sum(val1, val2) {
  return val1 + val2;
}

and the test:

// index.test.js
import { strictEqual } from "node:assert";
import { it, describe } from "node:test";
import { sum } from "./index.js";

describe("test", () => {
  it("should pass", () => {
    strictEqual(sum(40, 2), 42);
  });
});

Once I run node --experimental-test-coverage --test I get:

> [email protected] no
> node --experimental-test-coverage --test

▶ test
  ✔ should pass (0.155709ms)
▶ test (1.117417ms)

ℹ tests 1
ℹ suites 1
ℹ pass 1
ℹ fail 0
ℹ cancelled 0
ℹ skipped 0
ℹ todo 0
ℹ duration_ms 47.674834
ℹ start of coverage report
ℹ --------------------------------------------------------------
ℹ file          | line % | branch % | funcs % | uncovered lines
ℹ --------------------------------------------------------------
ℹ index.js      | 100.00 |   100.00 |  100.00 | 
ℹ index.test.js | 100.00 |   100.00 |  100.00 | 
ℹ --------------------------------------------------------------
ℹ all files     | 100.00 |   100.00 |  100.00 |
ℹ --------------------------------------------------------------
ℹ end of coverage report

What is the feature you are proposing to solve the problem?

Ideally, .test.* should be excluded from the coverage report

What alternatives have you considered?

No response

@rozzilla rozzilla added the feature request Issues that request new features to be added to Node.js. label Jun 19, 2024
@VoltrexKeyva VoltrexKeyva added the test_runner Issues and PRs related to the test runner subsystem. label Jun 19, 2024
@avivkeller
Copy link
Member

avivkeller commented Jun 19, 2024

Seems simple enough. The same logic for --test-skip-pattern can be used.

--coverage-exclude-glob ...
--coverage-include-glob ...

@avivkeller avivkeller assigned avivkeller and unassigned avivkeller Jun 19, 2024
@avivkeller avivkeller added the coverage Issues and PRs related to native coverage support. label Jun 19, 2024
@avivkeller
Copy link
Member

avivkeller commented Jun 19, 2024

I'm happy to work on this :-).

@avivkeller avivkeller self-assigned this Jun 19, 2024
@avivkeller
Copy link
Member

avivkeller commented Jun 22, 2024

Hey! Sorry for the delay, I've been out-of-town, but I'll begin work on this ASAP.

@JakobJingleheimer
Copy link
Member

Thanks @redyetidev! Shouldn't the default behaviour exclude test files themselves from the coverage report? I can't think of a reason anyone would ever want them included.

@cjihrig
Copy link
Contributor

cjihrig commented Oct 27, 2024

Now that we have a way to configure the list of files, I agree that we should exclude the tests from the report. The issue in the past was that people could write tests in their source files.

@avivkeller
Copy link
Member

avivkeller commented Oct 27, 2024

Thanks @redyetidev! Shouldn't the default behaviour exclude test files themselves from the coverage report? I can't think of a reason anyone would ever want them included.

That shouldn't be too difficult. We can use the same list of file patterns to include with --test as ones to exclude for coverage

@avivkeller
Copy link
Member

avivkeller commented Oct 28, 2024

The only "snag" is that glob patterns are used to find test files. Because that feature isn't stable, it'd cause an experimentalWarning ExperimentalWarning: glob is an experimental feature and might change at any time, which users may not want to see when running code coverage (which is also experimental). If we do not care about this, I can go-ahead and submit a PR, or I can find a way to not emit the error when triggered internally from code coverage?

@cjihrig
Copy link
Contributor

cjihrig commented Oct 28, 2024

We already use glob in the test runner. I think you need to avoid the public API to avoid the warning.

@avivkeller
Copy link
Member

avivkeller commented Oct 28, 2024

The matchesGlob API emits a warning, but I can work around it.

I'm just wondering if, speed wise, it's faster to get all the paths matching a glob, and check the path against that array, or check each glob using the matchesGlob API, WDYT?

Oh wait! The test runner will already have done that magic for us, I can reuse data!

@silviuburceadev
Copy link

I'm keeping my lib files in src/main and my tests in src/test. I have my tests written in TS and run them with node --import tsx --test --experimental-test-coverage src/test/**.test.ts and I can see the src/test folder included in the coverage report. I've thought that maybe adding --experimental-strip-types might help the test runner/coverage reporter figure out that I'm on TS, but it isn't working.

Llorx added a commit to Llorx/node that referenced this issue Nov 1, 2024
Is not usual to test the code coverage of test files.

Fixes: nodejs#53508
Llorx added a commit to Llorx/node that referenced this issue Nov 1, 2024
Is not usual to test the code coverage of test files.

Fixes: nodejs#53508
Llorx added a commit to Llorx/node that referenced this issue Nov 1, 2024
Is not usual to test the code coverage of test files.

Fixes: nodejs#53508
@Llorx
Copy link

Llorx commented Nov 1, 2024

@redyetidev Just created a PR with the "default exclude" behaviour: #55633

@pmarchini pmarchini reopened this Nov 1, 2024
@avivkeller
Copy link
Member

@pmarchini IMHO this issue is completed, the PR itself should be the discussion for the other exclusion rules. If you disagree, re-open

@pmarchini
Copy link
Member

@redyetidev, I reopened the issue since there's a related PR that will resolve this. Even though the PR is the right place for the implementation discussion, I think it might be better to keep this issue open until the PR lands.
I've seen many times in the past where PRs get stuck or are no longer under active development, and I found them through the issues.

What do you think?

@avivkeller
Copy link
Member

SGTM, thanks for your insight :-)

@avivkeller avivkeller reopened this Nov 1, 2024
@avivkeller avivkeller removed their assignment Nov 1, 2024
Llorx added a commit to Llorx/node that referenced this issue Nov 2, 2024
Is not usual to test the code coverage of test files.

Fixes: nodejs#53508
Llorx added a commit to Llorx/node that referenced this issue Nov 2, 2024
Is not usual to test the code coverage of test files.

Fixes: nodejs#53508
Llorx added a commit to Llorx/node that referenced this issue Nov 2, 2024
Is not usual to test the code coverage of test files.

Fixes: nodejs#53508
@cjihrig
Copy link
Contributor

cjihrig commented Dec 17, 2024

Fixed by #56060
cc: @pmarchini

@cjihrig cjihrig closed this as completed Dec 17, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
coverage Issues and PRs related to native coverage support. feature request Issues that request new features to be added to Node.js. test_runner Issues and PRs related to the test runner subsystem.
Projects
None yet
8 participants