From af45875e8df3485265907b05fe263a4a1a07eeb2 Mon Sep 17 00:00:00 2001 From: MSP-Greg Date: Sat, 7 Jan 2023 16:33:25 -0600 Subject: [PATCH] Add --disable-download-timeout for MSYS2 pacman, fixups, v1.32.4 (#29) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * pacman - add --disable-download-timeout, v1.32.4 Co-authored-by: David Rodríguez * Fix OpenSSL install for Ruby head * Don't install dlfcn package * Fix Actions for Windows Head/OpenSSL, RG for 2.4 & 2.5 --- .github/workflows/ruby.yml | 11 ++++++----- dist/index.js | 8 ++++---- dist/package.json | 2 +- mingw.js | 8 ++++---- mingw_gcc.js | 2 +- package.json | 2 +- 6 files changed, 17 insertions(+), 16 deletions(-) diff --git a/.github/workflows/ruby.yml b/.github/workflows/ruby.yml index 7c7a38b..fcb811d 100644 --- a/.github/workflows/ruby.yml +++ b/.github/workflows/ruby.yml @@ -25,7 +25,7 @@ jobs: runs-on: ${{ matrix.os }} steps: - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v3 - name: Ruby Install uses: ./ @@ -63,6 +63,7 @@ jobs: - name: Ruby Install uses: ./ + timeout-minutes: 10 with: ruby-version: ${{ matrix.ruby }} mingw: _upgrade_ openssl ragel @@ -88,12 +89,12 @@ jobs: - name: update RubyGems for Ruby 2.4 & 2.5 # Included RubyGems doesn't work with required_ruby_version - if: (matrix.ruby >= '2.4') && (matrix.ruby < '2.6') - run: gem update --system --no-document + if: contains('2.4 2.5', matrix.ruby) + run: gem update --system 3.3.14 --no-document timeout-minutes: 5 - name: gem install openssl - if: (matrix.ruby >= '2.4') && (matrix.ruby <= '3.2') + if: ((matrix.ruby >= '2.4') && (matrix.ruby <= '3.2')) || (matrix.ruby == 'head') run: gem install openssl -N plus: @@ -107,7 +108,7 @@ jobs: runs-on: ${{ matrix.os }} steps: - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v3 - name: Ruby Install uses: ./ diff --git a/dist/index.js b/dist/index.js index d1e3aa2..c82bb15 100644 --- a/dist/index.js +++ b/dist/index.js @@ -327,14 +327,13 @@ let msys2Pkgs = getInput('msys2') let pre // package prefix, set in setRuby // standard pacman args -const args = '--noconfirm --noprogressbar --needed' +const args = '--noconfirm --noprogressbar --needed --disable-download-timeout' // Not used. Installs packages stored in GitHub release. // Only needed for exceptional cases. const install = async (pkg, release) => { // eslint-disable-line no-unused-vars const uriBase = 'https://github.com/MSP-Greg/ruby-msys2-package-archive/releases/download' const suff = '-any.pkg.tar.xz' - const args = '--noconfirm --noprogressbar --needed' const uri = `${uriBase}/${release}` @@ -386,7 +385,8 @@ const openssl = async () => { execSync(`pacman.exe -Udd --noconfirm --noprogressbar ${fn}`) grpEnd(msSt) mingwPkgs = mingwPkgs.replace(/\bopenssl\b/gi, '').trim() - } else if (is2022orLater && ruby.abiVers >= '2.5.0 ') + } else if ((is2022orLater && ruby.abiVers >= '2.5.0') || core.getInput('ruby-version') === 'head') + // Ruby 'head' uses a custom OpenSSL 3 package mingwPkgs = mingwPkgs.replace(/\bopenssl\b/gi, '').trim() } @@ -396,7 +396,7 @@ const updateGCC = async () => { msSt = grpSt(`Upgrading gcc for Ruby ${ruby.vers}`) checkSpace - let gccPkgs = ['', 'binutils', 'crt', 'dlfcn', 'headers', 'libiconv', 'isl', 'make', 'mpc', 'mpfr', 'pkgconf', 'windows-default-manifest', 'libwinpthread', 'libyaml', 'winpthreads', 'zlib', 'gcc-libs', 'gcc'] + let gccPkgs = ['', 'binutils', 'crt', 'headers', 'libiconv', 'isl', 'make', 'mpc', 'mpfr', 'pkgconf', 'windows-default-manifest', 'libwinpthread', 'libyaml', 'winpthreads', 'zlib', 'gcc-libs', 'gcc'] execSync(`pacman.exe ${msys2Sync} --nodeps ${args} ${gccPkgs.join(pre)}`) grpEnd(msSt) diff --git a/dist/package.json b/dist/package.json index 68ab6e5..27b4101 100644 --- a/dist/package.json +++ b/dist/package.json @@ -1,6 +1,6 @@ { "name": "setup-ruby-pkgs", - "version": "1.32.3", + "version": "1.32.4", "description": "Install packages and update builds tools for Ruby", "main": "index.js", "scripts": { diff --git a/mingw.js b/mingw.js index 6e35a98..2db9d46 100644 --- a/mingw.js +++ b/mingw.js @@ -33,14 +33,13 @@ let msys2Pkgs = getInput('msys2') let pre // package prefix, set in setRuby // standard pacman args -const args = '--noconfirm --noprogressbar --needed' +const args = '--noconfirm --noprogressbar --needed --disable-download-timeout' // Not used. Installs packages stored in GitHub release. // Only needed for exceptional cases. const install = async (pkg, release) => { // eslint-disable-line no-unused-vars const uriBase = 'https://github.com/MSP-Greg/ruby-msys2-package-archive/releases/download' const suff = '-any.pkg.tar.xz' - const args = '--noconfirm --noprogressbar --needed' const uri = `${uriBase}/${release}` @@ -92,7 +91,8 @@ const openssl = async () => { execSync(`pacman.exe -Udd --noconfirm --noprogressbar ${fn}`) grpEnd(msSt) mingwPkgs = mingwPkgs.replace(/\bopenssl\b/gi, '').trim() - } else if (is2022orLater && ruby.abiVers >= '2.5.0 ') + } else if ((is2022orLater && ruby.abiVers >= '2.5.0') || core.getInput('ruby-version') === 'head') + // Ruby 'head' uses a custom OpenSSL 3 package mingwPkgs = mingwPkgs.replace(/\bopenssl\b/gi, '').trim() } @@ -102,7 +102,7 @@ const updateGCC = async () => { msSt = grpSt(`Upgrading gcc for Ruby ${ruby.vers}`) checkSpace - let gccPkgs = ['', 'binutils', 'crt', 'dlfcn', 'headers', 'libiconv', 'isl', 'make', 'mpc', 'mpfr', 'pkgconf', 'windows-default-manifest', 'libwinpthread', 'libyaml', 'winpthreads', 'zlib', 'gcc-libs', 'gcc'] + let gccPkgs = ['', 'binutils', 'crt', 'headers', 'libiconv', 'isl', 'make', 'mpc', 'mpfr', 'pkgconf', 'windows-default-manifest', 'libwinpthread', 'libyaml', 'winpthreads', 'zlib', 'gcc-libs', 'gcc'] execSync(`pacman.exe ${msys2Sync} --nodeps ${args} ${gccPkgs.join(pre)}`) grpEnd(msSt) diff --git a/mingw_gcc.js b/mingw_gcc.js index eab62f3..1ed84a2 100644 --- a/mingw_gcc.js +++ b/mingw_gcc.js @@ -28,7 +28,7 @@ export const run = async (rubyVers) => { const uriBase = 'https://github.com/MSP-Greg/ruby-msys2-package-archive/releases/download' const pre64 = 'mingw-w64-x86_64-' const suff = '-any.pkg.tar.xz' - const args = '--noconfirm --noprogressbar --needed' + const args = '--noconfirm --noprogressbar --needed --disable-download-timeout' let mingwFiles let uri diff --git a/package.json b/package.json index 68ab6e5..27b4101 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "setup-ruby-pkgs", - "version": "1.32.3", + "version": "1.32.4", "description": "Install packages and update builds tools for Ruby", "main": "index.js", "scripts": {