3 Running the testthat Tests

3.1 Requirements

  • The testthat package.

From the R command line, run install.packages('testthat').

3.2 tl;dr

To run all testthat tests, move to the tests directory within the BioCro source code directory tree and run

Rscript testthat.R

Warning: This assumes the BioCro package has been installed. It will run all tests in the tests/testthat directory against this installed version. If you want the tests to reflect changes to your source code, reinstall BioCro before running them, or use one of the alternative test-running methods outlined below.

3.3 tl;dr for devtools users

If you use the devtools package, you can run all tests by doing the following command in any directory in the BioCro source tree:

Rscript -e "devtools::test()"

This will test against the source code; it does not expect BioCro to be installed. Note that this source code test will compile or recompile the C++ code if necessary. See the source-code testing section (Section 3.5.3) for details.

3.4 Continuous integration workflow; why run tests manually?

BioCro’s testthat test suite is automatically run on GitHub as part of the R-CMD-check workflow every time a BioCro developer makes or modifies a pull request. Users also have the option to run this workflow manually by clicking a button on the GitHub page for R-CMD-check workflow runs. All R-CMD-check workflow run results are viewable here as well.

There are (at least) two scenarios, however, under which you may want to run tests manually:

  1. You have revised the package’s R code, stored data, or C++ code, and you want to run the testthat test suite against the changed code on your own machine before pushing that code to GitHub.

  2. You are writing new tests, and you want to ensure that they work as expected.

Read on for further information about various topics, including

  • testing package source versus testing an installed package
  • better test reporting options
  • running individual test files

3.5 Test-running scenarios

There are two main ways to run the BioCro testthat tests:

  • Run tests in the tests/testthat directory of a BioCro source tree against an installed version of BioCro

  • Run tests in the tests/testthat directory of a BioCro source tree against the code in that source tree

(A third scenario exists: running installed testthat tests against the installed package. But currently the BioCro package does not install any of its tests.)

3.5.1 Running the test suite on the installed version of BioCro

As explained in the tl;dr section above (Section 3.3), the easiest way to run the tests against an installed version of the BioCro package is to move to the tests directory within the BioCro source code directory tree and run

Rscript testthat.R

Alternatively, the tests may be run inside an R session as follows:

  1. Start an R session (if you don’t have one open already).

  2. Run xfun::in_dir('<path to tests directory>', source('testthat.R')), where <path to tests directory> is the path to the tests directory of a BioCro source tree.

    OR

    Use setwd to move to the tests directory (if you aren’t there already) and just run source('testthat.R').

Either of these methods will run the testthat tests in the same way that R CMD check would run them. (But R CMD check builds BioCro immediately before running the tests, ensuring that you are running the tests against a version of the BioCro package corresponding to the BioCro code in your source tree.)

3.5.2 Switching reporters

The default output of the test method used by testthat.R can be exceedingly terse, and so it is highly desirable to tweak the test output of that method for interactive use. This is done by overriding the default reporter of the testing function using the reporter argument.

A particularly useful and informative reporter is the Summary reporter. To use it, run the following commands in an R session:

library(BioCro)
library(testthat)
xfun::in_dir('<path to tests directory>',
             test_check('BioCro', reporter = 'Summary'))

(If you are in the tests directory, the third line can be simply

test_check('BioCro', reporter = 'Summary')

And if you have already loaded the BioCro and testthat packages (either directly or by sourcing testthat.R), there is no need to reload them!)

The Summary reporter is useful in two ways: It clearly indicates testing progress by printing a character to the screen each time a test completes (“.” for success, “S” for a skipped test, “W” for a warning, and an (error) number for a failed test). And it prints the file name of each test file before printing that file’s context message.

Setting reporter to ‘Progress’ yields slightly less verbose output. Crucially and inconveniently, it doesn’t print the names of the test files being run, although it does print their context messages. On the other hand, it gives a better numerical summary of the test results—how many tests passed, how many failed, and how many were skipped.11

