05 Automated module testing

Alex M. Chubaty

April 15 2024

1 Overview

Regular automated checks of your module code help ensure your module can be run by others and that no errors are introduced when you make a change to your code. Users hosting module code in GitHub repositories can take advantage of free GitHub Actions minutes to automatically run their module.

NOTE: Long-running or memory-intensive code should not be run. GitHub actions limits code execution.

Since we encourage all module authors to maintain a high-level overview of their module in a .Rmd file, this can be used to demonstrate use of the module, as as well as test that the module can be run without error. By default, the automated testing of the module is done by running (i.e., rendering) the module’s .Rmd file.

2 Setting up module tests

2.1 Using testing with new modules

When creating a new module, simply specify useGitHub = TRUE to generate the necessary GitHub Actions configuration file.

2.2 Using testing with existing modules

For existing modules, use use_gha(name = 'moduleName', path = 'modulePath') to add the GitHub Actions testing workflow.

3 Customizing the test configuration

You can modify your module’s workflow file (.github/workflows/render-module-rmd.yaml) to suit your specific needs.

3.1 Adding system dependencies

Some packages may require installation of additional system dependencies. The workflow file contains a section named Install GDAL and other dependencies, which can be updated to include additional system packages. To determine which additional packages need to be installed, use remotes::system_requirements. For example, to determine the system dependencies required for the usefulFuns package (from GitHub), get the package code and determine what additional system packages need to be installed.

$ git clone https://github.com/PredictiveEcology/usefulFuns
$ cd usefulFuns
$ Rscript -e 'remotes::system_requirements("ubuntu", "18.04")'
 [1] "apt-get install -y libcurl4-openssl-dev"
 [2] "apt-get install -y libssl-dev"          
 [3] "apt-get install -y imagemagick"         
 [4] "apt-get install -y libmagick++-dev"     
 [5] "apt-get install -y texlive"             
 [6] "apt-get install -y swftools"            
 [7] "apt-get install -y zlib1g-dev"          
 [8] "apt-get install -y make"                
 [9] "apt-get install -y libfreetype6-dev"    
[10] "apt-get install -y libpng-dev"          
[11] "apt-get install -y libicu-dev"          
[12] "apt-get install -y libglpk-dev"         
[13] "apt-get install -y libgmp3-dev"         
[14] "apt-get install -y libxml2-dev"         
[15] "apt-get install -y libgdal-dev"         
[16] "apt-get install -y gdal-bin"            
[17] "apt-get install -y libproj-dev"         
[18] "apt-get install -y libgeos-dev"         
[19] "apt-get install -y libjpeg-dev"         
[20] "apt-get install -y git"                 
[21] "apt-get install -y libudunits2-dev"     
[22] "apt-get install -y pandoc"  

Note that this does not currently capture system dependencies from packages in the Remotes field of the DESCRIPTION file. However, a separate call to those packages will get them.