diff --git a/README.md b/README.md index 292fee440..c3fe2c37a 100644 --- a/README.md +++ b/README.md @@ -20,7 +20,7 @@ This action currently supports these versions of MRI, JRuby and TruffleRuby: | `truffleruby` | 19.3.0 - 24.0.1, head | | `truffleruby+graalvm` | 21.2.0 - 24.0.1, head | -`ruby-debug` is the same as `ruby-head` but with assertions enabled (`-DRUBY_DEBUG=1`). +`ruby-debug` is the same as `ruby-head` but with assertions enabled (`-DRUBY_DEBUG=1`). Regarding Windows ruby master builds, `mingw` is a MSYS2/MinGW build, `head` & `ucrt` are MSYS2/UCRT64 builds, and `mswin` is a MSVC/VS 2022 build. diff --git a/dist/index.js b/dist/index.js index 482fd22f3..f15c6307f 100644 --- a/dist/index.js +++ b/dist/index.js @@ -65026,7 +65026,17 @@ async function downloadAndExtract(platform, engine, version, rubyPrefix) { const downloadPath = await common.measure('Downloading Ruby', async () => { const url = getDownloadURL(platform, engine, version) console.log(url) - return await tc.downloadTool(url) + try { + return await tc.downloadTool(url) + } catch (error) { + if (error.message.includes('404')) { + throw new Error(`Unavailable version ${version} for ${engine} on ${platform} + You can request it at https://github.com/ruby/setup-ruby/issues + Cause: ${error.message}`) + } else { + throw error + } + } }) await common.measure('Extracting Ruby', async () => { @@ -65636,7 +65646,7 @@ module.exports = JSON.parse('[[[0,44],"disallowed_STD3_valid"],[[45,46],"valid"] /***/ ((module) => { "use strict"; -module.exports = JSON.parse('{"ruby":["1.9.3-p551","2.0.0-p648","2.1.9","2.2.10","2.3.0","2.3.1","2.3.2","2.3.3","2.3.4","2.3.5","2.3.6","2.3.7","2.3.8","2.4.0","2.4.1","2.4.2","2.4.3","2.4.4","2.4.5","2.4.6","2.4.7","2.4.9","2.4.10","2.5.0","2.5.1","2.5.2","2.5.3","2.5.4","2.5.5","2.5.6","2.5.7","2.5.8","2.5.9","2.6.0","2.6.1","2.6.2","2.6.3","2.6.4","2.6.5","2.6.6","2.6.7","2.6.8","2.6.9","2.6.10","2.7.0","2.7.1","2.7.2","2.7.3","2.7.4","2.7.5","2.7.6","2.7.7","2.7.8","3.0.0-preview1","3.0.0-preview2","3.0.0-rc1","3.0.0","3.0.1","3.0.2","3.0.3","3.0.4","3.0.5","3.0.6","3.0.7","3.1.0-preview1","3.1.0","3.1.1","3.1.2","3.1.3","3.1.4","3.1.5","3.2.0-preview1","3.2.0-preview2","3.2.0-preview3","3.2.0-rc1","3.2.0","3.2.1","3.2.2","3.2.3","3.2.4","3.3.0-preview1","3.3.0-preview2","3.3.0-preview3","3.3.0-rc1","3.3.0","3.3.1","3.4.0-preview1","head","debug"],"jruby":["9.1.17.0","9.2.9.0","9.2.10.0","9.2.11.0","9.2.11.1","9.2.12.0","9.2.13.0","9.2.14.0","9.2.15.0","9.2.16.0","9.2.17.0","9.2.18.0","9.2.19.0","9.2.20.0","9.2.20.1","9.2.21.0","9.3.0.0","9.3.1.0","9.3.2.0","9.3.3.0","9.3.4.0","9.3.6.0","9.3.7.0","9.3.8.0","9.3.9.0","9.3.10.0","9.3.11.0","9.3.13.0","9.3.14.0","9.4.0.0","9.4.1.0","9.4.2.0","9.4.3.0","9.4.4.0","9.4.5.0","9.4.6.0","9.4.7.0","head"],"truffleruby":["19.3.0","19.3.1","20.0.0","20.1.0","20.2.0","20.3.0","21.0.0","21.1.0","21.2.0","21.2.0.1","21.3.0","22.0.0.2","22.1.0","22.2.0","22.3.0","22.3.1","23.0.0-preview1","23.0.0","23.1.0","23.1.1","23.1.2","24.0.0","24.0.1","head"],"truffleruby+graalvm":["21.2.0","21.3.0","22.0.0.2","22.1.0","22.2.0","22.3.0","22.3.1","23.0.0-preview1","23.0.0","23.1.0","23.1.1","23.1.2","24.0.0","24.0.1","head"]}'); +module.exports = JSON.parse('{"ruby":["1.9.3-p551","2.0.0-p648","2.1.9","2.2.10","2.3.0","2.3.1","2.3.2","2.3.3","2.3.4","2.3.5","2.3.6","2.3.7","2.3.8","2.4.0","2.4.1","2.4.2","2.4.3","2.4.4","2.4.5","2.4.6","2.4.7","2.4.9","2.4.10","2.5.0","2.5.1","2.5.2","2.5.3","2.5.4","2.5.5","2.5.6","2.5.7","2.5.8","2.5.9","2.6.0","2.6.1","2.6.2","2.6.3","2.6.4","2.6.5","2.6.6","2.6.7","2.6.8","2.6.9","2.6.10","2.7.0","2.7.1","2.7.2","2.7.3","2.7.4","2.7.5","2.7.6","2.7.7","2.7.8","3.0.0-preview1","3.0.0-preview2","3.0.0-rc1","3.0.0","3.0.1","3.0.2","3.0.3","3.0.4","3.0.5","3.0.6","3.0.7","3.1.0-preview1","3.1.0","3.1.1","3.1.2","3.1.3","3.1.4","3.1.5","3.1.6","3.2.0-preview1","3.2.0-preview2","3.2.0-preview3","3.2.0-rc1","3.2.0","3.2.1","3.2.2","3.2.3","3.2.4","3.3.0-preview1","3.3.0-preview2","3.3.0-preview3","3.3.0-rc1","3.3.0","3.3.1","3.3.2","3.4.0-preview1","head","debug"],"jruby":["9.1.17.0","9.2.9.0","9.2.10.0","9.2.11.0","9.2.11.1","9.2.12.0","9.2.13.0","9.2.14.0","9.2.15.0","9.2.16.0","9.2.17.0","9.2.18.0","9.2.19.0","9.2.20.0","9.2.20.1","9.2.21.0","9.3.0.0","9.3.1.0","9.3.2.0","9.3.3.0","9.3.4.0","9.3.6.0","9.3.7.0","9.3.8.0","9.3.9.0","9.3.10.0","9.3.11.0","9.3.13.0","9.3.14.0","9.4.0.0","9.4.1.0","9.4.2.0","9.4.3.0","9.4.4.0","9.4.5.0","9.4.6.0","9.4.7.0","head"],"truffleruby":["19.3.0","19.3.1","20.0.0","20.1.0","20.2.0","20.3.0","21.0.0","21.1.0","21.2.0","21.2.0.1","21.3.0","22.0.0.2","22.1.0","22.2.0","22.3.0","22.3.1","23.0.0-preview1","23.0.0","23.1.0","23.1.1","23.1.2","24.0.0","24.0.1","head"],"truffleruby+graalvm":["21.2.0","21.3.0","22.0.0.2","22.1.0","22.2.0","22.3.0","22.3.1","23.0.0-preview1","23.0.0","23.1.0","23.1.1","23.1.2","24.0.0","24.0.1","head"]}'); /***/ }), @@ -65783,8 +65793,14 @@ async function setupRuby(options = {}) { installer = __nccwpck_require__(9974) } - const engineVersions = installer.getAvailableVersions(platform, engine) - const version = validateRubyEngineAndVersion(platform, engineVersions, engine, parsedVersion) + let version + if (common.isSelfHostedRunner()) { + // The list of available Rubies in the hostedtoolcache is unrelated to getAvailableVersions() + version = parsedVersion + } else { + const engineVersions = installer.getAvailableVersions(platform, engine) + version = validateRubyEngineAndVersion(platform, engineVersions, engine, parsedVersion) + } createGemRC(engine, version) envPreInstall() @@ -65884,11 +65900,19 @@ function validateRubyEngineAndVersion(platform, engineVersions, engine, parsedVe version = found } else { throw new Error(`Unknown version ${parsedVersion} for ${engine} on ${platform} - available versions for ${engine} on ${platform}: ${engineVersions.join(', ')} + Available versions for ${engine} on ${platform}: ${engineVersions.join(', ')} Make sure you use the latest version of the action with - uses: ruby/setup-ruby@v1`) } } + // Well known version-platform combinations which do not work: + if (engine === 'ruby' && platform.startsWith('macos') && os.arch() === 'arm64' && common.floatVersion(version) < 2.6) { + throw new Error(`CRuby < 2.6 does not support macos-arm64. + Either use a newer Ruby version or use a macOS image running on amd64, e.g., macos-13 or macos-12. + Note that GitHub changed the meaning of macos-latest from macos-12 (amd64) to macos-14 (arm64): + https://github.blog/changelog/2024-04-01-macos-14-sonoma-is-generally-available-and-the-latest-macos-runner-image/`) + } + return version } diff --git a/index.js b/index.js index 743616a5c..a3c40ac0c 100644 --- a/index.js +++ b/index.js @@ -58,8 +58,14 @@ export async function setupRuby(options = {}) { installer = require('./ruby-builder') } - const engineVersions = installer.getAvailableVersions(platform, engine) - const version = validateRubyEngineAndVersion(platform, engineVersions, engine, parsedVersion) + let version + if (common.isSelfHostedRunner()) { + // The list of available Rubies in the hostedtoolcache is unrelated to getAvailableVersions() + version = parsedVersion + } else { + const engineVersions = installer.getAvailableVersions(platform, engine) + version = validateRubyEngineAndVersion(platform, engineVersions, engine, parsedVersion) + } createGemRC(engine, version) envPreInstall() @@ -159,11 +165,19 @@ function validateRubyEngineAndVersion(platform, engineVersions, engine, parsedVe version = found } else { throw new Error(`Unknown version ${parsedVersion} for ${engine} on ${platform} - available versions for ${engine} on ${platform}: ${engineVersions.join(', ')} + Available versions for ${engine} on ${platform}: ${engineVersions.join(', ')} Make sure you use the latest version of the action with - uses: ruby/setup-ruby@v1`) } } + // Well known version-platform combinations which do not work: + if (engine === 'ruby' && platform.startsWith('macos') && os.arch() === 'arm64' && common.floatVersion(version) < 2.6) { + throw new Error(`CRuby < 2.6 does not support macos-arm64. + Either use a newer Ruby version or use a macOS image running on amd64, e.g., macos-13 or macos-12. + Note that GitHub changed the meaning of macos-latest from macos-12 (amd64) to macos-14 (arm64): + https://github.blog/changelog/2024-04-01-macos-14-sonoma-is-generally-available-and-the-latest-macos-runner-image/`) + } + return version } diff --git a/ruby-builder-versions.json b/ruby-builder-versions.json index d9b561b52..db722ff1a 100644 --- a/ruby-builder-versions.json +++ b/ruby-builder-versions.json @@ -10,9 +10,9 @@ "2.6.0", "2.6.1", "2.6.2", "2.6.3", "2.6.4", "2.6.5", "2.6.6", "2.6.7", "2.6.8", "2.6.9", "2.6.10", "2.7.0", "2.7.1", "2.7.2", "2.7.3", "2.7.4", "2.7.5", "2.7.6", "2.7.7", "2.7.8", "3.0.0-preview1", "3.0.0-preview2", "3.0.0-rc1", "3.0.0", "3.0.1", "3.0.2", "3.0.3", "3.0.4", "3.0.5", "3.0.6", "3.0.7", - "3.1.0-preview1", "3.1.0", "3.1.1", "3.1.2", "3.1.3", "3.1.4", "3.1.5", + "3.1.0-preview1", "3.1.0", "3.1.1", "3.1.2", "3.1.3", "3.1.4", "3.1.5", "3.1.6", "3.2.0-preview1", "3.2.0-preview2", "3.2.0-preview3", "3.2.0-rc1", "3.2.0", "3.2.1", "3.2.2", "3.2.3", "3.2.4", - "3.3.0-preview1", "3.3.0-preview2", "3.3.0-preview3", "3.3.0-rc1", "3.3.0", "3.3.1", + "3.3.0-preview1", "3.3.0-preview2", "3.3.0-preview3", "3.3.0-rc1", "3.3.0", "3.3.1", "3.3.2", "3.4.0-preview1", "head", "debug" ], diff --git a/ruby-builder.js b/ruby-builder.js index 72e2cfc59..06a81e0ce 100644 --- a/ruby-builder.js +++ b/ruby-builder.js @@ -69,7 +69,17 @@ async function downloadAndExtract(platform, engine, version, rubyPrefix) { const downloadPath = await common.measure('Downloading Ruby', async () => { const url = getDownloadURL(platform, engine, version) console.log(url) - return await tc.downloadTool(url) + try { + return await tc.downloadTool(url) + } catch (error) { + if (error.message.includes('404')) { + throw new Error(`Unavailable version ${version} for ${engine} on ${platform} + You can request it at https://github.com/ruby/setup-ruby/issues + Cause: ${error.message}`) + } else { + throw error + } + } }) await common.measure('Extracting Ruby', async () => {