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

Proposal: Introduce Mutation Testing to Enhance Test Coverage #269

Open
IamLizu opened this issue Sep 14, 2024 · 11 comments
Open

Proposal: Introduce Mutation Testing to Enhance Test Coverage #269

IamLizu opened this issue Sep 14, 2024 · 11 comments

Comments

@IamLizu
Copy link
Member

IamLizu commented Sep 14, 2024

I wanted to suggest introducing mutation testing to help strengthen our test suite. It adds another layer of confidence by checking how well our tests catch real issues, not just that they pass. This could help us ensure our tests are more effective in spotting potential bugs.

I'm happy to help explore how we could integrate mutation testing and improve our overall test coverage.

I know the team already has a solid testing strategy in place, so I'd love to hear your thoughts and see if this idea fits with the project's direction.

@IamLizu IamLizu changed the title **Proposal:** Introduce Mutation Testing to Enhance Test Coverage Proposal: Introduce Mutation Testing to Enhance Test Coverage Sep 14, 2024
@ljharb
Copy link
Contributor

ljharb commented Sep 14, 2024

What is “mutation testing”?

@IamLizu
Copy link
Member Author

IamLizu commented Nov 6, 2024

Hi @ljharb 👋

Sure, I'd be happy to explain! Mutation testing is a technique where small changes (mutations) are deliberately introduced to the codebase to test how well our existing test suite catches them. It’s essentially a way to assess whether our tests are effective in identifying potential issues. Somehow, I feel you know that already 😅.

In this context, I was referring to using a tool like Stryker, which mutates source files automatically and helps us find gaps in our test coverage. I noticed we currently don't have any Stryker configuration in the repo, so I was wondering if we are perhaps using another tool or approach for mutation testing?

In the meantime, I tried setting up Stryker myself to see if it could add value. Here's the initial configuration I used:

module.exports = {
  mutate: ["lib/**.js"],
  testRunner: "mocha",
  reporters: ["html", "clear-text"],
  mochaOptions: {
    spec: ["test/**/*.js"],
  },
  coverageAnalysis: "off",
  disableTypeChecks: "/examples/**/**/**.html",
};

While testing, I found that some of our test cases may need a bit of updating—particularly around how fixture paths are referenced in a few places. Currently, the tests pass on their own, but they fail with Stryker due to these path issues.

I didn't take a deeper look yet, but it seems we might need to rewrite a number of test files to address these issues. I wanted to bring it up here first before putting in that effort, just to ensure it aligns with what we want to do moving forward.

I'd be more than happy to help resolve these issues if mutation testing is something we'd like to explore further. Looking forward to your thoughts on this!

cc: @expressjs/express-tc

@UlisesGascon UlisesGascon added meeting top priority Issues which the TC deem our current highest priorities for the project tc agenda labels Nov 6, 2024
@UlisesGascon
Copy link
Member

Let's discuss this in a future meeting, seems interesting 👍

@ljharb
Copy link
Contributor

ljharb commented Nov 6, 2024

I've literally never heard of this or seen it used in any codebase in my entire career - it does seem interesting, though.

@wesleytodd wesleytodd removed top priority Issues which the TC deem our current highest priorities for the project meeting labels Nov 14, 2024
@wesleytodd
Copy link
Member

We should probably clarify the label meaning? I removed these because meeting is the label for meeting agendas and top priority was intended to be the ones we really for sure wanted to do.

@IamLizu
Copy link
Member Author

IamLizu commented Nov 23, 2024

I've literally never heard of this or seen it used in any codebase in my entire career - it does seem interesting, though.

It is comparatively a new thing for sure. I guess we will talk about this in future, but in the meantime here's something you can read which includes references from research papers.

Edit: The practice is new but it has existed for more than 50 years 😆

@ljharb
Copy link
Contributor

ljharb commented Nov 23, 2024

It seems awesome, but I'm very unclear on how it could be done in a practical sense for JavaScript.

@kibertoad
Copy link
Contributor

@ljharb see https://www.npmjs.com/package/@stryker-mutator/core

@wesleytodd
Copy link
Member

This might be the page we should link folks to (in addition to the wiki): https://stryker-mutator.io/docs/

I still dont think any of these are a great explanation. The way I am understanding this proposed approach is that it is applying "chaos engineering" to individual tests.

If that is correct, I can see how it might find gaps we have in the tests. I would suggest you run one of these tools against the project and see what it finds and report back.

@IamLizu
Copy link
Member Author

IamLizu commented Jan 15, 2025

Sure, I have personally configured and used Sktryer in projects.

As you said, I will implement it on one project and reference it back here.

@kjugi
Copy link
Member

kjugi commented Jan 15, 2025

We talked about this issue during our TC meeting. I can try to summarize that conversation. Partially touching the same as @wesleytodd mentioned in his last comment.

We have tried to look into the potential benefits of stryker tool and compare it to the same scenarios discovered locally. There is a feeling that the local approach can deliver potential fixes faster. While with the tool we get a few additional steps.

We have also questioned CI integration as running it on each PR is probably not the best idea. So where and when to run them?

We acknowledge that this type of test might show some fresh bugs. We would like to see a few example scenarios/test cases from our code. Let's try to do it even without preparing this stryker implementation yet.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

6 participants