mirror of
https://github.com/actions/setup-node.git
synced 2025-10-24 14:06:43 +08:00
Fix node version file parsing (#553)
* Fix node version file parsing * Build index.js * Non-json file error handling * Format code * Add package.json to e2e tests * Minor fix
This commit is contained in:
parent
2a814b57e1
commit
348e008008
2
.github/workflows/versions.yml
vendored
2
.github/workflows/versions.yml
vendored
@ -92,7 +92,7 @@ jobs:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
os: [ubuntu-latest, windows-latest, macos-latest]
|
||||
node-version-file: [.nvmrc, .tool-versions]
|
||||
node-version-file: [.nvmrc, .tool-versions, package.json]
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- name: Setup node from node version file
|
||||
|
@ -1,5 +1,5 @@
|
||||
{
|
||||
"engines": {
|
||||
"node": ">=14.0.0"
|
||||
"node": "^14.0.0"
|
||||
}
|
||||
}
|
||||
|
15
dist/setup/index.js
vendored
15
dist/setup/index.js
vendored
@ -71770,13 +71770,18 @@ function translateArchToDistUrl(arch) {
|
||||
function parseNodeVersionFile(contents) {
|
||||
var _a, _b;
|
||||
let nodeVersion;
|
||||
const found = contents.match(/^(?:nodejs\s+)?v?(?<version>[^\s]+)$/m);
|
||||
nodeVersion = (_a = found === null || found === void 0 ? void 0 : found.groups) === null || _a === void 0 ? void 0 : _a.version;
|
||||
if (!nodeVersion) {
|
||||
try {
|
||||
// Try parsing the file as an NPM `package.json`
|
||||
// file.
|
||||
nodeVersion = (_b = JSON.parse(contents).engines) === null || _b === void 0 ? void 0 : _b.node;
|
||||
try {
|
||||
nodeVersion = (_a = JSON.parse(contents).engines) === null || _a === void 0 ? void 0 : _a.node;
|
||||
}
|
||||
catch (_c) {
|
||||
core.warning('Node version file is not JSON file');
|
||||
}
|
||||
if (!nodeVersion) {
|
||||
try {
|
||||
const found = contents.match(/^(?:nodejs\s+)?v?(?<version>[^\s]+)$/m);
|
||||
nodeVersion = (_b = found === null || found === void 0 ? void 0 : found.groups) === null || _b === void 0 ? void 0 : _b.version;
|
||||
if (!nodeVersion)
|
||||
throw new Error();
|
||||
}
|
||||
|
@ -497,14 +497,18 @@ function translateArchToDistUrl(arch: string): string {
|
||||
export function parseNodeVersionFile(contents: string): string {
|
||||
let nodeVersion: string | undefined;
|
||||
|
||||
const found = contents.match(/^(?:nodejs\s+)?v?(?<version>[^\s]+)$/m);
|
||||
nodeVersion = found?.groups?.version;
|
||||
// Try parsing the file as an NPM `package.json`
|
||||
// file.
|
||||
try {
|
||||
nodeVersion = JSON.parse(contents).engines?.node;
|
||||
} catch {
|
||||
core.warning('Node version file is not JSON file');
|
||||
}
|
||||
|
||||
if (!nodeVersion) {
|
||||
try {
|
||||
// Try parsing the file as an NPM `package.json`
|
||||
// file.
|
||||
nodeVersion = JSON.parse(contents).engines?.node;
|
||||
const found = contents.match(/^(?:nodejs\s+)?v?(?<version>[^\s]+)$/m);
|
||||
nodeVersion = found?.groups?.version;
|
||||
|
||||
if (!nodeVersion) throw new Error();
|
||||
} catch (err) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user