-
Notifications
You must be signed in to change notification settings - Fork 17
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
Comments
What is “mutation testing”? |
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 |
Let's discuss this in a future meeting, seems interesting 👍 |
I've literally never heard of this or seen it used in any codebase in my entire career - it does seem interesting, though. |
We should probably clarify the label meaning? I removed these because |
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 😆 |
It seems awesome, but I'm very unclear on how it could be done in a practical sense for JavaScript. |
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. |
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. |
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. |
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.
The text was updated successfully, but these errors were encountered: