During the development of another R package I wasted a bit of time figuring out how to add code coverage to my package. I had the same problem last time so I decided to write up the procedure step-by-step.
Provided that you’ve already written an R package, the next step is to create tests. Luckily, devtools package makes setting up both testing and code coverage a breeze.
Let’s start with adding an infrastructure for tests with devtools:
library(devtools)
use_testthat()
Then add a test file of your_function() to your tests folder:
use_test("your_function")
Then add the scaffolding for the code coverage (codecov)
use_coverage(pkg = ".", type = c("codecov"))
After running this code you will get a code that can be added to your README file to display a codecov badge. In my case it’s the following:
[data:image/s3,"s3://crabby-images/01591/0159163db4f1393b5dbebcfd196d64f58bbd171b" alt="Coverage Status"](https://codecov.io/github/erzk/PostcodesioR?branch=master)
This will create a codecov.yml file that needs to be edited by adding:
comment: false
language: R
sudo: false
cache: packages
after_success:
- Rscript -e 'covr::codecov()'
Now log in to codecov.io using the GitHub account. Give codecov access to the project where you want to cover the code. This should create a screen where you can see a token which needs to be copied:
data:image/s3,"s3://crabby-images/45fd5/45fd5df075741c190783e0efe14f1551a2b1a503" alt=""
Once this is completed, go back to R and run the following commands to use covr:
install.packages("covr")
library(covr)
codecov(token = "YOUR_TOKEN_GOES_HERE")
The last line will connect your package to codecov. If the whole process worked, you should be able to see a percentage of coverage in your badge, like this:
data:image/s3,"s3://crabby-images/6834d/6834d87e83fc424af2a0946c7c8e55aaec7a3eb3" alt=""
Click on it to see which functions are not fully covered/need more test:
data:image/s3,"s3://crabby-images/9d14d/9d14d8d7743fac125d839158970dd7a4ae329a63" alt=""
I hope this will be useful and will save a lot of frustrations.