Skip to content

Latest commit

 

History

History
51 lines (37 loc) · 1.8 KB

README.md

File metadata and controls

51 lines (37 loc) · 1.8 KB

JAllele

ci GPL v3

JAllele is a mutation testing tool for Java. By design, all mutants generated are valid and it aspires to avoid equivalent mutants.

Here is the origin for the project's name:

http://en.wikipedia.org/wiki/Allele

Status

Current status of the project is described in bytecode mapping. Currently implemented bytecodes display the corresponding handler.

An initial run will determine a list of all possible mutations. The actual mutation run will choose one of the previously identified mutations to validate that the unit test bed detects that change.

The "strength" of the test bed can be expressed as percentage of the mutation runs failed over the number of mutations runs.

Usage

Currently a command line access is made available. The libraries have to be built, as they are not yet published to a Maven repository.

$ ./gradlew build

Run JUnit sample (packaged into uberjar):

$ java -Djdk.attach.allowAttachSelf=true -jar jallele-cmdline/build/libs/jallele-cmdline-test-*.jar --junit --count 10 \
--sources com.github.gliptak.jallele.SimpleClass --tests com.github.gliptak.jallele.SimpleClassJUnitTest

Run TestNG sample (packaged into uberjar):

$ java -Djdk.attach.allowAttachSelf=true -jar jallele-cmdline/build/libs/jallele-cmdline-test-*.jar --testng --count 10 \
--sources com.github.gliptak.jallele.SimpleClass --tests com.github.gliptak.jallele.SimpleClassTestNGTest

Contributions, issues, pull requests are welcome.

Notes

https://asm.ow2.io/asm4-guide.pdf