Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/eed3si9n/verify
Scala Verify is a minimal testing framework for Scala. Trust, but verify.
https://github.com/eed3si9n/verify
Last synced: 1 day ago
JSON representation
Scala Verify is a minimal testing framework for Scala. Trust, but verify.
- Host: GitHub
- URL: https://github.com/eed3si9n/verify
- Owner: eed3si9n
- License: apache-2.0
- Created: 2019-07-16T15:58:40.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2024-12-23T17:45:55.000Z (14 days ago)
- Last Synced: 2024-12-29T03:17:49.562Z (8 days ago)
- Language: Scala
- Homepage:
- Size: 1.26 MB
- Stars: 93
- Watchers: 7
- Forks: 21
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Verify
======Verify is a minimalist unit testing framework, tracing its origins to [Minitest](https://github.com/monix/minitest) + [Expecty](https://github.com/eed3si9n/expecty) + [SourceCode](https://github.com/lihaoyi/sourcecode).
It is a small testing framework cross-compiled for Scala 2.11, 2.12, 2.13, Scala 3.x, [Scala.js](http://www.scala-js.org/) 0.6 and 1.0, and
[Scala Native](https://www.scala-native.org/) 0.3.x and 0.4.0.## Usage in sbt
For `build.sbt` (use the `%%%` operator for Scala.js or Scala Native):
```scala
// use the %%% operator for Scala.js or Scala Native
libraryDependencies += "com.eed3si9n.verify" %% "verify" % "1.0.0" % TesttestFrameworks += new TestFramework("verify.runner.Framework")
```## Tutorial
### BasicTestSuite
Test suites MUST BE objects, not classes. To create a test suite without `setup` and `teardown`,
extend [BasicTestSuite](shared/src/main/scala/verify/BasicTestSuite.scala) trait:Here's a simple test:
```scala
import verify._object SomethingTest extends BasicTestSuite {
test("addition") {
assert(2 == 1 + 1)
}test("failing test") {
case class Person(name: String = "Fred", age: Int = 42) {
def say(words: String*) = words.mkString(" ")
}
assert(Person().say("ping", "poing") == "pong pong")
}test("should throw") {
class DummyException extends RuntimeException("DUMMY")
def test(): String = throw new DummyExceptionintercept[DummyException] {
test()
}
}
}
```In the context of `BasicTestSuite`, `assert(...)` function is wired up to power assertion,
as known in Groovy. In the above, the failing test would result to the following:```
- failing test *** FAILED ***
assertion failedassert(Person().say("ping", "poing") == "pong pong")
| | |
| ping poing false
Person(Fred,42)
verify.asserts.PowerAssert$AssertListener.expressionRecorded(PowerAssert.scala:38)
verify.asserts.RecorderRuntime.recordExpression(RecorderRuntime.scala:39)
example.tests.SimpleTest$.$anonfun$new$9(SimpleTest.scala:54)
```### assertions
For the most part, `assert(...)` should do the job.
To compare large strings, scala-verify also provides `assertEquals(expected: String, found: String, message: => String)`.
In case of an error, it will print the diff in color for easier detection of the differences.### setup and tearDown
In case you want to setup an environment for each test example and need `setup` and
`tearDown` semantics, per test example, extend [TestSuite](shared/src/main/scala/verify/TestSuite.scala).
Then on each `test` definition, you'll receive a fresh value:```scala
import verify.TestSuiteobject SomethingTest extends TestSuite[Int] {
def setup(): Int = {
Random.nextInt(100) + 1
}def tearDown(env: Int): Unit = {
assert(env > 0, "should still be positive")
}test("should be positive") { env =>
assert(env > 0, "positive test")
}test("should be lower or equal to 100") { env =>
assert(env <= 100, s"$env > 100")
}
}
```Some tests require setup and tear down logic to happen only once per test suite
being executed and `TestSuite` supports that as well, but note you should abstain
from doing this unless you really need it, since the per test semantics are much
saner:```scala
object SomethingTest extends TestSuite[Int] {
private var system: ActorSystem = _override def setupSuite(): Unit = {
system = ActorSystem.create()
}override def tearDownSuite(): Unit = {
TestKit.shutdownActorSystem(system)
system = null
}
}
```### asynchronous testing
scala-verify supports asynchronous results in tests, use `testAsync` and
return a `Future[Unit]`:```scala
import scala.concurrent.ExecutionContext.Implicits.globalobject SomethingTest extends BasicTestSuite {
testAsync("asynchronous execution") {
val future = Future(100).map(_+1)for (result <- future) yield {
assert(result == 101)
}
}
}
```That's all you need to know.
## Historical background
Verify started out as an attempt to create a cross-platform, zero-dependency, minimal, testing framework for bootstrapping the toolchain and a small handful of foundational third-party libraries.
See https://github.com/scala/scala-dev/issues/641.## License
All code in this repository is licensed under the Apache License, Version 2.0.
See [NOTICE](./NOTICE).