Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tonivade/purecheck
Property based testing in Java
https://github.com/tonivade/purecheck
experimental functional-programming java property-based-testing unit-testing
Last synced: 2 months ago
JSON representation
Property based testing in Java
- Host: GitHub
- URL: https://github.com/tonivade/purecheck
- Owner: tonivade
- License: mit
- Created: 2020-08-05T10:12:49.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-10-22T05:51:18.000Z (3 months ago)
- Last Synced: 2024-10-23T08:05:55.525Z (3 months ago)
- Topics: experimental, functional-programming, java, property-based-testing, unit-testing
- Language: Java
- Homepage:
- Size: 843 KB
- Stars: 2
- Watchers: 4
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# purecheck
The idea of this project is try to implement unit testing thinking in tests like pure values,
instead of statements, no annotations, no runtime bytecode manipulation.Pure values have some improvements, for example, it's pretty easy to retry in case of some
flaky tests, or repeat the test, or measure the time the computation it takes.So, a test case can be defined as a function that eventually returns a result, like this:
```scala
type TestCase[E, T] = IO[TestResult[E, T]]
```E is the type of the error generated by the test, and T the value generated by the computation
under test.But in Java there are no type aliases, though we can create a class `TestCase` and wrap the value:
```java
public class TestCase {
private final IO> test;
//...
}
````TestResult` can have 4 different values:
- `Success` when everything is ok,
- `Failure` when the validations fail,
- `Error` when the execution of the computation throws an error,
- `Disabled` when the test is disabled.
This a simple example:
```java
TestSuite suite = suite("NonEmptyString",it.should("not accept null")
.givenNull()
.when(NonEmptyString::of)
.thenThrows(instanceOf(IllegalArgumentException.class)),it.should("not accept empty string")
.given("")
.when(NonEmptyString::of)
.thenThrows(instanceOf(IllegalArgumentException.class)),it.should("contains a non empty string")
.given("hola mundo")
.when(NonEmptyString::of)
.then(equalsTo("hola mundo").compose(NonEmptyString::get)),it.should("map inner value")
.given(NonEmptyString.of("hola mundo"))
.when(hello -> hello.map(String::toUpperCase))
.then(equalsTo("HOLA MUNDO").compose(NonEmptyString::get)),it.should("transform inner value")
.given(NonEmptyString.of("hola mundo"))
.when(hello -> hello.transform(String::toUpperCase))
.then(equalsTo("HOLA MUNDO")),it.should("be equals to other string `hola mundo`")
.given(NonEmptyString.of("hola mundo"))
.noop()
.then(equalsTo(NonEmptyString.of("hola mundo"))),it.should("not be equals to other string different to `hola mundo`")
.given(NonEmptyString.of("hola mundo"))
.noop()
.then(notEqualsTo(NonEmptyString.of("HOLA MUNDO")))
);
```
Then you can run the suite and generate a test report:
```java
TestReport report = suite.run();
```
And the report generated looks like this:
```
NonEmptyString {
- it should 'not accept null' SUCCESS: 'java.lang.IllegalArgumentException: require non null'
- it should 'not accept empty string' SUCCESS: 'java.lang.IllegalArgumentException: require non empty string'
- it should 'contains a non empty string' SUCCESS: 'NonEmptyString(hola mundo)'
- it should 'map inner value' SUCCESS: 'NonEmptyString(HOLA MUNDO)'
- it should 'transform inner value' SUCCESS: 'HOLA MUNDO'
- it should 'be equals to other string `hola mundo`' SUCCESS: 'NonEmptyString(hola mundo)'
- it should 'not be equals to other string different to `hola mundo`' SUCCESS: 'NonEmptyString(hola mundo)'
}
```