Compare commits

..

15 Commits

Author SHA1 Message Date
Fabio Niephaus
49e43a25ae Build simple web server. 2025-09-23 13:32:57 +02:00
Fabio Niephaus
83c82dcca9 Fix musl name 2025-09-23 13:30:36 +02:00
Fabio Niephaus
e140024fdc Bump version to 1.4.0. 2025-09-23 09:36:09 +02:00
Joel Rudsberg
933f90457d Bump SBOM test versions to 25 2025-09-23 09:36:09 +02:00
Fabio Niephaus
0246c29a59 Upgrade minimatch for ESM support.
Context: https://github.com/actions/typescript-action/issues/1017#issuecomment-2659619253
2025-09-23 09:36:09 +02:00
Fabio Niephaus
b4c67abb33 Convert to ESM.
Context: https://github.com/actions/typescript-action/pull/969
2025-09-23 09:36:09 +02:00
dependabot[bot]
59f089d81e Bump the npm-updates group with 7 updates
Bumps the npm-updates group with 7 updates:

| Package | From | To |
| --- | --- | --- |
| [uuid](https://github.com/uuidjs/uuid) | `11.1.0` | `13.0.0` |
| [@types/node](https://github.com/DefinitelyTyped/DefinitelyTyped/tree/HEAD/types/node) | `20.19.11` | `24.4.0` |
| [@types/semver](https://github.com/DefinitelyTyped/DefinitelyTyped/tree/HEAD/types/semver) | `7.7.0` | `7.7.1` |
| [@typescript-eslint/eslint-plugin](https://github.com/typescript-eslint/typescript-eslint/tree/HEAD/packages/eslint-plugin) | `8.41.0` | `8.43.0` |
| [@typescript-eslint/parser](https://github.com/typescript-eslint/typescript-eslint/tree/HEAD/packages/parser) | `8.41.0` | `8.43.0` |
| [eslint](https://github.com/eslint/eslint) | `9.34.0` | `9.35.0` |
| [jest](https://github.com/jestjs/jest/tree/HEAD/packages/jest) | `30.1.2` | `30.1.3` |


Updates `uuid` from 11.1.0 to 13.0.0
- [Release notes](https://github.com/uuidjs/uuid/releases)
- [Changelog](https://github.com/uuidjs/uuid/blob/main/CHANGELOG.md)
- [Commits](https://github.com/uuidjs/uuid/compare/v11.1.0...v13.0.0)

Updates `@types/node` from 20.19.11 to 24.4.0
- [Release notes](https://github.com/DefinitelyTyped/DefinitelyTyped/releases)
- [Commits](https://github.com/DefinitelyTyped/DefinitelyTyped/commits/HEAD/types/node)

Updates `@types/semver` from 7.7.0 to 7.7.1
- [Release notes](https://github.com/DefinitelyTyped/DefinitelyTyped/releases)
- [Commits](https://github.com/DefinitelyTyped/DefinitelyTyped/commits/HEAD/types/semver)

Updates `@typescript-eslint/eslint-plugin` from 8.41.0 to 8.43.0
- [Release notes](https://github.com/typescript-eslint/typescript-eslint/releases)
- [Changelog](https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/CHANGELOG.md)
- [Commits](https://github.com/typescript-eslint/typescript-eslint/commits/v8.43.0/packages/eslint-plugin)

Updates `@typescript-eslint/parser` from 8.41.0 to 8.43.0
- [Release notes](https://github.com/typescript-eslint/typescript-eslint/releases)
- [Changelog](https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/parser/CHANGELOG.md)
- [Commits](https://github.com/typescript-eslint/typescript-eslint/commits/v8.43.0/packages/parser)

Updates `eslint` from 9.34.0 to 9.35.0
- [Release notes](https://github.com/eslint/eslint/releases)
- [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md)
- [Commits](https://github.com/eslint/eslint/compare/v9.34.0...v9.35.0)

Updates `jest` from 30.1.2 to 30.1.3
- [Release notes](https://github.com/jestjs/jest/releases)
- [Changelog](https://github.com/jestjs/jest/blob/main/CHANGELOG.md)
- [Commits](https://github.com/jestjs/jest/commits/v30.1.3/packages/jest)

---
updated-dependencies:
- dependency-name: uuid
  dependency-version: 13.0.0
  dependency-type: direct:production
  update-type: version-update:semver-major
  dependency-group: npm-updates
- dependency-name: "@types/node"
  dependency-version: 24.4.0
  dependency-type: direct:development
  update-type: version-update:semver-major
  dependency-group: npm-updates
- dependency-name: "@types/semver"
  dependency-version: 7.7.1
  dependency-type: direct:development
  update-type: version-update:semver-patch
  dependency-group: npm-updates
- dependency-name: "@typescript-eslint/eslint-plugin"
  dependency-version: 8.43.0
  dependency-type: direct:development
  update-type: version-update:semver-minor
  dependency-group: npm-updates
- dependency-name: "@typescript-eslint/parser"
  dependency-version: 8.43.0
  dependency-type: direct:development
  update-type: version-update:semver-minor
  dependency-group: npm-updates
- dependency-name: eslint
  dependency-version: 9.35.0
  dependency-type: direct:development
  update-type: version-update:semver-minor
  dependency-group: npm-updates
- dependency-name: jest
  dependency-version: 30.1.3
  dependency-type: direct:development
  update-type: version-update:semver-patch
  dependency-group: npm-updates
...

Signed-off-by: dependabot[bot] <support@github.com>
2025-09-23 09:36:09 +02:00
Fabio Niephaus
aba6a077d7 Bump version to 1.3.7. 2025-09-16 17:03:23 +02:00
Fabio Niephaus
f4710e594c Update README.md for GraalVM 25. 2025-09-16 17:03:23 +02:00
Fabio Niephaus
1513e54cc1 Test against GraalVM 25 and 26 EA builds. 2025-09-16 17:03:23 +02:00
Fabio Niephaus
ba5bc86319 Pin GitHub Actions. 2025-09-15 17:01:28 +02:00
Fabio Niephaus
2fea119c1a Revise dependabot.yml. 2025-09-15 17:01:28 +02:00
Fabio Niephaus
deee6c389f Address new eslint warning. 2025-09-03 09:07:58 +02:00
dependabot[bot]
eb8ac6d547 Bump the npm-development group across 1 directory with 9 updates
Bumps the npm-development group with 8 updates in the / directory:

| Package | From | To |
| --- | --- | --- |
| [@eslint/compat](https://github.com/eslint/rewrite/tree/HEAD/packages/compat) | `1.3.1` | `1.3.2` |
| [@types/node](https://github.com/DefinitelyTyped/DefinitelyTyped/tree/HEAD/types/node) | `20.19.9` | `20.19.11` |
| [@typescript-eslint/eslint-plugin](https://github.com/typescript-eslint/typescript-eslint/tree/HEAD/packages/eslint-plugin) | `8.38.0` | `8.41.0` |
| [eslint](https://github.com/eslint/eslint) | `9.31.0` | `9.34.0` |
| [eslint-plugin-prettier](https://github.com/prettier/eslint-plugin-prettier) | `5.5.3` | `5.5.4` |
| [jest](https://github.com/jestjs/jest/tree/HEAD/packages/jest) | `30.0.5` | `30.1.2` |
| [ts-jest](https://github.com/kulshekhar/ts-jest) | `29.4.0` | `29.4.1` |
| [typescript](https://github.com/microsoft/TypeScript) | `5.8.3` | `5.9.2` |



Updates `@eslint/compat` from 1.3.1 to 1.3.2
- [Release notes](https://github.com/eslint/rewrite/releases)
- [Changelog](https://github.com/eslint/rewrite/blob/main/packages/compat/CHANGELOG.md)
- [Commits](https://github.com/eslint/rewrite/commits/compat-v1.3.2/packages/compat)

Updates `@types/node` from 20.19.9 to 20.19.11
- [Release notes](https://github.com/DefinitelyTyped/DefinitelyTyped/releases)
- [Commits](https://github.com/DefinitelyTyped/DefinitelyTyped/commits/HEAD/types/node)

Updates `@typescript-eslint/eslint-plugin` from 8.38.0 to 8.41.0
- [Release notes](https://github.com/typescript-eslint/typescript-eslint/releases)
- [Changelog](https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/CHANGELOG.md)
- [Commits](https://github.com/typescript-eslint/typescript-eslint/commits/v8.41.0/packages/eslint-plugin)

Updates `@typescript-eslint/parser` from 8.38.0 to 8.41.0
- [Release notes](https://github.com/typescript-eslint/typescript-eslint/releases)
- [Changelog](https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/parser/CHANGELOG.md)
- [Commits](https://github.com/typescript-eslint/typescript-eslint/commits/v8.41.0/packages/parser)

Updates `eslint` from 9.31.0 to 9.34.0
- [Release notes](https://github.com/eslint/eslint/releases)
- [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md)
- [Commits](https://github.com/eslint/eslint/compare/v9.31.0...v9.34.0)

Updates `eslint-plugin-prettier` from 5.5.3 to 5.5.4
- [Release notes](https://github.com/prettier/eslint-plugin-prettier/releases)
- [Changelog](https://github.com/prettier/eslint-plugin-prettier/blob/main/CHANGELOG.md)
- [Commits](https://github.com/prettier/eslint-plugin-prettier/compare/v5.5.3...v5.5.4)

Updates `jest` from 30.0.5 to 30.1.2
- [Release notes](https://github.com/jestjs/jest/releases)
- [Changelog](https://github.com/jestjs/jest/blob/main/CHANGELOG.md)
- [Commits](https://github.com/jestjs/jest/commits/HEAD/packages/jest)

Updates `ts-jest` from 29.4.0 to 29.4.1
- [Release notes](https://github.com/kulshekhar/ts-jest/releases)
- [Changelog](https://github.com/kulshekhar/ts-jest/blob/main/CHANGELOG.md)
- [Commits](https://github.com/kulshekhar/ts-jest/compare/v29.4.0...v29.4.1)

Updates `typescript` from 5.8.3 to 5.9.2
- [Release notes](https://github.com/microsoft/TypeScript/releases)
- [Changelog](https://github.com/microsoft/TypeScript/blob/main/azure-pipelines.release-publish.yml)
- [Commits](https://github.com/microsoft/TypeScript/compare/v5.8.3...v5.9.2)

---
updated-dependencies:
- dependency-name: "@eslint/compat"
  dependency-version: 1.3.2
  dependency-type: direct:development
  update-type: version-update:semver-patch
  dependency-group: npm-development
- dependency-name: "@types/node"
  dependency-version: 20.19.11
  dependency-type: direct:development
  update-type: version-update:semver-patch
  dependency-group: npm-development
- dependency-name: "@typescript-eslint/eslint-plugin"
  dependency-version: 8.41.0
  dependency-type: direct:development
  update-type: version-update:semver-minor
  dependency-group: npm-development
- dependency-name: "@typescript-eslint/parser"
  dependency-version: 8.41.0
  dependency-type: direct:development
  update-type: version-update:semver-minor
  dependency-group: npm-development
- dependency-name: eslint
  dependency-version: 9.34.0
  dependency-type: direct:development
  update-type: version-update:semver-minor
  dependency-group: npm-development
- dependency-name: eslint-plugin-prettier
  dependency-version: 5.5.4
  dependency-type: direct:development
  update-type: version-update:semver-patch
  dependency-group: npm-development
- dependency-name: jest
  dependency-version: 30.1.2
  dependency-type: direct:development
  update-type: version-update:semver-minor
  dependency-group: npm-development
- dependency-name: ts-jest
  dependency-version: 29.4.1
  dependency-type: direct:development
  update-type: version-update:semver-patch
  dependency-group: npm-development
- dependency-name: typescript
  dependency-version: 5.9.2
  dependency-type: direct:development
  update-type: version-update:semver-minor
  dependency-group: npm-development
...

Signed-off-by: dependabot[bot] <support@github.com>
2025-09-03 09:07:58 +02:00
dependabot[bot]
7e60c937ee Bump actions/checkout from 4 to 5
Bumps [actions/checkout](https://github.com/actions/checkout) from 4 to 5.
- [Release notes](https://github.com/actions/checkout/releases)
- [Changelog](https://github.com/actions/checkout/blob/main/CHANGELOG.md)
- [Commits](https://github.com/actions/checkout/compare/v4...v5)

---
updated-dependencies:
- dependency-name: actions/checkout
  dependency-version: '5'
  dependency-type: direct:production
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <support@github.com>
2025-09-02 17:45:14 +02:00
44 changed files with 125100 additions and 129958 deletions

View File

@@ -1,30 +1,19 @@
version: 2 version: 2
updates: updates:
- package-ecosystem: github-actions - package-ecosystem: 'github-actions'
directory: / directory: '/'
schedule: schedule:
interval: monthly interval: 'monthly'
groups: groups:
actions-minor: github-actions-updates:
update-types: patterns:
- minor - '*'
- patch
- package-ecosystem: npm - package-ecosystem: 'npm'
directory: / directory: '/'
schedule: schedule:
interval: monthly interval: 'monthly'
ignore:
- dependency-name: '@types/node'
update-types:
- 'version-update:semver-major'
groups: groups:
npm-development: npm-updates:
dependency-type: development patterns:
update-types: - '*'
- minor
- patch
npm-production:
dependency-type: production
update-types:
- patch

View File

@@ -32,11 +32,11 @@ jobs:
steps: steps:
- name: Checkout - name: Checkout
id: checkout id: checkout
uses: actions/checkout@v4 uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
- name: Setup Node.js - name: Setup Node.js
id: setup-node id: setup-node
uses: actions/setup-node@v4 uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0
with: with:
node-version-file: .node-version node-version-file: .node-version
cache: npm cache: npm
@@ -70,7 +70,7 @@ jobs:
- if: ${{ failure() && steps.diff.outcome == 'failure' }} - if: ${{ failure() && steps.diff.outcome == 'failure' }}
name: Upload Artifact name: Upload Artifact
id: upload id: upload
uses: actions/upload-artifact@v4 uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2
with: with:
name: dist name: dist
path: dist/ path: dist/

View File

@@ -18,9 +18,9 @@ jobs:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@v4 uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
- name: Setup Node.js - name: Setup Node.js
uses: actions/setup-node@v4 uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0
with: with:
node-version-file: .node-version node-version-file: .node-version
cache: npm cache: npm
@@ -35,350 +35,350 @@ jobs:
env: env:
INPUT_GITHUB_TOKEN: ${{ github.token }} # for core.getInput() INPUT_GITHUB_TOKEN: ${{ github.token }} # for core.getInput()
test-action: # test-action:
name: GraalVM # name: GraalVM
runs-on: ${{ matrix.os }} # runs-on: ${{ matrix.os }}
env: # env:
# Skip builds that require a GDS token but have no access to one (e.g., secrets are unavailable in PR runs) # # Skip builds that require a GDS token but have no access to one (e.g., secrets are unavailable in PR runs)
PASSES_GDS_TOKEN_CHECK: ${{ !matrix.set-gds-token || secrets.GDS_TOKEN != '' }} # PASSES_GDS_TOKEN_CHECK: ${{ !matrix.set-gds-token || secrets.GDS_TOKEN != '' }}
strategy: # strategy:
matrix: # matrix:
java-version: ['24', '21', '17', '20', 'dev'] # java-version: ['25', '21', '17', '20', 'dev']
distribution: ['graalvm', 'graalvm-community'] # distribution: ['graalvm', 'graalvm-community']
os: [ # os: [
ubuntu-latest, # Linux on Intel # ubuntu-latest, # Linux on Intel
ubuntu-22.04-arm, # Linux on arm64 # ubuntu-22.04-arm, # Linux on arm64
macos-latest, # macOS on Apple silicon # macos-latest, # macOS on Apple silicon
macos-13, # macOS on Intel # macos-13, # macOS on Intel
windows-latest # windows-latest
] # ]
set-gds-token: [false] # set-gds-token: [false]
components: [''] # components: ['']
include: # include:
- java-version: 'latest-ea' # - java-version: 'latest-ea'
distribution: 'graalvm' # distribution: 'graalvm'
os: ubuntu-latest # os: ubuntu-latest
- java-version: '25-ea' # - java-version: '25-ea'
distribution: 'graalvm' # distribution: 'graalvm'
os: ubuntu-latest # os: ubuntu-latest
- java-version: '21' # - java-version: '21'
distribution: '' # distribution: ''
os: ubuntu-latest # os: ubuntu-latest
- java-version: 'dev' # - java-version: 'dev'
distribution: '' # distribution: ''
os: windows-latest # os: windows-latest
- java-version: '21' # - java-version: '21'
distribution: 'graalvm-community' # distribution: 'graalvm-community'
os: ubuntu-latest # os: ubuntu-latest
components: 'native-image' # should print a warning but not fail # components: 'native-image' # should print a warning but not fail
- java-version: '21.0.0' # test for GA version (see #63) # - java-version: '21.0.0' # test for GA version (see #63)
distribution: 'graalvm' # distribution: 'graalvm'
os: ubuntu-latest # os: ubuntu-latest
- java-version: '17' # - java-version: '17'
distribution: 'graalvm' # distribution: 'graalvm'
os: ubuntu-latest # os: ubuntu-latest
set-gds-token: true # set-gds-token: true
- java-version: '17.0.13' # - java-version: '17.0.13'
distribution: 'graalvm' # distribution: 'graalvm'
os: ubuntu-latest # os: ubuntu-latest
set-gds-token: true # set-gds-token: true
steps: # steps:
- uses: actions/checkout@v4 # - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
- name: Run setup-graalvm action # - name: Run setup-graalvm action
uses: ./ # uses: ./
with: # with:
java-version: ${{ matrix.java-version }} # java-version: ${{ matrix.java-version }}
distribution: ${{ matrix.distribution }} # distribution: ${{ matrix.distribution }}
github-token: ${{ secrets.GITHUB_TOKEN }} # github-token: ${{ secrets.GITHUB_TOKEN }}
components: ${{ matrix.components }} # components: ${{ matrix.components }}
gds-token: ${{ matrix.set-gds-token && secrets.GDS_TOKEN || '' }} # gds-token: ${{ matrix.set-gds-token && secrets.GDS_TOKEN || '' }}
if: ${{ env.PASSES_GDS_TOKEN_CHECK == 'true' }} # if: ${{ env.PASSES_GDS_TOKEN_CHECK == 'true' }}
- name: Check environment # - name: Check environment
run: | # run: |
echo "GRAALVM_HOME: $GRAALVM_HOME" # echo "GRAALVM_HOME: $GRAALVM_HOME"
if [[ "${{ matrix.java-version }}" == "dev" ]]; then # if [[ "${{ matrix.java-version }}" == "dev" ]]; then
[[ "$GRAALVM_HOME" == *"$RUNNER_TEMP"* ]] || exit 12 # [[ "$GRAALVM_HOME" == *"$RUNNER_TEMP"* ]] || exit 12
else # else
[[ "$GRAALVM_HOME" == *"$RUNNER_TOOL_CACHE"* ]] || exit 23 # [[ "$GRAALVM_HOME" == *"$RUNNER_TOOL_CACHE"* ]] || exit 23
fi # fi
echo "JAVA_HOME: $JAVA_HOME" # echo "JAVA_HOME: $JAVA_HOME"
java --version # java --version
java --version | grep "GraalVM" || exit 34 # java --version | grep "GraalVM" || exit 34
native-image --version # native-image --version
if: ${{ env.PASSES_GDS_TOKEN_CHECK == 'true' && runner.os != 'Windows' }} # if: ${{ env.PASSES_GDS_TOKEN_CHECK == 'true' && runner.os != 'Windows' }}
- name: Check Windows environment # - name: Check Windows environment
run: | # run: |
echo "GRAALVM_HOME: $env:GRAALVM_HOME" # echo "GRAALVM_HOME: $env:GRAALVM_HOME"
echo "JAVA_HOME: $env:JAVA_HOME" # echo "JAVA_HOME: $env:JAVA_HOME"
java --version # java --version
native-image --version # native-image --version
if: ${{ env.PASSES_GDS_TOKEN_CHECK == 'true' && runner.os == 'Windows' }} # if: ${{ env.PASSES_GDS_TOKEN_CHECK == 'true' && runner.os == 'Windows' }}
test-action-ce: # make sure the action works on a clean machine without building # test-action-ce: # make sure the action works on a clean machine without building
needs: test-action # needs: test-action
name: CE ${{ matrix.version }} + JDK${{ matrix.java-version }} on ${{ matrix.os }} # name: CE ${{ matrix.version }} + JDK${{ matrix.java-version }} on ${{ matrix.os }}
runs-on: ${{ matrix.os }} # runs-on: ${{ matrix.os }}
strategy: # strategy:
matrix: # matrix:
version: ['latest', 'dev'] # version: ['latest', 'dev']
java-version: ['17', '20'] # java-version: ['17', '20']
components: ['native-image'] # components: ['native-image']
os: [macos-latest, windows-latest, ubuntu-latest] # os: [macos-latest, windows-latest, ubuntu-latest]
exclude: # exclude:
- version: 'latest' # - version: 'latest'
java-version: '20' # java-version: '20'
- version: 'dev' # - version: 'dev'
java-version: '19' # java-version: '19'
include: # include:
- version: '22.2.0' # for update notifications # - version: '22.2.0' # for update notifications
java-version: '17' # java-version: '17'
components: 'native-image' # components: 'native-image'
os: ubuntu-22.04 # os: ubuntu-22.04
- version: '21.2.0' # - version: '21.2.0'
java-version: '8' # for JDK 8 notification # java-version: '8' # for JDK 8 notification
components: 'native-image' # components: 'native-image'
os: ubuntu-latest # os: ubuntu-latest
- version: '22.3.1' # - version: '22.3.1'
java-version: '11' # for JDK 11 notification # java-version: '11' # for JDK 11 notification
components: 'native-image' # components: 'native-image'
os: macos-13 # os: macos-13
- version: '22.3.1' # - version: '22.3.1'
java-version: '17' # java-version: '17'
components: 'native-image' # components: 'native-image'
os: windows-2022 # os: windows-2022
- version: 'dev' # - version: 'dev'
java-version: 'dev' # java-version: 'dev'
components: 'native-image' # components: 'native-image'
os: ubuntu-latest # os: ubuntu-latest
steps: # steps:
- uses: actions/checkout@v4 # - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
- name: Run setup-graalvm action # - name: Run setup-graalvm action
uses: ./ # uses: ./
with: # with:
version: ${{ matrix.version }} # version: ${{ matrix.version }}
java-version: ${{ matrix.java-version }} # java-version: ${{ matrix.java-version }}
components: ${{ matrix.components }} # components: ${{ matrix.components }}
github-token: ${{ secrets.GITHUB_TOKEN }} # github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Check environment # - name: Check environment
run: | # run: |
echo "GRAALVM_HOME: $GRAALVM_HOME" # echo "GRAALVM_HOME: $GRAALVM_HOME"
if [[ "${{ matrix.version }}" == "dev" ]] && [[ "${{ matrix.java-version }}" == "dev" ]]; then # if [[ "${{ matrix.version }}" == "dev" ]] && [[ "${{ matrix.java-version }}" == "dev" ]]; then
[[ "$GRAALVM_HOME" == *"$RUNNER_TEMP"* ]] || exit 12 # [[ "$GRAALVM_HOME" == *"$RUNNER_TEMP"* ]] || exit 12
else # else
[[ "$GRAALVM_HOME" == *"$RUNNER_TOOL_CACHE"* ]] || exit 23 # [[ "$GRAALVM_HOME" == *"$RUNNER_TOOL_CACHE"* ]] || exit 23
fi # fi
echo "JAVA_HOME: $JAVA_HOME" # echo "JAVA_HOME: $JAVA_HOME"
java -version # java -version
java -version 2>&1 | grep "GraalVM" || exit 34 # java -version 2>&1 | grep "GraalVM" || exit 34
native-image --version # native-image --version
if [[ "${{ matrix.java-version }}" != "dev" ]]; then # if [[ "${{ matrix.java-version }}" != "dev" ]]; then
gu list # gu list
fi # fi
if: ${{ runner.os != 'Windows' }} # if: ${{ runner.os != 'Windows' }}
- name: Check Windows environment # - name: Check Windows environment
run: | # run: |
echo "GRAALVM_HOME: $env:GRAALVM_HOME" # echo "GRAALVM_HOME: $env:GRAALVM_HOME"
echo "JAVA_HOME: $env:JAVA_HOME" # echo "JAVA_HOME: $env:JAVA_HOME"
java -version # java -version
native-image --version # native-image --version
gu.cmd remove native-image # gu.cmd remove native-image
if: ${{ runner.os == 'Windows' }} # if: ${{ runner.os == 'Windows' }}
test-action-ee: # test-action-ee:
needs: test-action # needs: test-action
name: EE ${{ matrix.version }} + JDK${{ matrix.java-version }} on ${{ matrix.os }} # name: EE ${{ matrix.version }} + JDK${{ matrix.java-version }} on ${{ matrix.os }}
if: github.event_name != 'pull_request' # if: github.event_name != 'pull_request'
runs-on: ${{ matrix.os }} # runs-on: ${{ matrix.os }}
env: # env:
# Skip builds that require a GDS token but have no access to one (e.g., secrets are unavailable in PR runs) # # Skip builds that require a GDS token but have no access to one (e.g., secrets are unavailable in PR runs)
PASSES_GDS_TOKEN_CHECK: ${{ secrets.GDS_TOKEN != '' }} # PASSES_GDS_TOKEN_CHECK: ${{ secrets.GDS_TOKEN != '' }}
strategy: # strategy:
matrix: # matrix:
version: ['latest'] # version: ['latest']
java-version: ['17'] # java-version: ['17']
components: ['native-image'] # components: ['native-image']
os: [macos-latest, windows-latest, ubuntu-latest] # os: [macos-latest, windows-latest, ubuntu-latest]
include: # include:
- version: '22.3.3' # - version: '22.3.3'
java-version: '11' # java-version: '11'
components: 'native-image' # components: 'native-image'
os: ubuntu-latest # os: ubuntu-latest
- version: '22.3.3' # - version: '22.3.3'
java-version: '17' # java-version: '17'
components: 'native-image' # components: 'native-image'
os: ubuntu-latest # os: ubuntu-latest
steps: # steps:
- uses: actions/checkout@v4 # - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
- name: Run setup-graalvm action # - name: Run setup-graalvm action
uses: ./ # uses: ./
with: # with:
version: ${{ matrix.version }} # version: ${{ matrix.version }}
gds-token: ${{ secrets.GDS_TOKEN }} # gds-token: ${{ secrets.GDS_TOKEN }}
java-version: ${{ matrix.java-version }} # java-version: ${{ matrix.java-version }}
components: ${{ matrix.components }} # components: ${{ matrix.components }}
github-token: ${{ secrets.GITHUB_TOKEN }} # github-token: ${{ secrets.GITHUB_TOKEN }}
if: ${{ env.PASSES_GDS_TOKEN_CHECK == 'true' }} # if: ${{ env.PASSES_GDS_TOKEN_CHECK == 'true' }}
- name: Check environment # - name: Check environment
run: | # run: |
echo "GRAALVM_HOME: $GRAALVM_HOME" # echo "GRAALVM_HOME: $GRAALVM_HOME"
[[ "$GRAALVM_HOME" == *"$RUNNER_TOOL_CACHE"* ]] || exit 12 # [[ "$GRAALVM_HOME" == *"$RUNNER_TOOL_CACHE"* ]] || exit 12
echo "JAVA_HOME: $JAVA_HOME" # echo "JAVA_HOME: $JAVA_HOME"
java --version # java --version
java --version | grep -e "GraalVM EE" -e "Oracle GraalVM" || exit 23 # java --version | grep -e "GraalVM EE" -e "Oracle GraalVM" || exit 23
native-image --version # native-image --version
gu list # gu list
if: ${{ env.PASSES_GDS_TOKEN_CHECK == 'true' && runner.os != 'Windows' }} # if: ${{ env.PASSES_GDS_TOKEN_CHECK == 'true' && runner.os != 'Windows' }}
- name: Check Windows environment # - name: Check Windows environment
run: | # run: |
echo "GRAALVM_HOME: $env:GRAALVM_HOME" # echo "GRAALVM_HOME: $env:GRAALVM_HOME"
echo "JAVA_HOME: $env:JAVA_HOME" # echo "JAVA_HOME: $env:JAVA_HOME"
java --version # java --version
native-image --version # native-image --version
gu.cmd remove native-image # gu.cmd remove native-image
if: ${{ env.PASSES_GDS_TOKEN_CHECK == 'true' && runner.os == 'Windows' }} # if: ${{ env.PASSES_GDS_TOKEN_CHECK == 'true' && runner.os == 'Windows' }}
test-action-mandrel: # test-action-mandrel:
needs: test-action # needs: test-action
name: ${{ matrix.version }} + JDK${{ matrix.java-version }} on ${{ matrix.os }} # name: ${{ matrix.version }} + JDK${{ matrix.java-version }} on ${{ matrix.os }}
runs-on: ${{ matrix.os }} # runs-on: ${{ matrix.os }}
strategy: # strategy:
matrix: # matrix:
version: ['mandrel-22.2.0.0-Final', '23.0.1.2-Final', 'mandrel-latest'] # version: ['mandrel-22.2.0.0-Final', '23.0.1.2-Final', 'mandrel-latest']
java-version: ['17'] # java-version: ['17']
distribution: ['mandrel'] # distribution: ['mandrel']
os: [windows-latest, ubuntu-latest] # os: [windows-latest, ubuntu-latest]
include: # include:
- version: 'mandrel-latest' # - version: 'mandrel-latest'
java-version: '17' # java-version: '17'
distribution: '' # test empty distribution for backward compatibility # distribution: '' # test empty distribution for backward compatibility
os: ubuntu-latest # os: ubuntu-latest
- version: '' # test with no version # - version: '' # test with no version
java-version: '21' # java-version: '21'
distribution: 'mandrel' # distribution: 'mandrel'
os: ubuntu-latest # os: ubuntu-latest
steps: # steps:
- uses: actions/checkout@v4 # - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
- name: Run setup-graalvm action # - name: Run setup-graalvm action
uses: ./ # uses: ./
with: # with:
version: ${{ matrix.version }} # version: ${{ matrix.version }}
distribution: ${{ matrix.distribution }} # distribution: ${{ matrix.distribution }}
java-version: ${{ matrix.java-version }} # java-version: ${{ matrix.java-version }}
github-token: ${{ secrets.GITHUB_TOKEN }} # github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Check environment # - name: Check environment
run: | # run: |
echo "GRAALVM_HOME: $GRAALVM_HOME" # echo "GRAALVM_HOME: $GRAALVM_HOME"
[[ "$GRAALVM_HOME" == *"$RUNNER_TOOL_CACHE"* ]] || exit 12 # [[ "$GRAALVM_HOME" == *"$RUNNER_TOOL_CACHE"* ]] || exit 12
echo "JAVA_HOME: $JAVA_HOME" # echo "JAVA_HOME: $JAVA_HOME"
java --version # java --version
java --version | grep "Temurin" || exit 23 # java --version | grep "Temurin" || exit 23
native-image --version # native-image --version
if: ${{ runner.os != 'Windows' }} # if: ${{ runner.os != 'Windows' }}
- name: Check Windows environment # - name: Check Windows environment
run: | # run: |
echo "GRAALVM_HOME: $env:GRAALVM_HOME" # echo "GRAALVM_HOME: $env:GRAALVM_HOME"
echo "JAVA_HOME: $env:JAVA_HOME" # echo "JAVA_HOME: $env:JAVA_HOME"
java --version # java --version
native-image --version # native-image --version
if: ${{ runner.os == 'Windows' }} # if: ${{ runner.os == 'Windows' }}
test-action-liberica: # test-action-liberica:
needs: test-action # needs: test-action
name: Liberica (${{ matrix.java-version }}, '${{ matrix.java-package }}', ${{ matrix.os }}) # name: Liberica (${{ matrix.java-version }}, '${{ matrix.java-package }}', ${{ matrix.os }})
runs-on: ${{ matrix.os }} # runs-on: ${{ matrix.os }}
strategy: # strategy:
matrix: # matrix:
java-version: ['17', '21.0.2'] # java-version: ['17', '21.0.2']
java-package: ['', 'jdk', 'jdk+fx'] # java-package: ['', 'jdk', 'jdk+fx']
os: [ubuntu-latest, macos-latest, windows-latest] # os: [ubuntu-latest, macos-latest, windows-latest]
steps: # steps:
- uses: actions/checkout@v4 # - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
- name: Run setup-graalvm action # - name: Run setup-graalvm action
uses: ./ # uses: ./
with: # with:
distribution: liberica # distribution: liberica
java-version: ${{ matrix.java-version }} # java-version: ${{ matrix.java-version }}
java-package: ${{ matrix.java-package }} # java-package: ${{ matrix.java-package }}
github-token: ${{ secrets.GITHUB_TOKEN }} # github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Check environment # - name: Check environment
run: | # run: |
echo "GRAALVM_HOME: $GRAALVM_HOME" # echo "GRAALVM_HOME: $GRAALVM_HOME"
[[ "$GRAALVM_HOME" == *"$RUNNER_TOOL_CACHE"* ]] || exit 12 # [[ "$GRAALVM_HOME" == *"$RUNNER_TOOL_CACHE"* ]] || exit 12
echo "JAVA_HOME: $JAVA_HOME" # echo "JAVA_HOME: $JAVA_HOME"
java --version # java --version
java --version | fgrep -qw ${{ matrix.java-version }} || exit 23 # java --version | fgrep -qw ${{ matrix.java-version }} || exit 23
native-image --version # native-image --version
native-image --version | fgrep -qw ${{ matrix.java-version }} || exit 24 # native-image --version | fgrep -qw ${{ matrix.java-version }} || exit 24
if: ${{ runner.os != 'Windows' }} # if: ${{ runner.os != 'Windows' }}
- name: Check Windows environment # - name: Check Windows environment
shell: pwsh # shell: pwsh
run: | # run: |
echo "GRAALVM_HOME: $env:GRAALVM_HOME" # echo "GRAALVM_HOME: $env:GRAALVM_HOME"
echo "JAVA_HOME: $env:JAVA_HOME" # echo "JAVA_HOME: $env:JAVA_HOME"
java --version # java --version
if (!(java --version | findstr \<${{ matrix.java-version }}\>)) { # if (!(java --version | findstr \<${{ matrix.java-version }}\>)) {
exit 23 # exit 23
} # }
native-image --version # native-image --version
if (!(native-image --version | findstr \<${{ matrix.java-version }}\>)) { # if (!(native-image --version | findstr \<${{ matrix.java-version }}\>)) {
exit 24 # exit 24
} # }
if: ${{ runner.os == 'Windows' }} # if: ${{ runner.os == 'Windows' }}
test-action-native-image-windows: # test-action-native-image-windows:
name: native-image on windows-latest # name: native-image on windows-latest
runs-on: windows-latest # runs-on: windows-latest
permissions: # permissions:
contents: read # contents: read
pull-requests: write # for `native-image-pr-reports` option # pull-requests: write # for `native-image-pr-reports` option
steps: # steps:
- uses: actions/checkout@v4 # - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
- name: Run setup-graalvm action # - name: Run setup-graalvm action
uses: ./ # uses: ./
with: # with:
java-version: 'dev' # java-version: 'dev'
distribution: 'graalvm-community' # distribution: 'graalvm-community'
native-image-job-reports: 'true' # native-image-job-reports: 'true'
native-image-pr-reports: 'true' # native-image-pr-reports: 'true'
github-token: ${{ secrets.GITHUB_TOKEN }} # github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Build HelloWorld executable with GraalVM Native Image on Windows # - name: Build HelloWorld executable with GraalVM Native Image on Windows
run: | # run: |
echo 'public class HelloWorld { public static void main(String[] args) { System.out.println("Hello, World!"); } }' > HelloWorld.java # echo 'public class HelloWorld { public static void main(String[] args) { System.out.println("Hello, World!"); } }' > HelloWorld.java
javac HelloWorld.java # javac HelloWorld.java
native-image HelloWorld # native-image HelloWorld
./helloworld # ./helloworld
test-action-native-image-windows-msvc: # test-action-native-image-windows-msvc:
name: native-image on windows-2022 # name: native-image on windows-2022
runs-on: windows-2022 # runs-on: windows-2022
permissions: # permissions:
contents: read # contents: read
pull-requests: write # for `native-image-pr-reports` option # pull-requests: write # for `native-image-pr-reports` option
steps: # steps:
- uses: actions/checkout@v4 # - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
- name: Run setup-graalvm action # - name: Run setup-graalvm action
uses: ./ # uses: ./
with: # with:
java-version: '17' # java-version: '17'
distribution: 'graalvm' # distribution: 'graalvm'
native-image-job-reports: 'true' # native-image-job-reports: 'true'
native-image-pr-reports: 'true' # native-image-pr-reports: 'true'
github-token: ${{ secrets.GITHUB_TOKEN }} # github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Build HelloWorld executable with GraalVM Native Image on Windows # - name: Build HelloWorld executable with GraalVM Native Image on Windows
run: | # run: |
echo 'public class HelloWorld { public static void main(String[] args) { System.out.println("Hello, World!"); } }' > HelloWorld.java # echo 'public class HelloWorld { public static void main(String[] args) { System.out.println("Hello, World!"); } }' > HelloWorld.java
javac HelloWorld.java # javac HelloWorld.java
native-image HelloWorld # native-image HelloWorld
./helloworld # ./helloworld
test-action-native-image-musl: test-action-native-image-musl-ce:
name: native-image-musl on ubuntu-latest name: native-image-musl on ubuntu-latest
runs-on: ubuntu-latest runs-on: ubuntu-latest
permissions: permissions:
contents: read contents: read
pull-requests: write # for `native-image-pr-reports` option pull-requests: write # for `native-image-pr-reports` option
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
- name: Run setup-graalvm action - name: Run setup-graalvm action
uses: ./ uses: ./
with: with:
@@ -394,96 +394,124 @@ jobs:
javac HelloWorld.java javac HelloWorld.java
native-image --static --libc=musl HelloWorld native-image --static --libc=musl HelloWorld
./helloworld ./helloworld
native-image --static --libc=musl -m jdk.httpserver
test-action-extensive: ./jdk.httpserver --help
name: extensive tests on ubuntu-latest test-action-native-image-musl:
name: native-image-musl on ubuntu-latest
runs-on: ubuntu-latest runs-on: ubuntu-latest
permissions: permissions:
contents: read contents: read
pull-requests: write # for `native-image-pr-reports` option pull-requests: write # for `native-image-pr-reports` option
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
- name: Run setup-graalvm action - name: Run setup-graalvm action
uses: ./ uses: ./
with: with:
java-version: '17.0.8' java-version: '25'
distribution: 'graalvm' distribution: 'graalvm'
components: 'espresso,llvm-toolchain,native-image,nodejs,python,ruby,wasm' native-image-musl: 'true'
set-java-home: 'false'
native-image-job-reports: 'true' native-image-job-reports: 'true'
native-image-pr-reports: 'true' native-image-pr-reports: 'true'
github-token: ${{ secrets.GITHUB_TOKEN }} github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Check environment - name: Build static HelloWorld executable with GraalVM Native Image and musl
run: |
echo "GRAALVM_HOME: $GRAALVM_HOME"
echo "JAVA_HOME: $JAVA_HOME"
[[ "$GRAALVM_HOME" != "$JAVA_HOME" ]] || exit 12
[[ $(which java) == *"graalvm"* ]] || exit 23
java --version
java -truffle --version
gu --version
gu list
[[ $(which lli) == *"graalvm"* ]] || exit 34
lli --version
native-image --version
[[ $(which node) == *"graalvm"* ]] || exit 45
node --version
graalpy --version
truffleruby --version
wasm --version
- name: Build HelloWorld.java with GraalVM Native Image
run: | run: |
echo 'public class HelloWorld { public static void main(String[] args) { System.out.println("Hello, World!"); } }' > HelloWorld.java echo 'public class HelloWorld { public static void main(String[] args) { System.out.println("Hello, World!"); } }' > HelloWorld.java
javac HelloWorld.java javac HelloWorld.java
native-image -g HelloWorld native-image --static --libc=musl HelloWorld
./helloworld ./helloworld
# - name: Build Ruby-FFI with TruffleRuby native-image --static --libc=musl --gc=G1 -m jdk.httpserver
# run: | ./jdk.httpserver --help
# [[ $(which bundle) == *"graalvm"* ]] || exit 57
# git clone --depth 1 https://github.com/ffi/ffi.git
# pushd ffi > /dev/null
# # https://github.com/ffi/ffi/blob/447845cb3030194c79700c86fb388a12e6f81386/.github/workflows/ci.yml#L58-L62
# bundle install
# bundle exec rake libffi
# bundle exec rake compile
# bundle exec rake test
# popd > /dev/null
- name: Remove components
run: gu remove espresso llvm-toolchain nodejs python ruby wasm
test-action-sbom:
name: test 'native-image-enable-sbom' option # test-action-extensive:
runs-on: ${{ matrix.os }} # name: extensive tests on ubuntu-latest
permissions: # runs-on: ubuntu-latest
contents: write # permissions:
strategy: # contents: read
matrix: # pull-requests: write # for `native-image-pr-reports` option
java-version: ['24-ea', 'latest-ea'] # steps:
distribution: ['graalvm'] # - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
os: [macos-latest, windows-latest, ubuntu-latest, ubuntu-22.04-arm] # - name: Run setup-graalvm action
components: [''] # uses: ./
steps: # with:
- uses: actions/checkout@v4 # java-version: '17.0.8'
- name: Run setup-graalvm action # distribution: 'graalvm'
uses: ./ # components: 'espresso,llvm-toolchain,native-image,nodejs,python,ruby,wasm'
with: # set-java-home: 'false'
java-version: ${{ matrix.java-version }} # native-image-job-reports: 'true'
distribution: ${{ matrix.distribution }} # native-image-pr-reports: 'true'
github-token: ${{ secrets.GITHUB_TOKEN }} # github-token: ${{ secrets.GITHUB_TOKEN }}
components: ${{ matrix.components }} # - name: Check environment
native-image-enable-sbom: 'true' # run: |
cache: 'maven' # echo "GRAALVM_HOME: $GRAALVM_HOME"
- name: Build Maven project and verify that SBOM was generated and its contents # echo "JAVA_HOME: $JAVA_HOME"
run: | # [[ "$GRAALVM_HOME" != "$JAVA_HOME" ]] || exit 12
cd __tests__/sbom/main-test-app # [[ $(which java) == *"graalvm"* ]] || exit 23
mvn --no-transfer-progress -Pnative package # java --version
bash verify-sbom.sh # java -truffle --version
shell: bash # gu --version
if: ${{ runner.os != 'Windows' }} # gu list
- name: Build Maven project and verify that SBOM was generated and its contents (Windows) # [[ $(which lli) == *"graalvm"* ]] || exit 34
run: | # lli --version
cd __tests__\sbom\main-test-app # native-image --version
mvn --no-transfer-progress -Pnative package # [[ $(which node) == *"graalvm"* ]] || exit 45
cmd /c verify-sbom.cmd # node --version
shell: cmd # graalpy --version
if: ${{ runner.os == 'Windows' }} # truffleruby --version
# wasm --version
# - name: Build HelloWorld.java with GraalVM Native Image
# run: |
# echo 'public class HelloWorld { public static void main(String[] args) { System.out.println("Hello, World!"); } }' > HelloWorld.java
# javac HelloWorld.java
# native-image -g HelloWorld
# ./helloworld
# # - name: Build Ruby-FFI with TruffleRuby
# # run: |
# # [[ $(which bundle) == *"graalvm"* ]] || exit 57
# # git clone --depth 1 https://github.com/ffi/ffi.git
# # pushd ffi > /dev/null
# # # https://github.com/ffi/ffi/blob/447845cb3030194c79700c86fb388a12e6f81386/.github/workflows/ci.yml#L58-L62
# # bundle install
# # bundle exec rake libffi
# # bundle exec rake compile
# # bundle exec rake test
# # popd > /dev/null
# - name: Remove components
# run: gu remove espresso llvm-toolchain nodejs python ruby wasm
# test-action-sbom:
# name: test 'native-image-enable-sbom' option
# runs-on: ${{ matrix.os }}
# permissions:
# contents: write
# strategy:
# matrix:
# java-version: ['25', 'latest-ea']
# distribution: ['graalvm']
# os: [macos-latest, windows-latest, ubuntu-latest, ubuntu-22.04-arm]
# components: ['']
# steps:
# - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
# - name: Run setup-graalvm action
# uses: ./
# with:
# java-version: ${{ matrix.java-version }}
# distribution: ${{ matrix.distribution }}
# github-token: ${{ secrets.GITHUB_TOKEN }}
# components: ${{ matrix.components }}
# native-image-enable-sbom: 'true'
# cache: 'maven'
# - name: Build Maven project and verify that SBOM was generated and its contents
# run: |
# cd __tests__/sbom/main-test-app
# mvn --no-transfer-progress -Pnative package
# bash verify-sbom.sh
# shell: bash
# if: ${{ runner.os != 'Windows' }}
# - name: Build Maven project and verify that SBOM was generated and its contents (Windows)
# run: |
# cd __tests__\sbom\main-test-app
# mvn --no-transfer-progress -Pnative package
# cmd /c verify-sbom.cmd
# shell: cmd
# if: ${{ runner.os == 'Windows' }}

View File

@@ -29,7 +29,7 @@ jobs:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
- uses: graalvm/setup-graalvm@v1 - uses: graalvm/setup-graalvm@v1
with: with:
java-version: '21' # See 'Options' for more details java-version: '25' # See 'Options' for more details
distribution: 'graalvm' # See 'Supported distributions' for available options distribution: 'graalvm' # See 'Supported distributions' for available options
github-token: ${{ secrets.GITHUB_TOKEN }} github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Example step - name: Example step
@@ -61,7 +61,7 @@ jobs:
- uses: graalvm/setup-graalvm@v1 - uses: graalvm/setup-graalvm@v1
with: with:
java-version: '21' java-version: '25'
distribution: 'graalvm' distribution: 'graalvm'
github-token: ${{ secrets.GITHUB_TOKEN }} github-token: ${{ secrets.GITHUB_TOKEN }}
native-image-job-reports: 'true' native-image-job-reports: 'true'
@@ -92,7 +92,7 @@ jobs:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
- uses: graalvm/setup-graalvm@v1 - uses: graalvm/setup-graalvm@v1
with: with:
java-version: '24-ea' # or 'latest-ea' for the latest Java version available java-version: '26-ea' # or 'latest-ea' for the latest Java version available
distribution: 'graalvm' distribution: 'graalvm'
github-token: ${{ secrets.GITHUB_TOKEN }} github-token: ${{ secrets.GITHUB_TOKEN }}
``` ```
@@ -194,7 +194,7 @@ This actions can be configured with the following options:
| Name | Default | Description | | Name | Default | Description |
|-----------------|:--------:|-------------| |-----------------|:--------:|-------------|
| `java-version`<br>*(required)* | n/a | Java version <ul><li>major versions: `'24'`, `'21'`, `'17'`, `'11'`, `'8'`</li><li>specific versions: `'21.0.3'`, `'17.0.11'`</li><li>early access (EA) builds: `'25-ea'` *(requires `distribution: 'graalvm'`)*</li><li>latest EA build: `'latest-ea'` *(requires `distribution: 'graalvm'`)*</li><li>dev builds: `'dev'`</li></ul> | | `java-version`<br>*(required)* | n/a | Java version <ul><li>major versions: `'25'`, `'21'`, `'17'`, `'11'`, `'8'`</li><li>specific versions: `'21.0.3'`, `'17.0.11'`</li><li>early access (EA) builds: `'26-ea'` *(requires `distribution: 'graalvm'`)*</li><li>latest EA build: `'latest-ea'` *(requires `distribution: 'graalvm'`)*</li><li>dev builds: `'dev'`</li></ul> |
| `distribution` | `'graalvm'` | GraalVM distribution (see [supported distributions](#supported-distributions)) | | `distribution` | `'graalvm'` | GraalVM distribution (see [supported distributions](#supported-distributions)) |
| `java-package` | `'jdk'` | The package type (`'jdk'` or `'jdk+fx'`). Currently applies to Liberica only. | | `java-package` | `'jdk'` | The package type (`'jdk'` or `'jdk+fx'`). Currently applies to Liberica only. |
| `github-token` | `'${{ github.token }}'` | Token for communication with the GitHub API. Please set this to `${{ secrets.GITHUB_TOKEN }}` (see [templates](#templates)) to allow the action to authenticate with the GitHub API, which helps reduce rate-limiting issues. | | `github-token` | `'${{ github.token }}'` | Token for communication with the GitHub API. Please set this to `${{ secrets.GITHUB_TOKEN }}` (see [templates](#templates)) to allow the action to authenticate with the GitHub API, which helps reduce rate-limiting issues. |

7
__fixtures__/cache.ts Normal file
View File

@@ -0,0 +1,7 @@
import * as cache from '@actions/cache'
import { jest } from '@jest/globals'
export const ReserveCacheError = cache.ReserveCacheError
export const restoreCache = jest.fn<typeof cache.restoreCache>()
export const saveCache = jest.fn<typeof cache.saveCache>()
export const ValidationError = cache.ValidationError

13
__fixtures__/core.ts Normal file
View File

@@ -0,0 +1,13 @@
import type * as core from '@actions/core'
import { jest } from '@jest/globals'
export const debug = jest.fn<typeof core.debug>()
export const error = jest.fn<typeof core.error>()
export const exportVariable = jest.fn<typeof core.exportVariable>()
export const getInput = jest.fn<typeof core.getInput>()
export const getState = jest.fn<typeof core.getState>()
export const info = jest.fn<typeof core.info>()
export const saveState = jest.fn<typeof core.saveState>()
export const setFailed = jest.fn<typeof core.setFailed>()
export const setOutput = jest.fn<typeof core.setOutput>()
export const warning = jest.fn<typeof core.warning>()

15
__fixtures__/github.ts Normal file
View File

@@ -0,0 +1,15 @@
import * as github from '@actions/github'
import { jest } from '@jest/globals'
export const context = {
repo: {
owner: 'test-owner',
repo: 'test-repo'
},
sha: 'test-sha',
ref: 'test-ref',
workflow: 'test-workflow',
job: 'test-job',
runId: '12345'
}
export const getOctokit = jest.fn<typeof github.getOctokit>()

4
__fixtures__/glob.ts Normal file
View File

@@ -0,0 +1,4 @@
import * as glob from '@actions/glob'
import { jest } from '@jest/globals'
export const create = jest.fn<typeof glob.create>()

View File

@@ -24,24 +24,28 @@
* Forked from https://github.com/actions/setup-java/blob/5b36705a13905facb447b6812d613a06a07e371d/__tests__/cache.test.ts * Forked from https://github.com/actions/setup-java/blob/5b36705a13905facb447b6812d613a06a07e371d/__tests__/cache.test.ts
*/ */
import { jest } from '@jest/globals'
import { mkdtempSync } from 'fs' import { mkdtempSync } from 'fs'
import { tmpdir } from 'os' import { tmpdir } from 'os'
import { join } from 'path' import { join } from 'path'
import { restore, save } from '../src/features/cache'
import * as fs from 'fs' import * as fs from 'fs'
import * as os from 'os' import * as os from 'os'
import * as core from '@actions/core' import * as cache from '../__fixtures__/cache.js'
import * as cache from '@actions/cache' import * as core from '../__fixtures__/core.js'
// Mocks should be declared before the module being tested is imported.
jest.unstable_mockModule('@actions/core', () => core)
jest.unstable_mockModule('@actions/cache', () => cache)
// The module being tested should be imported dynamically. This ensures that the
// mocks are used in place of any actual dependencies.
const { restore, save } = await import('../src/features/cache.js')
describe('dependency cache', () => { describe('dependency cache', () => {
const ORIGINAL_RUNNER_OS = process.env['RUNNER_OS'] const ORIGINAL_RUNNER_OS = process.env['RUNNER_OS']
const ORIGINAL_GITHUB_WORKSPACE = process.env['GITHUB_WORKSPACE'] const ORIGINAL_GITHUB_WORKSPACE = process.env['GITHUB_WORKSPACE']
const ORIGINAL_CWD = process.cwd() const ORIGINAL_CWD = process.cwd()
let workspace: string let workspace: string
let spyInfo: jest.SpyInstance<void, Parameters<typeof core.info>>
let spyWarning: jest.SpyInstance<void, Parameters<typeof core.warning>>
let spyDebug: jest.SpyInstance<void, Parameters<typeof core.debug>>
let spySaveState: jest.SpyInstance<void, Parameters<typeof core.saveState>>
beforeEach(() => { beforeEach(() => {
workspace = mkdtempSync(join(tmpdir(), 'setup-graalvm-cache-')) workspace = mkdtempSync(join(tmpdir(), 'setup-graalvm-cache-'))
@@ -65,17 +69,9 @@ describe('dependency cache', () => {
}) })
beforeEach(() => { beforeEach(() => {
spyInfo = jest.spyOn(core, 'info') core.info.mockImplementation(() => null)
spyInfo.mockImplementation(() => null) core.warning.mockImplementation(() => null)
core.debug.mockImplementation(() => null)
spyWarning = jest.spyOn(core, 'warning')
spyWarning.mockImplementation(() => null)
spyDebug = jest.spyOn(core, 'debug')
spyDebug.mockImplementation(() => null)
spySaveState = jest.spyOn(core, 'saveState')
spySaveState.mockImplementation(() => null)
}) })
afterEach(() => { afterEach(() => {
@@ -86,13 +82,8 @@ describe('dependency cache', () => {
}) })
describe('restore', () => { describe('restore', () => {
let spyCacheRestore: jest.SpyInstance<ReturnType<typeof cache.restoreCache>, Parameters<typeof cache.restoreCache>>
beforeEach(() => { beforeEach(() => {
spyCacheRestore = jest cache.restoreCache.mockImplementation((_paths: string[], _primaryKey: string) => Promise.resolve(undefined))
.spyOn(cache, 'restoreCache')
.mockImplementation((_paths: string[], _primaryKey: string) => Promise.resolve(undefined))
spyWarning.mockImplementation(() => null)
}) })
it('throws error if unsupported package manager specified', () => { it('throws error if unsupported package manager specified', () => {
@@ -111,9 +102,9 @@ describe('dependency cache', () => {
createFile(join(workspace, 'pom.xml')) createFile(join(workspace, 'pom.xml'))
await restore('maven') await restore('maven')
expect(spyCacheRestore).toHaveBeenCalled() expect(cache.restoreCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
expect(spyInfo).toHaveBeenCalledWith('maven cache is not found') expect(core.info).toHaveBeenCalledWith('maven cache is not found')
}) })
}) })
describe('for gradle', () => { describe('for gradle', () => {
@@ -128,17 +119,17 @@ describe('dependency cache', () => {
createFile(join(workspace, 'build.gradle')) createFile(join(workspace, 'build.gradle'))
await restore('gradle') await restore('gradle')
expect(spyCacheRestore).toHaveBeenCalled() expect(cache.restoreCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
expect(spyInfo).toHaveBeenCalledWith('gradle cache is not found') expect(core.info).toHaveBeenCalledWith('gradle cache is not found')
}) })
it('downloads cache based on build.gradle.kts', async () => { it('downloads cache based on build.gradle.kts', async () => {
createFile(join(workspace, 'build.gradle.kts')) createFile(join(workspace, 'build.gradle.kts'))
await restore('gradle') await restore('gradle')
expect(spyCacheRestore).toHaveBeenCalled() expect(cache.restoreCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
expect(spyInfo).toHaveBeenCalledWith('gradle cache is not found') expect(core.info).toHaveBeenCalledWith('gradle cache is not found')
}) })
}) })
it('downloads cache based on buildSrc/Versions.kt', async () => { it('downloads cache based on buildSrc/Versions.kt', async () => {
@@ -146,9 +137,9 @@ describe('dependency cache', () => {
createFile(join(workspace, 'buildSrc', 'Versions.kt')) createFile(join(workspace, 'buildSrc', 'Versions.kt'))
await restore('gradle') await restore('gradle')
expect(spyCacheRestore).toHaveBeenCalled() expect(cache.restoreCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
expect(spyInfo).toHaveBeenCalledWith('gradle cache is not found') expect(core.info).toHaveBeenCalledWith('gradle cache is not found')
}) })
describe('for sbt', () => { describe('for sbt', () => {
it('throws error if no build.sbt found', async () => { it('throws error if no build.sbt found', async () => {
@@ -162,20 +153,16 @@ describe('dependency cache', () => {
createFile(join(workspace, 'build.sbt')) createFile(join(workspace, 'build.sbt'))
await restore('sbt') await restore('sbt')
expect(spyCacheRestore).toHaveBeenCalled() expect(cache.restoreCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
expect(spyInfo).toHaveBeenCalledWith('sbt cache is not found') expect(core.info).toHaveBeenCalledWith('sbt cache is not found')
}) })
}) })
}) })
describe('save', () => { describe('save', () => {
let spyCacheSave: jest.SpyInstance<ReturnType<typeof cache.saveCache>, Parameters<typeof cache.saveCache>>
beforeEach(() => { beforeEach(() => {
spyCacheSave = jest cache.saveCache.mockImplementation((_paths: string[], _key: string) => Promise.resolve(0))
.spyOn(cache, 'saveCache') core.warning.mockImplementation(() => null)
.mockImplementation((_paths: string[], _key: string) => Promise.resolve(0))
spyWarning.mockImplementation(() => null)
}) })
it('throws error if unsupported package manager specified', () => { it('throws error if unsupported package manager specified', () => {
@@ -183,18 +170,18 @@ describe('dependency cache', () => {
}) })
it('save with -1 cacheId , should not fail workflow', async () => { it('save with -1 cacheId , should not fail workflow', async () => {
spyCacheSave.mockImplementation(() => Promise.resolve(-1)) cache.saveCache.mockImplementation(() => Promise.resolve(-1))
createStateForMissingBuildFile() createStateForMissingBuildFile()
await save('maven') await save('maven')
expect(spyCacheSave).toHaveBeenCalled() expect(cache.saveCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
expect(spyInfo).toHaveBeenCalled() expect(core.info).toHaveBeenCalled()
expect(spyInfo).toHaveBeenCalledWith(expect.stringMatching(/^Cache saved with the key:.*/)) expect(core.info).toHaveBeenCalledWith(expect.stringMatching(/^Cache saved with the key:.*/))
}) })
it('saves with error from toolkit, should fail workflow', async () => { it('saves with error from toolkit, should fail workflow', async () => {
spyCacheSave.mockImplementation(() => Promise.reject(new cache.ValidationError('Validation failed'))) cache.saveCache.mockImplementation(() => Promise.reject(new cache.ValidationError('Validation failed')))
createStateForMissingBuildFile() createStateForMissingBuildFile()
expect.assertions(1) expect.assertions(1)
@@ -205,24 +192,24 @@ describe('dependency cache', () => {
it('uploads cache even if no pom.xml found', async () => { it('uploads cache even if no pom.xml found', async () => {
createStateForMissingBuildFile() createStateForMissingBuildFile()
await save('maven') await save('maven')
expect(spyCacheSave).toHaveBeenCalled() expect(cache.saveCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
}) })
it('does not upload cache if no restore run before', async () => { it('does not upload cache if no restore run before', async () => {
createFile(join(workspace, 'pom.xml')) createFile(join(workspace, 'pom.xml'))
await save('maven') await save('maven')
expect(spyCacheSave).not.toHaveBeenCalled() expect(cache.saveCache).not.toHaveBeenCalled()
expect(spyWarning).toHaveBeenCalledWith('Error retrieving key from state.') expect(core.warning).toHaveBeenCalledWith('Error retrieving key from state.')
}) })
it('uploads cache', async () => { it('uploads cache', async () => {
createFile(join(workspace, 'pom.xml')) createFile(join(workspace, 'pom.xml'))
createStateForSuccessfulRestore() createStateForSuccessfulRestore()
await save('maven') await save('maven')
expect(spyCacheSave).toHaveBeenCalled() expect(cache.saveCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
expect(spyInfo).toHaveBeenCalledWith(expect.stringMatching(/^Cache saved with the key:.*/)) expect(core.info).toHaveBeenCalledWith(expect.stringMatching(/^Cache saved with the key:.*/))
}) })
}) })
describe('for gradle', () => { describe('for gradle', () => {
@@ -230,33 +217,33 @@ describe('dependency cache', () => {
createStateForMissingBuildFile() createStateForMissingBuildFile()
await save('gradle') await save('gradle')
expect(spyCacheSave).toHaveBeenCalled() expect(cache.saveCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
}) })
it('does not upload cache if no restore run before', async () => { it('does not upload cache if no restore run before', async () => {
createFile(join(workspace, 'build.gradle')) createFile(join(workspace, 'build.gradle'))
await save('gradle') await save('gradle')
expect(spyCacheSave).not.toHaveBeenCalled() expect(cache.saveCache).not.toHaveBeenCalled()
expect(spyWarning).toHaveBeenCalledWith('Error retrieving key from state.') expect(core.warning).toHaveBeenCalledWith('Error retrieving key from state.')
}) })
it('uploads cache based on build.gradle', async () => { it('uploads cache based on build.gradle', async () => {
createFile(join(workspace, 'build.gradle')) createFile(join(workspace, 'build.gradle'))
createStateForSuccessfulRestore() createStateForSuccessfulRestore()
await save('gradle') await save('gradle')
expect(spyCacheSave).toHaveBeenCalled() expect(cache.saveCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
expect(spyInfo).toHaveBeenCalledWith(expect.stringMatching(/^Cache saved with the key:.*/)) expect(core.info).toHaveBeenCalledWith(expect.stringMatching(/^Cache saved with the key:.*/))
}) })
it('uploads cache based on build.gradle.kts', async () => { it('uploads cache based on build.gradle.kts', async () => {
createFile(join(workspace, 'build.gradle.kts')) createFile(join(workspace, 'build.gradle.kts'))
createStateForSuccessfulRestore() createStateForSuccessfulRestore()
await save('gradle') await save('gradle')
expect(spyCacheSave).toHaveBeenCalled() expect(cache.saveCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
expect(spyInfo).toHaveBeenCalledWith(expect.stringMatching(/^Cache saved with the key:.*/)) expect(core.info).toHaveBeenCalledWith(expect.stringMatching(/^Cache saved with the key:.*/))
}) })
it('uploads cache based on buildSrc/Versions.kt', async () => { it('uploads cache based on buildSrc/Versions.kt', async () => {
createDirectory(join(workspace, 'buildSrc')) createDirectory(join(workspace, 'buildSrc'))
@@ -264,47 +251,47 @@ describe('dependency cache', () => {
createStateForSuccessfulRestore() createStateForSuccessfulRestore()
await save('gradle') await save('gradle')
expect(spyCacheSave).toHaveBeenCalled() expect(cache.saveCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
expect(spyInfo).toHaveBeenCalledWith(expect.stringMatching(/^Cache saved with the key:.*/)) expect(core.info).toHaveBeenCalledWith(expect.stringMatching(/^Cache saved with the key:.*/))
}) })
}) })
describe('for sbt', () => { describe('for sbt', () => {
it('uploads cache even if no build.sbt found', async () => { it('uploads cache even if no build.sbt found', async () => {
createStateForMissingBuildFile() createStateForMissingBuildFile()
await save('sbt') await save('sbt')
expect(spyCacheSave).toHaveBeenCalled() expect(cache.saveCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
}) })
it('does not upload cache if no restore run before', async () => { it('does not upload cache if no restore run before', async () => {
createFile(join(workspace, 'build.sbt')) createFile(join(workspace, 'build.sbt'))
await save('sbt') await save('sbt')
expect(spyCacheSave).not.toHaveBeenCalled() expect(cache.saveCache).not.toHaveBeenCalled()
expect(spyWarning).toHaveBeenCalledWith('Error retrieving key from state.') expect(core.warning).toHaveBeenCalledWith('Error retrieving key from state.')
}) })
it('uploads cache', async () => { it('uploads cache', async () => {
createFile(join(workspace, 'build.sbt')) createFile(join(workspace, 'build.sbt'))
createStateForSuccessfulRestore() createStateForSuccessfulRestore()
await save('sbt') await save('sbt')
expect(spyCacheSave).toHaveBeenCalled() expect(cache.saveCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
expect(spyInfo).toHaveBeenCalledWith(expect.stringMatching(/^Cache saved with the key:.*/)) expect(core.info).toHaveBeenCalledWith(expect.stringMatching(/^Cache saved with the key:.*/))
}) })
}) })
}) })
}) })
function resetState() { function resetState() {
jest.spyOn(core, 'getState').mockReset() core.getState.mockReset()
} }
/** /**
* Create states to emulate a restore process without build file. * Create states to emulate a restore process without build file.
*/ */
function createStateForMissingBuildFile() { function createStateForMissingBuildFile() {
jest.spyOn(core, 'getState').mockImplementation((name) => { core.getState.mockImplementation((name) => {
switch (name) { switch (name) {
case 'cache-primary-key': case 'cache-primary-key':
return 'setup-graalvm-cache-' return 'setup-graalvm-cache-'
@@ -318,7 +305,7 @@ function createStateForMissingBuildFile() {
* Create states to emulate a successful restore process. * Create states to emulate a successful restore process.
*/ */
function createStateForSuccessfulRestore() { function createStateForSuccessfulRestore() {
jest.spyOn(core, 'getState').mockImplementation((name) => { core.getState.mockImplementation((name) => {
switch (name) { switch (name) {
case 'cache-primary-key': case 'cache-primary-key':
return 'setup-graalvm-cache-primary-key' return 'setup-graalvm-cache-primary-key'

View File

@@ -24,21 +24,23 @@
* Forked from https://github.com/actions/setup-java/blob/5b36705a13905facb447b6812d613a06a07e371d/__tests__/cleanup-java.test.ts * Forked from https://github.com/actions/setup-java/blob/5b36705a13905facb447b6812d613a06a07e371d/__tests__/cleanup-java.test.ts
*/ */
import { run as cleanup } from '../src/cleanup' import { jest } from '@jest/globals'
import * as core from '@actions/core' import * as cache from '../__fixtures__/cache.js'
import * as cache from '@actions/cache' import * as core from '../__fixtures__/core.js'
// Mocks should be declared before the module being tested is imported.
jest.unstable_mockModule('@actions/core', () => core)
jest.unstable_mockModule('@actions/cache', () => cache)
// The module being tested should be imported dynamically. This ensures that the
// mocks are used in place of any actual dependencies.
const { run } = await import('../src/cleanup.js')
describe('cleanup', () => { describe('cleanup', () => {
let spyWarning: jest.SpyInstance<void, Parameters<typeof core.warning>>
let spyInfo: jest.SpyInstance<void, Parameters<typeof core.info>>
let spyCacheSave: jest.SpyInstance<ReturnType<typeof cache.saveCache>, Parameters<typeof cache.saveCache>>
beforeEach(() => { beforeEach(() => {
spyWarning = jest.spyOn(core, 'warning') core.info.mockImplementation(() => null)
spyWarning.mockImplementation(() => null) core.warning.mockImplementation(() => null)
spyInfo = jest.spyOn(core, 'info') core.debug.mockImplementation(() => null)
spyInfo.mockImplementation(() => null)
spyCacheSave = jest.spyOn(cache, 'saveCache')
createStateForSuccessfulRestore() createStateForSuccessfulRestore()
}) })
afterEach(() => { afterEach(() => {
@@ -46,38 +48,40 @@ describe('cleanup', () => {
}) })
it('does not fail nor warn even when the save process throws a ReserveCacheError', async () => { it('does not fail nor warn even when the save process throws a ReserveCacheError', async () => {
spyCacheSave.mockImplementation((_paths: string[], _key: string) => cache.saveCache.mockImplementation((_paths: string[], _key: string) =>
Promise.reject( Promise.reject(
new cache.ReserveCacheError('Unable to reserve cache with key, another job may be creating this cache.') new cache.ReserveCacheError('Unable to reserve cache with key, another job may be creating this cache.')
) )
) )
jest.spyOn(core, 'getInput').mockImplementation((name: string) => { core.getInput.mockImplementation((name: string) => {
return name === 'cache' ? 'gradle' : '' return name === 'cache' ? 'gradle' : ''
}) })
await cleanup() await run()
expect(spyCacheSave).toHaveBeenCalled() expect(cache.saveCache).toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
}) })
it('does not fail even though the save process throws error', async () => { it('does not fail even though the save process throws error', async () => {
spyCacheSave.mockImplementation((_paths: string[], _key: string) => Promise.reject(new Error('Unexpected error'))) cache.saveCache.mockImplementation((_paths: string[], _key: string) =>
jest.spyOn(core, 'getInput').mockImplementation((name: string) => { Promise.reject(new Error('Unexpected error'))
)
core.getInput.mockImplementation((name: string) => {
return name === 'cache' ? 'gradle' : '' return name === 'cache' ? 'gradle' : ''
}) })
await cleanup() await run()
expect(spyCacheSave).toHaveBeenCalled() expect(cache.saveCache).toHaveBeenCalled()
}) })
}) })
function resetState() { function resetState() {
jest.spyOn(core, 'getState').mockReset() core.getState.mockReset()
} }
/** /**
* Create states to emulate a successful restore process. * Create states to emulate a successful restore process.
*/ */
function createStateForSuccessfulRestore() { function createStateForSuccessfulRestore() {
jest.spyOn(core, 'getState').mockImplementation((name) => { core.getState.mockImplementation((name) => {
switch (name) { switch (name) {
case 'cache-primary-key': case 'cache-primary-key':
return 'setup-java-cache-primary-key' return 'setup-java-cache-primary-key'

View File

@@ -1,10 +1,12 @@
import * as path from 'path' import * as path from 'path'
import { downloadGraalVM, downloadGraalVMEELegacy, fetchArtifact, fetchArtifactEE } from '../src/gds' import { downloadGraalVM, downloadGraalVMEELegacy, fetchArtifact, fetchArtifactEE } from '../src/gds'
import { expect, test } from '@jest/globals' import { expect, test } from '@jest/globals'
import { fileURLToPath } from 'url'
const TEST_USER_AGENT = 'GraalVMGitHubActionTest/1.0.4' const TEST_USER_AGENT = 'GraalVMGitHubActionTest/1.0.4'
process.env['RUNNER_TEMP'] = path.join(__dirname, 'TEMP') const dirname = path.dirname(fileURLToPath(import.meta.url))
process.env['RUNNER_TEMP'] = path.join(dirname, 'TEMP')
test('fetch artifacts', async () => { test('fetch artifacts', async () => {
let artifact = await fetchArtifact(TEST_USER_AGENT, 'isBase:True', '17.0.12') let artifact = await fetchArtifact(TEST_USER_AGENT, 'isBase:True', '17.0.12')

View File

@@ -4,9 +4,11 @@ import { expect, test } from '@jest/globals'
import { getTaggedRelease } from '../src/utils' import { getTaggedRelease } from '../src/utils'
import { findGraalVMVersion, findHighestJavaVersion, findLatestEABuildDownloadUrl } from '../src/graalvm' import { findGraalVMVersion, findHighestJavaVersion, findLatestEABuildDownloadUrl } from '../src/graalvm'
import { GRAALVM_GH_USER, GRAALVM_RELEASES_REPO } from '../src/constants' import { GRAALVM_GH_USER, GRAALVM_RELEASES_REPO } from '../src/constants'
import { fileURLToPath } from 'url'
process.env['RUNNER_TOOL_CACHE'] = path.join(__dirname, 'TOOL_CACHE') const dirname = path.dirname(fileURLToPath(import.meta.url))
process.env['RUNNER_TEMP'] = path.join(__dirname, 'TEMP') process.env['RUNNER_TOOL_CACHE'] = path.join(dirname, 'TOOL_CACHE')
process.env['RUNNER_TEMP'] = path.join(dirname, 'TEMP')
test('request invalid version/javaVersion', async () => { test('request invalid version/javaVersion', async () => {
for (const combination of [ for (const combination of [

View File

@@ -3,9 +3,11 @@ import * as c from '../src/constants'
import * as path from 'path' import * as path from 'path'
import * as semver from 'semver' import * as semver from 'semver'
import { expect, test } from '@jest/globals' import { expect, test } from '@jest/globals'
import { fileURLToPath } from 'url'
process.env['RUNNER_TOOL_CACHE'] = path.join(__dirname, 'TOOL_CACHE') const dirname = path.dirname(fileURLToPath(import.meta.url))
process.env['RUNNER_TEMP'] = path.join(__dirname, 'TEMP') process.env['RUNNER_TOOL_CACHE'] = path.join(dirname, 'TOOL_CACHE')
process.env['RUNNER_TEMP'] = path.join(dirname, 'TEMP')
/* eslint jest/expect-expect: ["error", { "assertFunctionNames": ["expect", "expectLatestToBe", "expectURL"] }] */ /* eslint jest/expect-expect: ["error", { "assertFunctionNames": ["expect", "expectLatestToBe", "expectURL"] }] */

View File

@@ -2,9 +2,11 @@ import * as path from 'path'
import * as mandrel from '../src/mandrel' import * as mandrel from '../src/mandrel'
import { expect, test } from '@jest/globals' import { expect, test } from '@jest/globals'
import { getLatestRelease } from '../src/utils' import { getLatestRelease } from '../src/utils'
import { fileURLToPath } from 'url'
process.env['RUNNER_TOOL_CACHE'] = path.join(__dirname, 'TOOL_CACHE') const dirname = path.dirname(fileURLToPath(import.meta.url))
process.env['RUNNER_TEMP'] = path.join(__dirname, 'TEMP') process.env['RUNNER_TOOL_CACHE'] = path.join(dirname, 'TOOL_CACHE')
process.env['RUNNER_TEMP'] = path.join(dirname, 'TEMP')
test('request invalid version/javaVersion combination', async () => { test('request invalid version/javaVersion combination', async () => {
for (const combination of [ for (const combination of [

View File

@@ -2,9 +2,11 @@ import * as path from 'path'
import { expect, test } from '@jest/globals' import { expect, test } from '@jest/globals'
import { needsWindowsEnvironmentSetup } from '../src/msvc' import { needsWindowsEnvironmentSetup } from '../src/msvc'
import { VERSION_DEV, VERSION_LATEST } from '../src/constants' import { VERSION_DEV, VERSION_LATEST } from '../src/constants'
import { fileURLToPath } from 'url'
process.env['RUNNER_TOOL_CACHE'] = path.join(__dirname, 'TOOL_CACHE') const dirname = path.dirname(fileURLToPath(import.meta.url))
process.env['RUNNER_TEMP'] = path.join(__dirname, 'TEMP') process.env['RUNNER_TOOL_CACHE'] = path.join(dirname, 'TOOL_CACHE')
process.env['RUNNER_TEMP'] = path.join(dirname, 'TEMP')
test('decide whether Window env must be set up for GraalVM for JDK', async () => { test('decide whether Window env must be set up for GraalVM for JDK', async () => {
for (const javaVersion of ['17', '17.0.8', '17.0', '21', '22', '22-ea', '23-ea', VERSION_DEV]) { for (const javaVersion of ['17', '17.0.8', '17.0', '21', '22', '22-ea', '23-ea', VERSION_DEV]) {

View File

@@ -1,55 +1,37 @@
/* eslint-disable @typescript-eslint/no-explicit-any */
import * as c from '../src/constants' import * as c from '../src/constants'
import { setUpSBOMSupport, processSBOM } from '../src/features/sbom'
import * as core from '@actions/core'
import * as github from '@actions/github'
import * as glob from '@actions/glob'
import { join } from 'path' import { join } from 'path'
import { tmpdir } from 'os' import { tmpdir } from 'os'
import { expect, jest } from '@jest/globals'
import { mkdtempSync, writeFileSync, rmSync } from 'fs' import { mkdtempSync, writeFileSync, rmSync } from 'fs'
import * as core from '../__fixtures__/core.js'
import * as glob from '../__fixtures__/glob.js'
import * as github from '../__fixtures__/github.js'
jest.mock('@actions/glob') // Mocks should be declared before the module being tested is imported.
jest.mock('@actions/github', () => ({ jest.unstable_mockModule('@actions/core', () => core)
getOctokit: jest.fn(() => ({ jest.unstable_mockModule('@actions/glob', () => glob)
request: jest.fn().mockResolvedValue(undefined) jest.unstable_mockModule('@actions/github', () => github)
})),
context: { // The module being tested should be imported dynamically. This ensures that the
repo: { // mocks are used in place of any actual dependencies.
owner: 'test-owner', const { setUpSBOMSupport, processSBOM } = await import('../src/features/sbom.js')
repo: 'test-repo'
},
sha: 'test-sha',
ref: 'test-ref',
workflow: 'test-workflow',
job: 'test-job',
runId: '12345'
}
}))
function mockFindSBOM(files: string[]) { function mockFindSBOM(files: string[]) {
const mockCreate = jest.fn().mockResolvedValue({ glob.create.mockImplementation(
glob: jest.fn().mockResolvedValue(files) jest.fn<() => Promise<any>>().mockResolvedValue({
glob: jest.fn<() => Promise<string[]>>().mockResolvedValue(files)
}) })
;(glob.create as jest.Mock).mockImplementation(mockCreate) )
} }
// Mocks the GitHub dependency submission API return value const request = jest.fn<any>().mockResolvedValue(undefined)
// 'undefined' is treated as a successful request
function mockGithubAPIReturnValue(returnValue: Error | undefined = undefined) {
const mockOctokit = {
request:
returnValue === undefined ? jest.fn().mockResolvedValue(returnValue) : jest.fn().mockRejectedValue(returnValue)
}
;(github.getOctokit as jest.Mock).mockReturnValue(mockOctokit)
return mockOctokit
}
describe('sbom feature', () => { describe('sbom feature', () => {
let spyInfo: jest.SpyInstance<void, Parameters<typeof core.info>>
let spyWarning: jest.SpyInstance<void, Parameters<typeof core.warning>>
let spyExportVariable: jest.SpyInstance<void, Parameters<typeof core.exportVariable>>
let workspace: string let workspace: string
let originalEnv: NodeJS.ProcessEnv let originalEnv: NodeJS.ProcessEnv
const javaVersion = '24.0.0' const javaVersion = '25.0.0'
const distribution = c.DISTRIBUTION_GRAALVM const distribution = c.DISTRIBUTION_GRAALVM
beforeEach(() => { beforeEach(() => {
@@ -62,12 +44,11 @@ describe('sbom feature', () => {
} }
workspace = mkdtempSync(join(tmpdir(), 'setup-graalvm-sbom-')) workspace = mkdtempSync(join(tmpdir(), 'setup-graalvm-sbom-'))
mockGithubAPIReturnValue()
spyInfo = jest.spyOn(core, 'info').mockImplementation(() => null) core.info.mockImplementation(() => null)
spyWarning = jest.spyOn(core, 'warning').mockImplementation(() => null) core.warning.mockImplementation(() => null)
spyExportVariable = jest.spyOn(core, 'exportVariable').mockImplementation(() => null) core.debug.mockImplementation(() => null)
jest.spyOn(core, 'getInput').mockImplementation((name: string) => { core.getInput.mockImplementation((name: string) => {
if (name === 'native-image-enable-sbom') { if (name === 'native-image-enable-sbom') {
return 'true' return 'true'
} }
@@ -76,14 +57,17 @@ describe('sbom feature', () => {
} }
return '' return ''
}) })
github.getOctokit.mockImplementation(
jest.fn<any>(() => ({
request: request
}))
)
}) })
afterEach(() => { afterEach(() => {
process.env = originalEnv process.env = originalEnv
jest.clearAllMocks() jest.clearAllMocks()
spyInfo.mockRestore()
spyWarning.mockRestore()
spyExportVariable.mockRestore()
rmSync(workspace, { recursive: true, force: true }) rmSync(workspace, { recursive: true, force: true })
}) })
@@ -108,7 +92,7 @@ describe('sbom feature', () => {
}) })
it('should not throw an error when the java-version is supported', () => { it('should not throw an error when the java-version is supported', () => {
const supported_versions = ['24', '24-ea', '24.0.2', 'latest-ea'] const supported_versions = ['25', '26-ea', 'latest-ea']
for (const version of supported_versions) { for (const version of supported_versions) {
expect(() => setUpSBOMSupport(version, distribution)).not.toThrow() expect(() => setUpSBOMSupport(version, distribution)).not.toThrow()
} }
@@ -117,35 +101,35 @@ describe('sbom feature', () => {
it('should set the SBOM option when activated', () => { it('should set the SBOM option when activated', () => {
setUpSBOMSupport(javaVersion, distribution) setUpSBOMSupport(javaVersion, distribution)
expect(spyExportVariable).toHaveBeenCalledWith( expect(core.exportVariable).toHaveBeenCalledWith(
c.NATIVE_IMAGE_OPTIONS_ENV, c.NATIVE_IMAGE_OPTIONS_ENV,
expect.stringContaining('--enable-sbom=export') expect.stringContaining('--enable-sbom=export')
) )
expect(spyInfo).toHaveBeenCalledWith('Enabled SBOM generation for Native Image build') expect(core.info).toHaveBeenCalledWith('Enabled SBOM generation for Native Image build')
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
}) })
it('should not set the SBOM option when not activated', () => { it('should not set the SBOM option when not activated', () => {
jest.spyOn(core, 'getInput').mockReturnValue('false') core.getInput.mockReturnValue('false')
setUpSBOMSupport(javaVersion, distribution) setUpSBOMSupport(javaVersion, distribution)
expect(spyExportVariable).not.toHaveBeenCalled() expect(core.exportVariable).not.toHaveBeenCalled()
expect(spyInfo).not.toHaveBeenCalled() expect(core.info).not.toHaveBeenCalled()
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
}) })
}) })
describe('process', () => { describe('process', () => {
async function setUpAndProcessSBOM(sbom: object): Promise<void> { async function setUpAndProcessSBOM(sbom: object): Promise<void> {
setUpSBOMSupport(javaVersion, distribution) setUpSBOMSupport(javaVersion, distribution)
spyInfo.mockClear() core.info.mockClear()
// Mock 'native-image' invocation by creating the SBOM file // Mock 'native-image' invocation by creating the SBOM file
const sbomPath = join(workspace, 'test.sbom.json') const sbomPath = join(workspace, 'test.sbom.json')
writeFileSync(sbomPath, JSON.stringify(sbom, null, 2)) writeFileSync(sbomPath, JSON.stringify(sbom, null, 2))
mockFindSBOM([sbomPath]) mockFindSBOM([sbomPath])
jest.spyOn(core, 'getState').mockReturnValue(javaVersion) core.getState.mockReturnValue(javaVersion)
await processSBOM() await processSBOM()
} }
@@ -160,13 +144,13 @@ describe('sbom feature', () => {
type: 'library', type: 'library',
group: 'org.json', group: 'org.json',
name: 'json', name: 'json',
version: '20241224', version: '20250517',
purl: 'pkg:maven/org.json/json@20241224', purl: 'pkg:maven/org.json/json@20250517',
'bom-ref': 'pkg:maven/org.json/json@20241224', 'bom-ref': 'pkg:maven/org.json/json@20250517',
properties: [ properties: [
{ {
name: 'syft:cpe23', name: 'syft:cpe23',
value: 'cpe:2.3:a:json:json:20241224:*:*:*:*:*:*:*' value: 'cpe:2.3:a:json:json:20250517:*:*:*:*:*:*:*'
} }
] ]
}, },
@@ -182,10 +166,10 @@ describe('sbom feature', () => {
dependencies: [ dependencies: [
{ {
ref: 'pkg:maven/com.oracle/main-test-app@1.0-SNAPSHOT', ref: 'pkg:maven/com.oracle/main-test-app@1.0-SNAPSHOT',
dependsOn: ['pkg:maven/org.json/json@20241224'] dependsOn: ['pkg:maven/org.json/json@20250517']
}, },
{ {
ref: 'pkg:maven/org.json/json@20241224', ref: 'pkg:maven/org.json/json@20250517',
dependsOn: [] dependsOn: []
} }
] ]
@@ -198,12 +182,12 @@ describe('sbom feature', () => {
it('should process SBOM and display components', async () => { it('should process SBOM and display components', async () => {
await setUpAndProcessSBOM(sampleSBOM) await setUpAndProcessSBOM(sampleSBOM)
expect(spyInfo).toHaveBeenCalledWith('Found SBOM: ' + join(workspace, 'test.sbom.json')) expect(core.info).toHaveBeenCalledWith('Found SBOM: ' + join(workspace, 'test.sbom.json'))
expect(spyInfo).toHaveBeenCalledWith('=== SBOM Content ===') expect(core.info).toHaveBeenCalledWith('=== SBOM Content ===')
expect(spyInfo).toHaveBeenCalledWith('- pkg:maven/org.json/json@20241224') expect(core.info).toHaveBeenCalledWith('- pkg:maven/org.json/json@20250517')
expect(spyInfo).toHaveBeenCalledWith('- pkg:maven/com.oracle/main-test-app@1.0-SNAPSHOT') expect(core.info).toHaveBeenCalledWith('- pkg:maven/com.oracle/main-test-app@1.0-SNAPSHOT')
expect(spyInfo).toHaveBeenCalledWith(' depends on: pkg:maven/org.json/json@20241224') expect(core.info).toHaveBeenCalledWith(' depends on: pkg:maven/org.json/json@20250517')
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
}) })
it('should handle components without purl', async () => { it('should handle components without purl', async () => {
@@ -220,14 +204,14 @@ describe('sbom feature', () => {
} }
await setUpAndProcessSBOM(sbomWithoutPurl) await setUpAndProcessSBOM(sbomWithoutPurl)
expect(spyInfo).toHaveBeenCalledWith('=== SBOM Content ===') expect(core.info).toHaveBeenCalledWith('=== SBOM Content ===')
expect(spyInfo).toHaveBeenCalledWith('- no-purl-package@1.0.0') expect(core.info).toHaveBeenCalledWith('- no-purl-package@1.0.0')
expect(spyWarning).not.toHaveBeenCalled() expect(core.warning).not.toHaveBeenCalled()
}) })
it('should handle missing SBOM file', async () => { it('should handle missing SBOM file', async () => {
setUpSBOMSupport(javaVersion, distribution) setUpSBOMSupport(javaVersion, distribution)
spyInfo.mockClear() core.info.mockClear()
mockFindSBOM([]) mockFindSBOM([])
@@ -250,10 +234,9 @@ describe('sbom feature', () => {
}) })
it('should submit dependencies when processing valid SBOM', async () => { it('should submit dependencies when processing valid SBOM', async () => {
const mockOctokit = mockGithubAPIReturnValue(undefined)
await setUpAndProcessSBOM(sampleSBOM) await setUpAndProcessSBOM(sampleSBOM)
expect(mockOctokit.request).toHaveBeenCalledWith( expect(request).toHaveBeenCalledWith(
'POST /repos/{owner}/{repo}/dependency-graph/snapshots', 'POST /repos/{owner}/{repo}/dependency-graph/snapshots',
expect.objectContaining({ expect.objectContaining({
owner: 'test-owner', owner: 'test-owner',
@@ -270,23 +253,27 @@ describe('sbom feature', () => {
name: 'test.sbom.json', name: 'test.sbom.json',
resolved: expect.objectContaining({ resolved: expect.objectContaining({
json: expect.objectContaining({ json: expect.objectContaining({
package_url: 'pkg:maven/org.json/json@20241224', package_url: 'pkg:maven/org.json/json@20250517',
dependencies: [] dependencies: []
}), }),
'main-test-app': expect.objectContaining({ 'main-test-app': expect.objectContaining({
package_url: 'pkg:maven/com.oracle/main-test-app@1.0-SNAPSHOT', package_url: 'pkg:maven/com.oracle/main-test-app@1.0-SNAPSHOT',
dependencies: ['pkg:maven/org.json/json@20241224'] dependencies: ['pkg:maven/org.json/json@20250517']
}) })
}) })
}) })
}) })
}) })
) )
expect(spyInfo).toHaveBeenCalledWith('Dependency snapshot submitted successfully.') expect(core.info).toHaveBeenCalledWith('Dependency snapshot submitted successfully.')
}) })
it('should handle GitHub API submission errors gracefully', async () => { it('should handle GitHub API submission errors gracefully', async () => {
mockGithubAPIReturnValue(new Error('API submission failed')) github.getOctokit.mockImplementation(
jest.fn<any>(() => ({
request: jest.fn<(a: any, b: any) => Promise<any>>().mockRejectedValue(new Error('API submission failed'))
}))
)
await expect(setUpAndProcessSBOM(sampleSBOM)).rejects.toBeInstanceOf(Error) await expect(setUpAndProcessSBOM(sampleSBOM)).rejects.toBeInstanceOf(Error)
}) })

View File

@@ -17,7 +17,7 @@
<dependency> <dependency>
<groupId>org.json</groupId> <groupId>org.json</groupId>
<artifactId>json</artifactId> <artifactId>json</artifactId>
<version>20241224</version> <version>20250517</version>
</dependency> </dependency>
</dependencies> </dependencies>
@@ -29,7 +29,7 @@
<plugin> <plugin>
<groupId>org.graalvm.buildtools</groupId> <groupId>org.graalvm.buildtools</groupId>
<artifactId>native-maven-plugin</artifactId> <artifactId>native-maven-plugin</artifactId>
<version>0.10.3</version> <version>0.11.0</version>
<executions> <executions>
<execution> <execution>
<goals> <goals>

View File

@@ -2,7 +2,7 @@
set "SCRIPT_DIR=%~dp0" set "SCRIPT_DIR=%~dp0"
for %%p in ( for %%p in (
"\"pkg:maven/org.json/json@20241224\"" "\"pkg:maven/org.json/json@20250517\""
"\"main-test-app\"" "\"main-test-app\""
"\"svm\"" "\"svm\""
"\"nativeimage\"" "\"nativeimage\""

View File

@@ -2,7 +2,7 @@
script_dir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" script_dir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
required_patterns=( required_patterns=(
'"pkg:maven/org.json/json@20241224"' '"pkg:maven/org.json/json@20250517"'
'"main-test-app"' '"main-test-app"'
'"svm"' '"svm"'
'"nativeimage"' '"nativeimage"'

View File

@@ -72,6 +72,6 @@ outputs:
description: 'A boolean value to indicate an exact match was found for the primary key' description: 'A boolean value to indicate an exact match was found for the primary key'
runs: runs:
using: 'node20' using: 'node20'
main: 'dist/main/index.js' main: 'dist/main.js'
post: 'dist/cleanup/index.js' post: 'dist/cleanup.js'
post-if: 'success()' post-if: 'success()'

118636
dist/main/index.js → dist/cleanup.js generated vendored

File diff suppressed because one or more lines are too long

119534
dist/cleanup/index.js → dist/main.js generated vendored

File diff suppressed because one or more lines are too long

View File

@@ -53,7 +53,7 @@ export default [
parserOptions: { parserOptions: {
project: ['tsconfig.eslint.json'], project: ['tsconfig.eslint.json'],
tsconfigRootDir: '.' tsconfigRootDir: __dirname
} }
}, },

View File

@@ -1,14 +1,29 @@
module.exports = { // See: https://jestjs.io/docs/configuration
/** @type {import('ts-jest').JestConfigWithTsJest} **/
export default {
clearMocks: true, clearMocks: true,
collectCoverage: true, collectCoverage: true,
collectCoverageFrom: ['./src/**'], collectCoverageFrom: ['./src/**'],
coverageDirectory: './coverage', coverageDirectory: './coverage',
coveragePathIgnorePatterns: ['/node_modules/', '/dist/'], coveragePathIgnorePatterns: ['/node_modules/', '/dist/'],
coverageReporters: ['json-summary', 'text', 'lcov'], coverageReporters: ['json-summary', 'text', 'lcov'],
moduleFileExtensions: ['js', 'ts'], extensionsToTreatAsEsm: ['.ts'],
moduleFileExtensions: ['ts', 'js'],
preset: 'ts-jest',
reporters: ['default'],
resolver: 'ts-jest-resolver',
testEnvironment: 'node',
testMatch: ['**/*.test.ts'], testMatch: ['**/*.test.ts'],
testPathIgnorePatterns: ['/dist/', '/node_modules/'],
transform: { transform: {
'^.+\\.ts$': 'ts-jest' '^.+\\.ts$': [
'ts-jest',
{
tsconfig: 'tsconfig.eslint.json',
useESM: true
}
]
}, },
verbose: true verbose: true
} }

1729
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -2,7 +2,8 @@
"name": "setup-graalvm", "name": "setup-graalvm",
"author": "GraalVM Community", "author": "GraalVM Community",
"description": "GitHub Action for GraalVM", "description": "GitHub Action for GraalVM",
"version": "1.3.6", "version": "1.4.0",
"type": "module",
"private": true, "private": true,
"repository": { "repository": {
"type": "git", "type": "git",
@@ -17,6 +18,9 @@
"actions", "actions",
"setup" "setup"
], ],
"exports": {
".": "./dist/index.js"
},
"engines": { "engines": {
"node": ">=20" "node": ">=20"
}, },
@@ -26,9 +30,9 @@
"format:check": "npx prettier --check .", "format:check": "npx prettier --check .",
"lint": "npx eslint .", "lint": "npx eslint .",
"package": "npm run package:main && npm run package:cleanup", "package": "npm run package:main && npm run package:cleanup",
"package:main": "npx ncc build src/main.ts -o dist/main", "package:main": "npx rollup --config rollup.main.config.ts --configPlugin @rollup/plugin-typescript",
"package:cleanup": "npx ncc build src/cleanup.ts -o dist/cleanup", "package:cleanup": "npx rollup --config rollup.cleanup.config.ts --configPlugin @rollup/plugin-typescript",
"test": "npx jest", "test": "NODE_OPTIONS=--experimental-vm-modules NODE_NO_WARNINGS=1 npx jest",
"all": "npm run format:write && npm run lint && npm run test && npm run package" "all": "npm run format:write && npm run lint && npm run test && npm run package"
}, },
"license": "UPL", "license": "UPL",
@@ -44,31 +48,44 @@
"@octokit/types": "^14.1.0", "@octokit/types": "^14.1.0",
"@github/dependency-submission-toolkit": "^2.0.5", "@github/dependency-submission-toolkit": "^2.0.5",
"semver": "^7.7.2", "semver": "^7.7.2",
"uuid": "^11.1.0" "uuid": "^13.0.0"
}, },
"devDependencies": { "devDependencies": {
"@eslint/compat": "^1.3.1", "@eslint/compat": "^1.3.2",
"@rollup/plugin-commonjs": "^28.0.6",
"@rollup/plugin-json": "^6.1.0",
"@rollup/plugin-node-resolve": "^16.0.1",
"@rollup/plugin-typescript": "^12.1.4",
"@types/jest": "^30.0.0", "@types/jest": "^30.0.0",
"@types/node": "^20.19.9", "@types/node": "^24.4.0",
"@types/semver": "^7.7.0", "@types/semver": "^7.7.1",
"@types/uuid": "^10.0.0", "@types/uuid": "^10.0.0",
"@typescript-eslint/eslint-plugin": "^8.38.0", "@typescript-eslint/eslint-plugin": "^8.43.0",
"@typescript-eslint/parser": "^8.31.1", "@typescript-eslint/parser": "^8.31.1",
"@vercel/ncc": "^0.38.3", "eslint": "^9.35.0",
"eslint": "^9.31.0",
"eslint-config-prettier": "^10.1.8", "eslint-config-prettier": "^10.1.8",
"eslint-import-resolver-typescript": "^4.4.4", "eslint-import-resolver-typescript": "^4.4.4",
"eslint-plugin-import": "^2.32.0", "eslint-plugin-import": "^2.32.0",
"eslint-plugin-jest": "^29.0.1", "eslint-plugin-jest": "^29.0.1",
"eslint-plugin-jsonc": "^2.20.1", "eslint-plugin-jsonc": "^2.20.1",
"eslint-plugin-node": "^11.1.0", "eslint-plugin-node": "^11.1.0",
"eslint-plugin-prettier": "^5.5.3", "eslint-plugin-prettier": "^5.5.4",
"jest": "^30.0.5", "jest": "^30.1.3",
"js-yaml": "^4.1.0", "js-yaml": "^4.1.0",
"prettier": "^3.6.2", "prettier": "^3.6.2",
"prettier-eslint": "^16.4.2", "prettier-eslint": "^16.4.2",
"ts-jest": "^29.4.0", "rollup": "^4.50.2",
"ts-jest": "^29.4.1",
"ts-jest-resolver": "^2.0.1",
"ts-node": "^10.9.2", "ts-node": "^10.9.2",
"typescript": "^5.8.3" "typescript": "^5.9.2"
},
"optionalDependencies": {
"@rollup/rollup-linux-x64-gnu": "*"
},
"overrides": {
"@actions/glob": {
"minimatch": "^10.0.1"
}
} }
} }

19
rollup.cleanup.config.ts Normal file
View File

@@ -0,0 +1,19 @@
// See: https://rollupjs.org/introduction/
import commonjs from '@rollup/plugin-commonjs'
import json from '@rollup/plugin-json'
import nodeResolve from '@rollup/plugin-node-resolve'
import typescript from '@rollup/plugin-typescript'
const config = {
input: 'src/cleanup.ts',
output: {
esModule: true,
file: 'dist/cleanup.js',
format: 'es',
sourcemap: false
},
plugins: [typescript(), nodeResolve({ preferBuiltins: true }), commonjs(), json()]
}
export default config

19
rollup.main.config.ts Normal file
View File

@@ -0,0 +1,19 @@
// See: https://rollupjs.org/introduction/
import commonjs from '@rollup/plugin-commonjs'
import json from '@rollup/plugin-json'
import nodeResolve from '@rollup/plugin-node-resolve'
import typescript from '@rollup/plugin-typescript'
const config = {
input: 'src/main.ts',
output: {
esModule: true,
file: 'dist/main.js',
format: 'es',
sourcemap: false
},
plugins: [typescript(), nodeResolve({ preferBuiltins: true }), commonjs(), json()]
}
export default config

View File

@@ -25,10 +25,10 @@
*/ */
import * as core from '@actions/core' import * as core from '@actions/core'
import * as constants from './constants' import * as constants from './constants.js'
import { save } from './features/cache' import { save } from './features/cache.js'
import { generateReports } from './features/reports' import { generateReports } from './features/reports.js'
import { processSBOM } from './features/sbom' import { processSBOM } from './features/sbom.js'
/** /**
* Check given input and run a save process for the specified package manager * Check given input and run a save process for the specified package manager

View File

@@ -1,6 +1,6 @@
import * as otypes from '@octokit/types' import * as otypes from '@octokit/types'
export const ACTION_VERSION = '1.3.6' export const ACTION_VERSION = '1.4.0'
export const INPUT_VERSION = 'version' export const INPUT_VERSION = 'version'
export const INPUT_GDS_TOKEN = 'gds-token' export const INPUT_GDS_TOKEN = 'gds-token'

View File

@@ -1,6 +1,6 @@
import * as core from '@actions/core' import * as core from '@actions/core'
import { GRAALVM_PLATFORM } from './constants' import { GRAALVM_PLATFORM } from './constants.js'
import { exec } from './utils' import { exec } from './utils.js'
const APT_GET_INSTALL_BASE = 'sudo apt-get -y --no-upgrade install' const APT_GET_INSTALL_BASE = 'sudo apt-get -y --no-upgrade install'
const COMPONENT_TO_DEPS = new Map<string, Map<string, string>>([ const COMPONENT_TO_DEPS = new Map<string, Map<string, string>>([

View File

@@ -1,11 +1,10 @@
import * as c from '../constants' import * as c from '../constants.js'
import * as core from '@actions/core' import * as core from '@actions/core'
import * as tc from '@actions/tool-cache' import * as tc from '@actions/tool-cache'
import { exec } from '../utils'
import { join } from 'path' import { join } from 'path'
const MUSL_NAME = 'x86_64-linux-musl-native' const MUSL_VERSION = '1.2.5.1'
const MUSL_VERSION = '10.2.1' const MUSL_NAME = 'musl-toolchain'
export async function setUpNativeImageMusl(): Promise<void> { export async function setUpNativeImageMusl(): Promise<void> {
if (!c.IS_LINUX) { if (!c.IS_LINUX) {
@@ -18,26 +17,10 @@ export async function setUpNativeImageMusl(): Promise<void> {
} else { } else {
core.startGroup(`Setting up musl for GraalVM Native Image...`) core.startGroup(`Setting up musl for GraalVM Native Image...`)
const muslDownloadPath = await tc.downloadTool( const muslDownloadPath = await tc.downloadTool(
`https://github.com/graalvm/setup-graalvm/releases/download/x86_64-linux-musl-${MUSL_VERSION}/${MUSL_NAME}.tgz` `https://github.com/graalvm/setup-graalvm/releases/download/v1.3.7/musl-toolchain-amd64-1.2.5-gcc10.3.0-zlib1.2.13.tar.gz`
) )
const muslExtractPath = await tc.extractTar(muslDownloadPath) const muslExtractPath = await tc.extractTar(muslDownloadPath)
const muslPath = join(muslExtractPath, MUSL_NAME) const muslPath = join(muslExtractPath, MUSL_NAME)
const zlibCommit = 'ec3df00224d4b396e2ac6586ab5d25f673caa4c2'
const zlibDownloadPath = await tc.downloadTool(`https://github.com/madler/zlib/archive/${zlibCommit}.tar.gz`)
const zlibExtractPath = await tc.extractTar(zlibDownloadPath)
const zlibPath = join(zlibExtractPath, `zlib-${zlibCommit}`)
const zlibBuildOptions = {
cwd: zlibPath,
env: {
...process.env,
CC: join(muslPath, 'bin', 'gcc')
}
}
await exec('./configure', [`--prefix=${muslPath}`, '--static'], zlibBuildOptions)
await exec('make', [], zlibBuildOptions)
await exec('make', ['install'], { cwd: zlibPath })
core.info(`Adding ${MUSL_NAME} ${MUSL_VERSION} to tool-cache ...`) core.info(`Adding ${MUSL_NAME} ${MUSL_VERSION} to tool-cache ...`)
toolPath = await tc.cacheDir(muslPath, MUSL_NAME, MUSL_VERSION) toolPath = await tc.cacheDir(muslPath, MUSL_NAME, MUSL_VERSION)
core.endGroup() core.endGroup()

View File

@@ -1,4 +1,4 @@
import * as c from '../constants' import * as c from '../constants.js'
import * as core from '@actions/core' import * as core from '@actions/core'
import * as fs from 'fs' import * as fs from 'fs'
import * as github from '@actions/github' import * as github from '@actions/github'
@@ -11,7 +11,7 @@ import {
updatePRComment, updatePRComment,
tmpfile, tmpfile,
setNativeImageOption setNativeImageOption
} from '../utils' } from '../utils.js'
const BUILD_OUTPUT_JSON_PATH = tmpfile('native-image-build-output.json') const BUILD_OUTPUT_JSON_PATH = tmpfile('native-image-build-output.json')
const BYTES_TO_KiB = 1024 const BYTES_TO_KiB = 1024

View File

@@ -1,11 +1,11 @@
import * as c from '../constants' import * as c from '../constants.js'
import * as core from '@actions/core' import * as core from '@actions/core'
import * as fs from 'fs' import * as fs from 'fs'
import * as github from '@actions/github' import * as github from '@actions/github'
import * as glob from '@actions/glob' import * as glob from '@actions/glob'
import { basename } from 'path' import { basename } from 'path'
import * as semver from 'semver' import * as semver from 'semver'
import { setNativeImageOption } from '../utils' import { setNativeImageOption } from '../utils.js'
const INPUT_NI_SBOM = 'native-image-enable-sbom' const INPUT_NI_SBOM = 'native-image-enable-sbom'
const SBOM_FILE_SUFFIX = '.sbom.json' const SBOM_FILE_SUFFIX = '.sbom.json'

View File

@@ -1,4 +1,4 @@
import * as c from './constants' import * as c from './constants.js'
import * as core from '@actions/core' import * as core from '@actions/core'
import * as fs from 'fs' import * as fs from 'fs'
import * as httpClient from '@actions/http-client' import * as httpClient from '@actions/http-client'
@@ -8,8 +8,8 @@ import * as stream from 'stream'
import * as util from 'util' import * as util from 'util'
import * as semver from 'semver' import * as semver from 'semver'
import { IncomingHttpHeaders, OutgoingHttpHeaders } from 'http' import { IncomingHttpHeaders, OutgoingHttpHeaders } from 'http'
import { RetryHelper } from '@actions/tool-cache/lib/retry-helper' import { RetryHelper } from '@actions/tool-cache/lib/retry-helper.js'
import { calculateSHA256 } from './utils' import { calculateSHA256 } from './utils.js'
import { ok } from 'assert' import { ok } from 'assert'
import { v4 as uuidv4 } from 'uuid' import { v4 as uuidv4 } from 'uuid'

View File

@@ -1,4 +1,4 @@
import * as c from './constants' import * as c from './constants.js'
import * as core from '@actions/core' import * as core from '@actions/core'
import * as semver from 'semver' import * as semver from 'semver'
import { import {
@@ -8,8 +8,8 @@ import {
getLatestRelease, getLatestRelease,
getMatchingTags, getMatchingTags,
getTaggedRelease getTaggedRelease
} from './utils' } from './utils.js'
import { downloadGraalVM, downloadGraalVMEELegacy } from './gds' import { downloadGraalVM, downloadGraalVMEELegacy } from './gds.js'
import { downloadTool } from '@actions/tool-cache' import { downloadTool } from '@actions/tool-cache'
import { basename } from 'path' import { basename } from 'path'

View File

@@ -1,8 +1,8 @@
import * as c from './constants' import * as c from './constants.js'
import * as core from '@actions/core' import * as core from '@actions/core'
import * as semver from 'semver' import * as semver from 'semver'
import { GRAALVM_PLATFORM } from './constants' import { GRAALVM_PLATFORM } from './constants.js'
import { exec } from './utils' import { exec } from './utils.js'
import { join } from 'path' import { join } from 'path'
const BASE_FLAGS = ['--non-interactive', 'install', '--no-progress'] const BASE_FLAGS = ['--non-interactive', 'install', '--no-progress']

View File

@@ -1,6 +1,6 @@
import * as c from './constants' import * as c from './constants.js'
import * as semver from 'semver' import * as semver from 'semver'
import { downloadExtractAndCacheJDK, getTaggedRelease, getMatchingTags } from './utils' import { downloadExtractAndCacheJDK, getTaggedRelease, getMatchingTags } from './utils.js'
import { downloadTool } from '@actions/tool-cache' import { downloadTool } from '@actions/tool-cache'
import { spawnSync } from 'child_process' import { spawnSync } from 'child_process'

View File

@@ -1,20 +1,20 @@
import * as c from './constants' import * as c from './constants.js'
import * as core from '@actions/core' import * as core from '@actions/core'
import * as graalvm from './graalvm' import * as graalvm from './graalvm.js'
import * as semver from 'semver' import * as semver from 'semver'
import { isFeatureAvailable as isCacheAvailable } from '@actions/cache' import { isFeatureAvailable as isCacheAvailable } from '@actions/cache'
import { basename, join } from 'path' import { basename, join } from 'path'
import { restore } from './features/cache' import { restore } from './features/cache.js'
import { setUpDependencies } from './dependencies' import { setUpDependencies } from './dependencies.js'
import { setUpGUComponents } from './gu' import { setUpGUComponents } from './gu.js'
import { setUpMandrel } from './mandrel' import { setUpMandrel } from './mandrel.js'
import { setUpLiberica } from './liberica' import { setUpLiberica } from './liberica.js'
import { checkForUpdates } from './features/check-for-updates' import { checkForUpdates } from './features/check-for-updates.js'
import { setUpNativeImageMusl } from './features/musl' import { setUpNativeImageMusl } from './features/musl.js'
import { setUpWindowsEnvironment } from './msvc' import { setUpWindowsEnvironment } from './msvc.js'
import { setUpNativeImageBuildReports } from './features/reports' import { setUpNativeImageBuildReports } from './features/reports.js'
import { exec } from '@actions/exec' import { exec } from '@actions/exec'
import { setUpSBOMSupport } from './features/sbom' import { setUpSBOMSupport } from './features/sbom.js'
async function run(): Promise<void> { async function run(): Promise<void> {
try { try {

View File

@@ -1,6 +1,6 @@
import * as c from './constants' import * as c from './constants.js'
import * as httpClient from '@actions/http-client' import * as httpClient from '@actions/http-client'
import { downloadExtractAndCacheJDK } from './utils' import { downloadExtractAndCacheJDK } from './utils.js'
import { downloadTool } from '@actions/tool-cache' import { downloadTool } from '@actions/tool-cache'
import { basename } from 'path' import { basename } from 'path'

View File

@@ -1,7 +1,7 @@
import * as core from '@actions/core' import * as core from '@actions/core'
import { execSync } from 'child_process' import { execSync } from 'child_process'
import { existsSync } from 'fs' import { existsSync } from 'fs'
import { VERSION_DEV } from './constants' import { VERSION_DEV } from './constants.js'
// Keep in sync with https://github.com/actions/virtual-environments // Keep in sync with https://github.com/actions/virtual-environments
const KNOWN_VISUAL_STUDIO_INSTALLATIONS = [ const KNOWN_VISUAL_STUDIO_INSTALLATIONS = [

View File

@@ -1,4 +1,4 @@
import * as c from './constants' import * as c from './constants.js'
import * as core from '@actions/core' import * as core from '@actions/core'
import * as github from '@actions/github' import * as github from '@actions/github'
import * as semver from 'semver' import * as semver from 'semver'
@@ -9,7 +9,7 @@ import { readFileSync, readdirSync } from 'fs'
import { createHash } from 'crypto' import { createHash } from 'crypto'
import { join } from 'path' import { join } from 'path'
import { tmpdir } from 'os' import { tmpdir } from 'os'
import { GitHub } from '@actions/github/lib/utils' import { GitHub } from '@actions/github/lib/utils.js'
export async function exec(commandLine: string, args?: string[], options?: ExecOptions | undefined): Promise<void> { export async function exec(commandLine: string, args?: string[], options?: ExecOptions | undefined): Promise<void> {
const exitCode = await e(commandLine, args, options) const exitCode = await e(commandLine, args, options)

View File

@@ -15,7 +15,7 @@
"noUnusedParameters": false, "noUnusedParameters": false,
"pretty": true, "pretty": true,
"resolveJsonModule": true, "resolveJsonModule": true,
"sourceMap": true, "sourceMap": false,
"strict": true, "strict": true,
"strictNullChecks": true, "strictNullChecks": true,
"target": "ES2022" "target": "ES2022"

View File

@@ -6,5 +6,13 @@
"noEmit": true "noEmit": true
}, },
"exclude": ["dist", "node_modules"], "exclude": ["dist", "node_modules"],
"include": ["__tests__", "src", "eslint.config.mjs", "jest.config.js"] "include": [
"__fixtures__",
"__tests__",
"src",
"eslint.config.mjs",
"jest.config.js",
"rollup.cleanup.config.ts",
"rollup.main.config.ts"
]
} }