From 058dd4d51ef4a70aef3b913e556b4ab1a150d1c9 Mon Sep 17 00:00:00 2001 From: Benjamin Schwendinger <52290390+ben-schwen@users.noreply.github.com> Date: Sun, 20 Oct 2024 12:06:37 +0200 Subject: [PATCH] simplify GLCI (#6585) * remove hard code rtools * use powershell syntax * add debug * rewrite more powershell * move new variable to script step * persist rtools_home * move Rscript debug * fix typo * remove debug * add comments --- .gitlab-ci.yml | 24 ++++++++++-------------- 1 file changed, 10 insertions(+), 14 deletions(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index ba48ee332..8e1137510 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -13,17 +13,12 @@ variables: TZ: "UTC" ## to avoid 'Failed to create bus connection' from timedatectl via Sys.timezone() on Docker with R 3.4. ## Setting TZ for all GLCI jobs to isolate them from timezone. We could have a new GLCI job to test under ## a non-UTC timezone, although, that's what we do routinely in dev. - R_REL_VERSION: "4.4" + R_REL_VERSION: "4.4" # only raise when RTOOLS for REL is available R_REL_WIN_BIN: "https://cloud.r-project.org/bin/windows/base/old/4.4.1/R-4.4.1-win.exe" - RTOOLS_REL_BIN: "https://cloud.r-project.org/bin/windows/Rtools/rtools44/files/rtools44-6104-6039.exe" - RTOOLS44_HOME: "/c/rtools" # needed for finding gcc #6552 R_DEV_VERSION: "4.5" R_DEV_WIN_BIN: "https://cloud.r-project.org/bin/windows/base/R-devel-win.exe" - RTOOLS_DEV_BIN: "https://cloud.r-project.org/bin/windows/Rtools/rtools44/files/rtools44-6104-6039.exe" # dev uses same rtools as release R_OLD_VERSION: "4.3" R_OLD_WIN_BIN: "https://cloud.r-project.org/bin/windows/base/old/4.3.3/R-4.3.3-win.exe" - RTOOLS_OLD_BIN: "https://cloud.r-project.org/bin/windows/Rtools/rtools43/files/rtools43-5958-5975.exe" - RTOOLS43_HOME: "/c/rtools" # needed for finding gcc #6552 stages: - dependencies @@ -219,9 +214,13 @@ test-lin-ancient-cran: tags: - saas-windows-medium-amd64 before_script: - - curl.exe -s -o ../R-win.exe $R_BIN --fail; if (!(Test-Path -Path ..\R-win.exe)) {Write-Error "R-win.exe not found, download failed?"} + - Invoke-WebRequest -Uri $R_BIN -OutFile ../R-win.exe -ErrorAction Stop; if (!(Test-Path -Path ..\R-win.exe)) {Write-Error "R-win.exe not found, download failed?"} - Start-Process -FilePath ..\R-win.exe -ArgumentList "/VERYSILENT /DIR=C:\R" -NoNewWindow -Wait - - curl.exe -s -o ../rtools.exe $RTOOLS_BIN --fail; if (!(Test-Path -Path ..\rtools.exe)) {Write-Error "rtools.exe not found, download failed?"} + - $VERSION = $RTOOLS_VERSION -replace '\.', '' + # persist RTOOLSXX_HOME="/c/rtools" which is needed for finding gcc #6552 + - Add-Content -Path ".\.Renviron" -Value "RTOOLS${VERSION}_HOME='/c/rtools'" + - $RTOOLS_BIN="https://github.com/r-hub/rtools${VERSION}/releases/download/latest/rtools${VERSION}.exe" + - Invoke-WebRequest -Uri $RTOOLS_BIN -OutFile ../rtools.exe -ErrorAction Stop; if (!(Test-Path -Path ..\rtools.exe)) {Write-Error "rtools.exe not found, download failed?"} - Start-Process -FilePath ..\rtools.exe -ArgumentList "/VERYSILENT /DIR=C:\rtools" -NoNewWindow -Wait - $env:PATH = "C:\R\bin;C:\rtools\usr\bin;$env:PATH" - Rscript.exe -e "source('.ci/ci.R'); install.packages(dcf.dependencies('DESCRIPTION', which='all'), repos=file.path('file://',getwd(),'bus/mirror-packages/cran'), quiet=TRUE)" @@ -244,27 +243,24 @@ test-lin-ancient-cran: test-win-rel: <<: *test-win variables: - R_VERSION: "$R_REL_VERSION" R_BIN: "$R_REL_WIN_BIN" - RTOOLS_BIN: "$RTOOLS_REL_BIN" + RTOOLS_VERSION: "$R_REL_VERSION" ## R-devel on Windows # test and build binaries test-win-dev: <<: *test-win variables: - R_VERSION: "$R_DEV_VERSION" R_BIN: "$R_DEV_WIN_BIN" - RTOOLS_BIN: "$RTOOLS_DEV_BIN" + RTOOLS_VERSION: "$R_REL_VERSION" ## R-oldrel on Windows # test and build binaries test-win-old: <<: *test-win variables: - R_VERSION: "$R_OLD_VERSION" R_BIN: "$R_OLD_WIN_BIN" - RTOOLS_BIN: "$RTOOLS_OLD_BIN" + RTOOLS_VERSION: "$R_OLD_VERSION" .test-mac-template: &test-mac <<: *test