From 65d7f2d534ac1bc67fcd62888c5f4f3d2cb2b236 Mon Sep 17 00:00:00 2001 From: Dmitry Shibanov Date: Thu, 7 Sep 2023 15:45:09 +0200 Subject: [PATCH] Add range validation for toml files (#726) --- .github/workflows/test-python.yml | 4 ++-- __tests__/utils.test.ts | 4 ++-- dist/setup/index.js | 11 ++++++++++- src/utils.ts | 16 +++++++++++++++- 4 files changed, 29 insertions(+), 6 deletions(-) diff --git a/.github/workflows/test-python.yml b/.github/workflows/test-python.yml index 56f8479..9dbdc70 100644 --- a/.github/workflows/test-python.yml +++ b/.github/workflows/test-python.yml @@ -157,7 +157,7 @@ jobs: fail-fast: false matrix: os: [macos-latest, windows-latest, ubuntu-20.04, ubuntu-22.04] - python: [3.5.4, 3.6.7, 3.7.5, 3.8.15, 3.9.13] + python: [3.5.4, 3.6.7, 3.7.5, 3.8.15, 3.9.13, '==3.10.10'] exclude: - os: ubuntu-22.04 python: 3.5.4 @@ -190,7 +190,7 @@ jobs: - name: Validate version run: | $pythonVersion = (python --version) - if ("Python ${{ matrix.python }}" -ne "$pythonVersion"){ + if ("Python ${{ matrix.python }}".replace("==", "") -ne "$pythonVersion"){ Write-Host "The current version is $pythonVersion; expected version is ${{ matrix.python }}" exit 1 } diff --git a/__tests__/utils.test.ts b/__tests__/utils.test.ts index 85b127a..40ef2f6 100644 --- a/__tests__/utils.test.ts +++ b/__tests__/utils.test.ts @@ -107,7 +107,7 @@ describe('Version from file test', () => { await io.mkdirP(tempDir); const pythonVersionFileName = 'pyproject.toml'; const pythonVersionFilePath = path.join(tempDir, pythonVersionFileName); - const pythonVersion = '>=3.7'; + const pythonVersion = '>=3.7.0'; const pythonVersionFileContent = `[project]\nrequires-python = "${pythonVersion}"`; fs.writeFileSync(pythonVersionFilePath, pythonVersionFileContent); expect(_fn(pythonVersionFilePath)).toEqual([pythonVersion]); @@ -119,7 +119,7 @@ describe('Version from file test', () => { await io.mkdirP(tempDir); const pythonVersionFileName = 'pyproject.toml'; const pythonVersionFilePath = path.join(tempDir, pythonVersionFileName); - const pythonVersion = '>=3.7'; + const pythonVersion = '>=3.7.0'; const pythonVersionFileContent = `[tool.poetry.dependencies]\npython = "${pythonVersion}"`; fs.writeFileSync(pythonVersionFilePath, pythonVersionFileContent); expect(_fn(pythonVersionFilePath)).toEqual([pythonVersion]); diff --git a/dist/setup/index.js b/dist/setup/index.js index 37b2479..ef8220c 100644 --- a/dist/setup/index.js +++ b/dist/setup/index.js @@ -70143,7 +70143,16 @@ function getVersionInputFromTomlFile(versionFile) { versions.push(version); } core.info(`Extracted ${versions} from ${versionFile}`); - return Array.from(versions, version => version.split(',').join(' ')); + const rawVersions = Array.from(versions, version => version.split(',').join(' ')); + const validatedVersions = rawVersions + .map(item => semver.validRange(item, true)) + .filter((versionRange, index) => { + if (!versionRange) { + core.debug(`The version ${rawVersions[index]} is not valid SemVer range`); + } + return !!versionRange; + }); + return validatedVersions; } exports.getVersionInputFromTomlFile = getVersionInputFromTomlFile; /** diff --git a/src/utils.ts b/src/utils.ts index 552f589..5f000c1 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -229,7 +229,21 @@ export function getVersionInputFromTomlFile(versionFile: string): string[] { } core.info(`Extracted ${versions} from ${versionFile}`); - return Array.from(versions, version => version.split(',').join(' ')); + const rawVersions = Array.from(versions, version => + version.split(',').join(' ') + ); + const validatedVersions = rawVersions + .map(item => semver.validRange(item, true)) + .filter((versionRange, index) => { + if (!versionRange) { + core.debug( + `The version ${rawVersions[index]} is not valid SemVer range` + ); + } + + return !!versionRange; + }) as string[]; + return validatedVersions; } /**