Chapter 15. Advanced Testing Techniques
This chapter runs a few small bits of testthat code, so we must do some setup that is not necessary in organic testthat usage.
Warning
Your test files should not include these library()
calls. We also
explicitly request testthat edition 3, but in a real package this will
be declared in DESCRIPTION:
library
(
testthat
)
local_edition
(
3
)
Test Fixtures
When it’s not practical to make your test entirely self-sufficient, prefer making the necessary object, logic, or conditions available in a structured, explicit way. There’s a preexisting term for this in software engineering: a test fixture.
A test fixture is something used to consistently test some item, device, or piece of software. — Wikipedia
The main idea is that we need to make it as easy and obvious as possible to arrange the world into a state that is conducive to testing. We describe several specific solutions to this problem:
-
Put repeated code in a constructor-type helper function. Memoise it, if construction is demonstrably slow.
-
If the repeated code has side effects, write a custom
local_*()
function to do what’s needed and clean up afterwards. -
If the preceding approaches are too slow or awkward and the thing you need is fairly stable, save it as a static file and load it.
Create useful_things with a Helper Function
Is it fiddly to create a useful_thing
? Does it take several lines of code but not much time or memory? In that case, write a helper function to create a useful_thing ...
Get R Packages, 2nd Edition now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.