Unit test code, just like any other source code, is subject to bad programming practices, known also as anti-patterns, defects and smells. Smells, being symptoms of bad design or implementation decisions, has been proven to be responsible for decreasing the quality of software systems from various aspects, such as making it harder to understand, more complex to maintain, more prone to errors and bugs.
Test smells are defined as bad programming practices in unit test code (such as how test cases are organized, implemented and interact with each other) that indicate potential design problems in the test source code.
The purpose of this project is twofold:
- Contribute to the list of existing test smells, by proposing new test smells that developers need to be aware of.
- Provide developers with a tool to automatically detect test smell in their unit test code.
Visit the project website: https://testsmells.github.io/
Running the jar with --help
will print its usage.
- A CSV input file always need to be given as parameter, specified with
-f
; - A detection threshold can also be specified. Possible values are
default
andspadini
. The flag is-t
. By default, the tool uses the thresholds that have been originally implemented; withspadini
, sensibility thresholds published by Spadini et.al. will be used. - One can specify the granularity of the detection.
boolean
will return either true or false, respectively if a given smell is present or not in the test;numerical
will return instead the number of smelly instances detected.
Options:
-f, --file PATH The csv input file
-t, --thresholds [default|spadini]
The threshold to use for the detection
-g, --granularity [boolean|numerical]
Boolean value of numerical for the
detection
-o, --output TEXT
-h, --help Show this message and exit