This function is very similar to testthat::expect_snapshot_output()
,
but it runs the code in an asciciast subprocess, using record_output()
.
Usage
expect_snapshot_r_process(
...,
interactive = TRUE,
echo = TRUE,
startup = NULL,
transform = NULL,
variant = NULL
)
Arguments
- ...
Code to run (unnamed arguments) and arguments to pass to
record_output()
(named arguments). The code is evaluated in a new asciicast subprocess. Their output is returned and used in a testthat snapshot test.- interactive
Whether to use an interactive R process to evaluate the code.
- echo
Whether to echo the code in the subprocess before running it.
- startup
Expression to evaluate in the subprocess before recording the snapshot. By default it loads and attaches the calling package, including its internal functions.
- transform
Passed to
testthat::expect_snapshot()
.- variant
Passed to
testthat::expect_snapshot()
.
Details
THe Code
part of the snapshot is always the same, but the
Output
part shows the code, assuming echo = TRUE
(the default).
Examples
Sys.getpid()
#> [1] 6825
testthat::local_edition(3)
expect_snapshot_r_process(Sys.getpid())
#> Can't compare snapshot to reference when testing interactively.
#> ℹ Run `devtools::test()` or `testthat::test_file()` to see changes.
#> Current value:
#> Code
#> r_process()
#> Output
#> > Sys.getpid()
#> [1] 7400