12 Trouble shoot package builds
12.1 How often is data updated?
- The system checks package Git repositories and the registry for changes every hour.
- If changes are detected:
- The workflow starts building the affected packages.
- Upon completion, the packages are uploaded to R-universe.
- The workflow starts building the affected packages.
12.2 Can the package build process be customized with custom options/tools/variables?
No, customization is not possible, except for addressing third-party system requirements (covered in the next section).
Think of R-universe as your own mini-CRAN. The build environment is very similar to CRAN’s, so if a package builds successfully on CRAN, it is likely to work on R-universe.
This restriction ensures that packages deployed on R-universe are reproducible, work seamlessly on user machines, and do not rely on custom settings or tools.
12.3 What if the Git repository is not a ready-to-build source package?
For repositories requiring additional preparation before building, you can add a script at the root of the package:
- An R script named
bootstrap.R
, or
- A shell script named
.prepare
.
These scripts will be executed before R CMD build
.
Examples of actions performed by the script:
- Initializing a Git submodule.
- Running
roxygen2
(if.Rd
files are not committed to Git).
- Performing other necessary preparations.
12.4 How to request additional third-party system requirements?
If packages need a Linux library that is not available on the server:
- Send a pull request (PR) to the base image for reasonably small or common dependencies.
- Alternatively, send a PR to rstudio/r-system-requirements to resolve the library based on the
SystemRequirements
field in the packageDESCRIPTION
file.
12.5 How to publish vignettes/articles requiring custom software/tokens to render?
Precompute these vignettes locally before publishing.
Follow the guide: How to precompute package vignettes or pkgdown articles.
12.6 Are packages on R-universe required to pass CMD check or meet other criteria?
No, R-universe is an open publishing system. It builds and deploys R packages from Git into personal CRAN-like repositories.
The universe owner is responsible for setting policies and ensuring quality control.
12.7 How to use a universe on regular continous integration?
If you want to test a package against versions of other packages that are in a universe, on GitHub Actions you can use the extra-repositories
field of the r-lib/actions
setup-r action.
12.8 How to know whether tests are run on R-universe?
During the build, the MY_UNIVERSE
environment variable is set to the URL of the universe.