From 4c86a382147a8ae885ec29b874c4dcc6066dafad Mon Sep 17 00:00:00 2001 From: Riccardo Porreca Date: Mon, 15 Jan 2024 10:21:04 +0100 Subject: [PATCH] Install system dependencies using `remotes` from GitHub * We need the development version of remotes to support Ubuntu 22.04 and for querying system requirements for multiple pkgs (r-lib/remotes<>665), which we apply to all packages locked in `renv.lock`. * Note that we deactivate renv to have an renv-free `remotes::system_requirements()`, in particular to get a clean stdout. `r-lib/actions/setup-renv` will reactivate renv. --- .github/workflows/ci-cd-renv.yml | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/.github/workflows/ci-cd-renv.yml b/.github/workflows/ci-cd-renv.yml index bfca2ee..e69d04f 100644 --- a/.github/workflows/ci-cd-renv.yml +++ b/.github/workflows/ci-cd-renv.yml @@ -48,10 +48,17 @@ jobs: - name: Install system dependencies # This is not taken care of (yet) by r-lib/actions/setup-renv - # Package distro used to get the distro for the used ubuntu-latest + # We need the development version of remotes to support Ubuntu 22.04 and + # for querying system requirements for multiple pkgs (r-lib/remotes#665) + # Note: We deactivate renv explicitly (setup-renv below will reactivate) + # We could use pak-based installation for renv, which includes system + # requirements, but would have to handle the pak cache explicitly + # See https://github.com/r-lib/actions/issues/785 run: | - Rscript -e "install.packages(c('remotes', 'distro'))" - SYSTEM_REQUIREMENTS='with(distro::distro(), remotes::system_requirements(id, short_version))' + Rscript -e "if (Sys.getenv('RENV_PROJECT') != '') renv::deactivate()" + Rscript -e "install.packages(c('remotes', 'distro', 'jsonlite'))" + Rscript -e "remotes::install_github('r-lib/remotes')" + SYSTEM_REQUIREMENTS='with(distro::distro(), remotes::system_requirements(id, short_version, package = names(jsonlite::read_json("renv.lock")$Packages)))' while read -r cmd; do echo sudo $cmd && eval sudo $cmd done < <(Rscript -e "writeLines($SYSTEM_REQUIREMENTS)")