A handy utility for generating strings that match given regular expression criteria.
Include the following dependency into your project:
testImplementation "com.github.simy4.coregex:coregex-jqwik"
Use the provided Regex
annotation to generate a string that would match the regular expression predicate:
class MyTest {
@Property
void myProperty(@ForAll @Regex("[a-zA-Z]{3}") String str) {
assertThat(str).hasLength(3);
}
}
Include the following dependency into your project:
testImplementation "com.github.simy4.coregex:coregex-junit-quickcheck"
Use the provided Regex
annotation to generate a string that would match the regular expression predicate:
@RunWith(JUnitQuickcheck.class)
public class MyTest {
@Property
public void myProperty(@Regex("[a-zA-Z]{3}") String str) {
assertThat(str).hasLength(3);
}
}
Include the following dependency into your project:
testImplementation "com.github.simy4.coregex:coregex-kotest"
Use the provided CoregexArbirary
class to generate a string that would match the regular expression predicate:
class MyTest : DescribeSpec({
describe("my property") {
it("should hold") {
checkAll(CoregexArbitrary.of("[a-zA-Z]{3}")) { str ->
str.length shouldBe 3
}
}
}
})
Include the following dependency into your project:
libraryDependencies ++= Seq("com.github.simy4.coregex" %% "coregex-scalacheck" % Test)
Use the provided CoregexInstances
trait to constrain string arbitraries:
object MySpecification extends Properties("MySpecification") with CoregexInstances {
property("my property") = forAll { (str: String Matching "[a-zA-Z]{3}") =>
3 == str.length
}
}
Include the following dependency into your project:
testImplementation "com.github.simy4.coregex:coregex-vavr-test"
Use the provided CoregexArbirary
class to generate a string that would match the regular expression predicate:
class MyTest {
@Test
void myProperty() {
Property.def("my property")
.forAll(CoregexArbitrary.of("[a-zA-Z]{3}"))
.suchThat(str -> 3 == str.length())
.check();
}
}