Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rcmartins/blinky
Semantic mutation testing for Scala
https://github.com/rcmartins/blinky
mutation-testing scala testing-tools
Last synced: about 1 month ago
JSON representation
Semantic mutation testing for Scala
- Host: GitHub
- URL: https://github.com/rcmartins/blinky
- Owner: RCMartins
- License: apache-2.0
- Created: 2019-05-12T21:46:53.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2024-08-15T18:19:20.000Z (5 months ago)
- Last Synced: 2024-12-06T04:10:39.874Z (about 1 month ago)
- Topics: mutation-testing, scala, testing-tools
- Language: Scala
- Homepage: https://rcmartins.github.io/blinky/
- Size: 859 KB
- Stars: 3
- Watchers: 4
- Forks: 2
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Blinky
[![Build Status][badge-github-actions]][link-github-actions]
[![Coverage Status][badge-codecov]][link-codecov]
[![Sonatype Nexus (Releases)][badge-release]][link-release]
[![Sonatype Nexus (Snapshots)][badge-snapshot]][link-snapshot]
[![Scala Steward Badge][badge-scalasteward]][link-scalasteward]Mutation testing is a type of software testing where we mutate (change) certain expressions in the source code
and check if the test cases are able to find the errors.
It is a type of White Box Testing which is mainly used for Unit Testing._Blinky_ has 3 main steps:
* Copy the git project to a temporary folder (where the source code can be safely modified)
* Run the scalafix tool with the _Blinky_ rule (on the copy project)
* Run the project tests on the mutated code (usually with only 1 mutant active each time)We use _Blinky_ to test this repository, improving the test code quality.
Similar projects:
* [scalamu](https://github.com/sugakandrey/scalamu)
* [stryker4s](https://github.com/stryker-mutator/stryker4s)The main difference is that in _Blinky_ the mutations are semantic instead of just syntactic.
Meaning when using a rule like `ScalaOptions.filter` we only mutate calls to
the method `filter` of objects of type `scala.Option`.
In order to have this semantic information about the types _Blinky_
needs the [semanticdb](https://scalameta.org/docs/semanticdb/guide.html)
data of all files that we want to mutate.### [User documentation][docs]
Head over to [the user docs][docs] for instructions on how to install blinky.[badge-github-actions]: https://github.com/RCMartins/blinky/actions/workflows/ci.yml/badge.svg?branch=main "build"
[badge-codecov]: https://codecov.io/gh/RCMartins/blinky/branch/main/graph/badge.svg?token=o3yIhzL932 "covecov"
[badge-release]: https://img.shields.io/nexus/r/com.github.rcmartins/blinky_2.13?server=https%3A%2F%2Foss.sonatype.org%2F "release"
[badge-snapshot]: https://img.shields.io/nexus/s/com.github.rcmartins/blinky-cli_2.13?server=https%3A%2F%2Foss.sonatype.org "snapshot"
[badge-scalasteward]: https://img.shields.io/badge/Scala_Steward-helping-blue.svg?style=flat&logo= "scala steward"[link-github-actions]: https://github.com/RCMartins/blinky/actions "build"
[link-codecov]: https://codecov.io/gh/RCMartins/blinky "covecov"
[link-release]: https://mvnrepository.com/artifact/com.github.rcmartins/blinky-cli_2.13 "release"
[link-snapshot]: https://oss.sonatype.org/content/repositories/snapshots/com/github/rcmartins/blinky-cli_2.13/ "snapshot"
[link-scalasteward]: https://scala-steward.org "scala steward"[docs]: https://rcmartins.github.io/blinky/