Title: | Runs Only Failed Tests |
---|---|
Description: | A companion package to the testthat package that saves development time by helping you rerun only the tests that have failed during the last run. |
Authors: | Kirill Müller [aut, cre] , cynkra GmbH [fnd, cph] |
Maintainer: | Kirill Müller <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.0.0.9072 |
Built: | 2025-01-08 02:41:19 UTC |
Source: | https://github.com/cynkra/lazytest |
A drop-in replacement for testthat::test_local()
that by default reruns
only the tests that failed last time.
lazytest_local( path = ".", reporter = NULL, ..., lazytest_reset = FALSE, stop_on_failure = TRUE, stop_on_warning = FALSE, filter = NULL, load_package = "source" )
lazytest_local( path = ".", reporter = NULL, ..., lazytest_reset = FALSE, stop_on_failure = TRUE, stop_on_warning = FALSE, filter = NULL, load_package = "source" )
path |
Path to directory containing tests. |
reporter |
Reporter to use to summarise output. Can be supplied
as a string (e.g. "summary") or as an R6 object
(e.g. See Reporter for more details and a list of built-in reporters. |
... |
Additional arguments passed to |
lazytest_reset |
Set to |
stop_on_failure |
If |
stop_on_warning |
If |
filter |
Must be |
load_package |
Strategy to use for load package code:
|
A list (invisibly) containing data about the test results,
like testthat::test_local()
.
Let's create a package with two boilerplate tests.
withr::local_seed(42) withr::local_options(usethis.quiet = TRUE) pkg_parent_dir <- withr::local_tempdir() pkg_dir <- file.path(pkg_parent_dir, "tea") usethis::create_package(pkg_dir) usethis::with_project(path = pkg_dir, { usethis::use_testthat() usethis::use_test("blop") usethis::use_test("blip") })
If we run the tests, they all pass.
withr::with_dir( pkg_dir, lazytest::lazytest_local() ) #> i Testing all tests. #> v | F W S OK | Context #> #> / | 0 | blip #> v | 1 | blip #> #> / | 0 | blop #> v | 1 | blop #> #> == Results ===================================================================== #> [ FAIL 0 | WARN 0 | SKIP 0 | PASS 2 ] #> > Testing all tests next time.
Now if we replace one of the tests with a failing test,
brio::write_lines( text = c( 'test_that("blop() works", {', 'expect_equal(2 * 2, 42)', '})' ), path = file.path(pkg_dir, "tests", "testthat", "test-blop.R") )
and then run the tests,
withr::with_dir( pkg_dir, lazytest::lazytest_local() ) #> i Testing all tests. #> v | F W S OK | Context #> #> / | 0 | blip #> v | 1 | blip #> #> / | 0 | blop #> - | 1 0 | blop #> x | 1 0 | blop #> -------------------------------------------------------------------------------- #> Failure ('test-blop.R:2:1'): blop() works #> 2 * 2 (`actual`) not equal to 42 (`expected`). #> #> `actual`: 4 #> `expected`: 42 #> -------------------------------------------------------------------------------- #> #> == Results ===================================================================== #> -- Failed tests ---------------------------------------------------------------- #> Failure ('test-blop.R:2:1'): blop() works #> 2 * 2 (`actual`) not equal to 42 (`expected`). #> #> `actual`: 4 #> `expected`: 42 #> #> [ FAIL 1 | WARN 0 | SKIP 0 | PASS 1 ] #> > Testing the following tests next time: #> * blop #> Error: Test failures
a file is created with the failing test name:
brio::read_lines(file.path(pkg_dir, ".lazytest")) #> [1] "blop"
Next time we run the tests, only this test will be run, until it is fixed at which point all tests are run again to check no failure has been introduced elsewhere.
withr::with_dir( pkg_dir, lazytest::lazytest_local() ) #> i Testing only tests that failed last time: #> * blop #> v | F W S OK | Context #> #> / | 0 | blop #> x | 1 0 | blop #> -------------------------------------------------------------------------------- #> Failure ('test-blop.R:2:1'): blop() works #> 2 * 2 (`actual`) not equal to 42 (`expected`). #> #> `actual`: 4 #> `expected`: 42 #> -------------------------------------------------------------------------------- #> #> == Results ===================================================================== #> -- Failed tests ---------------------------------------------------------------- #> Failure ('test-blop.R:2:1'): blop() works #> 2 * 2 (`actual`) not equal to 42 (`expected`). #> #> `actual`: 4 #> `expected`: 42 #> #> [ FAIL 1 | WARN 0 | SKIP 0 | PASS 0 ] #> > Repeating the same tests next time. #> Error: Test failures