3.5.3 Running the test suite against the BioCro source code

If you are making changes to the R code or to the C++ code (or even to the package data) and you want to test your changes to the source code without installing (or re-installing) the BioCro package, the function to use is test_local.12

The steps are similar to the steps above for running test_check:

  1. Start an R session.

  2. Load the testthat library: library(testthat). (Note that we don’t need to load the BioCro library, and there needn’t even be a copy of it installed!)

  3. Run test_local('<path to the tests directory of some BioCro source tree>')

If you are actually in the tests directory—either because you started R there or because you moved there with setwd—you can just run test_local(), because the path defaults to '.'.

Note that this function expects to find an up-to-date copy of the BioCro C++ library file (BioCro.so, or BioCro.dll on Windows) in the src directory. If it doesn’t find it (or if it is out of date with respect to the C++ source files), it will try to re-create it. (This will happen even if none of the tests use any of the package code.) So be patient if the function seems to hang for several minutes while it does this!

The default reporter for test_local is the Progress reporter, but if you prefer the Summary reporter, which gives better progress indication and prints the name of each test file it runs, you can switch:

test_local('<path to the tests directory of some BioCro source tree>',
           reporter = 'Summary')`

3.6 Running individual test files

While writing new tests, it is useful to be able to run a single test file rather than the whole test suite. The test may be run either against the installed version of the BioCro package, or against the source code.

3.6.1 Running an individual test file on the installed package

Method 1

  1. Start an R session.

  2. Load the BioCro and testthat packages:

    library(BioCro)
    library(testthat)
  3. Call the test_file function on the path to a test file:

    test_file('<path to test file to run>')

Note the path passed to test_file can be either a relative or an absolute path. It doesn’t matter what directory the R session was started in or what the current R directory is as long as the path is correct. Making the testthat directory the current directory, however, will make for shorter path names.

Once again, the default reporter (“CompactProgress”, in this case) may be overridden:

test_file('<path to test file to run>', reporter = 'Summary')

See the documentation for testthat::Reporter for a list of reporters.

Method 2

This uses the test_check function we used earlier (see Section 3.5.2), but with a “filter” option.

  1. Start an R session.

  2. Load the BioCro and testthat packages:

    library(BioCro)
    library(testthat)
  3. Call the test_check function with a filter option to select the desired test file. The filter pattern should be a regular expression matching the main part of the test file. For example, to run the tests in test.HarmonicOscillationModeling.R, we could setwd to the tests directory and call test_check as follows:

    test_check('BioCro', filter = 'Harm')

The filter matching is performed on file names after they are stripped of “test-” and “.R”.

Again, a reporter option may be specified. For example,

test_check('BioCro', filter = 'Harm', reporter = 'Summary')

Note that step 3 assumes you are in the BioCro tests directory when test_check is called. If you aren’t, either usesetwd get there first, or use the xfun::in_dir wrapper:

xfun::in_dir('<path to tests directory>',
             test_check('BioCro', filter = 'Harm'))

3.6.2 Running an individual test file against the package source code

Again, the test_local function is used. The method is exactly the same as specified above in section 3.5.3 except that a filter option is used to limit testing to matching files (see Method 2 in the previous section).

3.7 Using devtools

If you don’t mind installing and using the devtools package, it provides a particularly easy way to run tests against the package source code: simply issue the following command in any directory in the BioCro source tree:

Rscript -e "devtools::test()"

Again, the filter option may be used with this function to limit the tests run, and the default reporter may be overridden with the reporter option.


  1. The names “Progress” and “Summary” almost seem to me as if they have been reversed! After all, it is the Summary reporter which most clearly indicates how the testing is progressing and the Progress reporter that gives the best numerical summary of how many tests failed.↩︎

  2. Or you can use devtools::test(). See tl;dr for devtools users and Using devtools.↩︎