Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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

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/