mirror of
https://github.com/julia-actions/setup-julia.git
synced 2026-02-14 03:56:53 +08:00
Compare commits
108 Commits
SaschaMann
...
v2.2
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
3645a07f58 | ||
|
|
d56bd397bb | ||
|
|
c7aa298e32 | ||
|
|
cae3c21ea1 | ||
|
|
389de5c0df | ||
|
|
42e03d3446 | ||
|
|
e62bf8c418 | ||
|
|
30038810d2 | ||
|
|
0e4b558b25 | ||
|
|
3599cbd45f | ||
|
|
16b01270a4 | ||
|
|
ed4a842dbe | ||
|
|
63a26ece8c | ||
|
|
4581e12ce4 | ||
|
|
4212b2587b | ||
|
|
a515f9fb49 | ||
|
|
5fb759db5c | ||
|
|
90754937ed | ||
|
|
f5b61b79e1 | ||
|
|
ae2b920dd5 | ||
|
|
699547385f | ||
|
|
85c0672686 | ||
|
|
b96a5725f5 | ||
|
|
437a175294 | ||
|
|
e9d953d306 | ||
|
|
4190528a8c | ||
|
|
9acd04fccc | ||
|
|
e61a30fa06 | ||
|
|
0f702cc7c1 | ||
|
|
bb12998da7 | ||
|
|
9c6e4ea02e | ||
|
|
b69305e71d | ||
|
|
83ec284724 | ||
|
|
afda220f43 | ||
|
|
abbe9013bd | ||
|
|
27b547a6da | ||
|
|
a1c40e9691 | ||
|
|
ffd1649f9b | ||
|
|
f3d4142aa8 | ||
|
|
d3d61d99d5 | ||
|
|
a46a85f797 | ||
|
|
15b8728ec6 | ||
|
|
82b8fbfebd | ||
|
|
0affa9ffb0 | ||
|
|
e27a7638ca | ||
|
|
67c6198a06 | ||
|
|
2c0c1c0f24 | ||
|
|
2e04bcf2ea | ||
|
|
de4ef5e2fd | ||
|
|
c7ecd325d5 | ||
|
|
3961cd13d2 | ||
|
|
e16483e859 | ||
|
|
472a0c3588 | ||
|
|
0644643060 | ||
|
|
c629ec2fb8 | ||
|
|
69754702fb | ||
|
|
e0c860ed1a | ||
|
|
b0ddaa0f3f | ||
|
|
7e992845db | ||
|
|
a86c40a7ef | ||
|
|
5ee76acf71 | ||
|
|
aa55906904 | ||
|
|
3fd1872eb1 | ||
|
|
022282ae13 | ||
|
|
3d2a9887ca | ||
|
|
56e107761d | ||
|
|
8a5ee44838 | ||
|
|
84c4368e8a | ||
|
|
9c1e77be1e | ||
|
|
0e1e5daf3b | ||
|
|
23a5f339d0 | ||
|
|
6b19329a6c | ||
|
|
5ed2862b88 | ||
|
|
431db78ca5 | ||
|
|
400582c979 | ||
|
|
87851b8730 | ||
|
|
c21388676f | ||
|
|
9179217812 | ||
|
|
9ddbd3e829 | ||
|
|
ac49140569 | ||
|
|
ca4f81e332 | ||
|
|
90d78ece70 | ||
|
|
7c41900d93 | ||
|
|
54863dca42 | ||
|
|
2960172124 | ||
|
|
f132be810e | ||
|
|
6d60bc8709 | ||
|
|
152b85e982 | ||
|
|
029296930b | ||
|
|
294135b6de | ||
|
|
2f270f0b37 | ||
|
|
13d92cb7a9 | ||
|
|
a7ad2168c4 | ||
|
|
43c4e31075 | ||
|
|
2bfca2816f | ||
|
|
87fafcc1ec | ||
|
|
57ce80e73c | ||
|
|
ffea8bb089 | ||
|
|
3a89763b86 | ||
|
|
40f50bc31f | ||
|
|
8474f0e14d | ||
|
|
76f26cb710 | ||
|
|
40ab89a96a | ||
|
|
631e68d88a | ||
|
|
a07a9b4c49 | ||
|
|
67db496725 | ||
|
|
800ff44572 | ||
|
|
6966335537 |
1
.github/ISSUE_TEMPLATE/bug_report.md
vendored
1
.github/ISSUE_TEMPLATE/bug_report.md
vendored
@@ -3,7 +3,6 @@ name: Bug report
|
|||||||
about: Create a report to help us improve
|
about: Create a report to help us improve
|
||||||
title: "[BUG] "
|
title: "[BUG] "
|
||||||
labels: bug
|
labels: bug
|
||||||
assignees: SaschaMann
|
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
|
|||||||
16
.github/dependabot.yml
vendored
16
.github/dependabot.yml
vendored
@@ -3,5 +3,17 @@ updates:
|
|||||||
- package-ecosystem: gitsubmodule
|
- package-ecosystem: gitsubmodule
|
||||||
directory: "/"
|
directory: "/"
|
||||||
schedule:
|
schedule:
|
||||||
interval: daily
|
interval: monthly
|
||||||
open-pull-requests-limit: 10
|
open-pull-requests-limit: 99
|
||||||
|
|
||||||
|
- package-ecosystem: 'github-actions'
|
||||||
|
directory: '/'
|
||||||
|
schedule:
|
||||||
|
interval: 'monthly'
|
||||||
|
open-pull-requests-limit: 99
|
||||||
|
|
||||||
|
- package-ecosystem: npm
|
||||||
|
directory: "/"
|
||||||
|
schedule:
|
||||||
|
interval: monthly
|
||||||
|
open-pull-requests-limit: 99
|
||||||
|
|||||||
11
.github/scripts/common-tests.jl
vendored
Normal file
11
.github/scripts/common-tests.jl
vendored
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
if !occursin("hostedtoolcache", Sys.BINDIR)
|
||||||
|
error("the wrong julia is being used: $(Sys.BINDIR)")
|
||||||
|
end
|
||||||
|
if VERSION >= v"1.7.0" # pkgdir was introduced here, and before then mtime wasn't a problem so just skip
|
||||||
|
using Pkg
|
||||||
|
src = pkgdir(Pkg, "src", "Pkg.jl")
|
||||||
|
# mtime is when it's compressed, ctime is when the file is extracted
|
||||||
|
if mtime(src) >= ctime(src)
|
||||||
|
error("source mtime ($(mtime(src))) is not earlier than ctime ($(ctime(src)))")
|
||||||
|
end
|
||||||
|
end
|
||||||
33
.github/workflows/backup.yml
vendored
33
.github/workflows/backup.yml
vendored
@@ -1,33 +0,0 @@
|
|||||||
name: Backup
|
|
||||||
|
|
||||||
on:
|
|
||||||
schedule:
|
|
||||||
- cron: '5 4 * * 0'
|
|
||||||
|
|
||||||
workflow_dispatch:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
backup:
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Configure cache
|
|
||||||
uses: actions/cache@v2
|
|
||||||
with:
|
|
||||||
path: |
|
|
||||||
${{ env.GITHUB_WORKSPACE }}
|
|
||||||
~/.cache/restic
|
|
||||||
key: ${{ runner.os }}
|
|
||||||
|
|
||||||
- name: Install the correct Python version
|
|
||||||
uses: actions/setup-python@v2
|
|
||||||
with:
|
|
||||||
python-version: '3.x'
|
|
||||||
|
|
||||||
- name: Run backup action
|
|
||||||
uses: julia-actions/restic-action@main
|
|
||||||
env: # Options: https://restic.readthedocs.io/en/latest/040_backup.html#environment-variables
|
|
||||||
RESTIC_REPOSITORY: b2:${{ secrets.B2_BUCKET }}:${{ github.repository }}
|
|
||||||
RESTIC_PASSWORD: ${{ secrets.RESTIC_PASSWORD }}
|
|
||||||
B2_ACCOUNT_ID: ${{ secrets.B2_ACCOUNT_ID }}
|
|
||||||
B2_ACCOUNT_KEY: ${{ secrets.B2_ACCOUNT_KEY }}
|
|
||||||
13
.github/workflows/checkin.yml
vendored
13
.github/workflows/checkin.yml
vendored
@@ -1,11 +1,22 @@
|
|||||||
name: "PR Checks"
|
name: "PR Checks"
|
||||||
on: [pull_request, push]
|
on: [pull_request, push]
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
# Skip intermediate builds: all builds except for builds on the `master`, `main`, or `release-*` branches
|
||||||
|
# Cancel intermediate builds: only pull request builds
|
||||||
|
group: ${{ github.workflow }}-${{ github.ref }}-${{ github.ref != 'refs/heads/master' || github.ref != 'refs/heads/main' || startsWith(github.ref, 'refs/heads/release-') || github.run_number }}
|
||||||
|
cancel-in-progress: ${{ startsWith(github.ref, 'refs/pull/') }}
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
check_pr:
|
check_pr:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
timeout-minutes: 60
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v1
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version-file: '.tool-versions'
|
||||||
|
|
||||||
- name: "npm ci"
|
- name: "npm ci"
|
||||||
run: npm ci
|
run: npm ci
|
||||||
|
|||||||
15
.github/workflows/codeql-analysis.yml
vendored
15
.github/workflows/codeql-analysis.yml
vendored
@@ -11,6 +11,12 @@
|
|||||||
#
|
#
|
||||||
name: "CodeQL"
|
name: "CodeQL"
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
# Skip intermediate builds: all builds except for builds on the `master`, `main`, or `release-*` branches
|
||||||
|
# Cancel intermediate builds: only pull request builds
|
||||||
|
group: ${{ github.workflow }}-${{ github.ref }}-${{ github.ref != 'refs/heads/master' || github.ref != 'refs/heads/main' || startsWith(github.ref, 'refs/heads/release-') || github.run_number }}
|
||||||
|
cancel-in-progress: ${{ startsWith(github.ref, 'refs/pull/') }}
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: [ master, releases/* ]
|
branches: [ master, releases/* ]
|
||||||
@@ -24,6 +30,7 @@ jobs:
|
|||||||
analyze:
|
analyze:
|
||||||
name: Analyze
|
name: Analyze
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
timeout-minutes: 60
|
||||||
|
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
@@ -35,11 +42,11 @@ jobs:
|
|||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
# Initializes the CodeQL tools for scanning.
|
# Initializes the CodeQL tools for scanning.
|
||||||
- name: Initialize CodeQL
|
- name: Initialize CodeQL
|
||||||
uses: github/codeql-action/init@v1
|
uses: github/codeql-action/init@v3
|
||||||
with:
|
with:
|
||||||
languages: ${{ matrix.language }}
|
languages: ${{ matrix.language }}
|
||||||
# If you wish to specify custom queries, you can do so here or in a config file.
|
# If you wish to specify custom queries, you can do so here or in a config file.
|
||||||
@@ -50,7 +57,7 @@ jobs:
|
|||||||
# Autobuild attempts to build any compiled languages (C/C++, C#, or Java).
|
# Autobuild attempts to build any compiled languages (C/C++, C#, or Java).
|
||||||
# If this step fails, then you should remove it and run the build manually (see below)
|
# If this step fails, then you should remove it and run the build manually (see below)
|
||||||
- name: Autobuild
|
- name: Autobuild
|
||||||
uses: github/codeql-action/autobuild@v1
|
uses: github/codeql-action/autobuild@v3
|
||||||
|
|
||||||
# ℹ️ Command-line programs to run using the OS shell.
|
# ℹ️ Command-line programs to run using the OS shell.
|
||||||
# 📚 https://git.io/JvXDl
|
# 📚 https://git.io/JvXDl
|
||||||
@@ -64,4 +71,4 @@ jobs:
|
|||||||
# make release
|
# make release
|
||||||
|
|
||||||
- name: Perform CodeQL Analysis
|
- name: Perform CodeQL Analysis
|
||||||
uses: github/codeql-action/analyze@v1
|
uses: github/codeql-action/analyze@v3
|
||||||
|
|||||||
48
.github/workflows/example-builds-defaultarch.yml
vendored
Normal file
48
.github/workflows/example-builds-defaultarch.yml
vendored
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
name: Example builds (default arch)
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
# Skip intermediate builds: all builds except for builds on the `master`, `main`, or `release-*` branches
|
||||||
|
# Cancel intermediate builds: only pull request builds
|
||||||
|
group: ${{ github.workflow }}-${{ github.ref }}-${{ github.ref != 'refs/heads/master' || github.ref != 'refs/heads/main' || startsWith(github.ref, 'refs/heads/release-') || github.run_number }}
|
||||||
|
cancel-in-progress: ${{ startsWith(github.ref, 'refs/pull/') }}
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: ['main', 'master', 'releases/*']
|
||||||
|
pull_request:
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test:
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
timeout-minutes: 60
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
julia-version: ['1']
|
||||||
|
os: [ubuntu-latest, macOS-latest, windows-latest]
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- uses: actions/setup-node@v4
|
||||||
|
if: ${{ ! startsWith(github.ref, 'refs/heads/releases') }}
|
||||||
|
with:
|
||||||
|
node-version-file: '.tool-versions'
|
||||||
|
|
||||||
|
- name: "Install dependencies"
|
||||||
|
if: ${{ ! startsWith(github.ref, 'refs/heads/releases') }}
|
||||||
|
run: |
|
||||||
|
npm install
|
||||||
|
npm run build
|
||||||
|
npm run pack
|
||||||
|
|
||||||
|
- name: "Set up Julia"
|
||||||
|
id: setup-julia
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
version: ${{ matrix.julia-version }}
|
||||||
|
- run: julia --version
|
||||||
|
- run: julia --compile=min -O0 -e 'import InteractiveUtils; InteractiveUtils.versioninfo()'
|
||||||
|
- name: "Check that the correct julia is used and that archive mtimes are maintained"
|
||||||
|
run: julia --startup-file=no --color=yes ./.github/scripts/common-tests.jl
|
||||||
53
.github/workflows/example-builds-nightly-defaultarch.yml
vendored
Normal file
53
.github/workflows/example-builds-nightly-defaultarch.yml
vendored
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
name: Example builds (nightly, default arch)
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
# Skip intermediate builds: all builds except for builds on the `master`, `main`, or `release-*` branches
|
||||||
|
# Cancel intermediate builds: only pull request builds
|
||||||
|
group: ${{ github.workflow }}-${{ github.ref }}-${{ github.ref != 'refs/heads/master' || github.ref != 'refs/heads/main' || startsWith(github.ref, 'refs/heads/release-') || github.run_number }}
|
||||||
|
cancel-in-progress: ${{ startsWith(github.ref, 'refs/pull/') }}
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: ['main', 'master', 'releases/*']
|
||||||
|
pull_request:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test:
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
timeout-minutes: 60
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
julia-version: [nightly, 1.10-nightly]
|
||||||
|
os:
|
||||||
|
- ubuntu-latest
|
||||||
|
- windows-latest
|
||||||
|
# - macos-11 # Intel
|
||||||
|
- macos-12 # Intel
|
||||||
|
- macos-13 # Intel
|
||||||
|
- macos-14 # Apple Silicon
|
||||||
|
- macos-latest # Currently Intel, but will probably point to Apple Silicon in the future
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- uses: actions/setup-node@v4
|
||||||
|
if: ${{ ! startsWith(github.ref, 'refs/heads/releases') }}
|
||||||
|
with:
|
||||||
|
node-version-file: '.tool-versions'
|
||||||
|
|
||||||
|
- name: "Install dependencies"
|
||||||
|
if: ${{ ! startsWith(github.ref, 'refs/heads/releases') }}
|
||||||
|
run: |
|
||||||
|
npm install
|
||||||
|
npm run build
|
||||||
|
npm run pack
|
||||||
|
|
||||||
|
- name: "Set up Julia (${{ matrix.julia-version }})"
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
version: ${{ matrix.julia-version }}
|
||||||
|
- run: julia --version
|
||||||
|
- run: julia --compile=min -O0 -e 'import InteractiveUtils; InteractiveUtils.versioninfo()'
|
||||||
|
- name: "Check that the correct julia is used and that archive mtimes are maintained"
|
||||||
|
run: julia --startup-file=no --color=yes ./.github/scripts/common-tests.jl
|
||||||
23
.github/workflows/example-builds-nightly.yml
vendored
23
.github/workflows/example-builds-nightly.yml
vendored
@@ -1,5 +1,11 @@
|
|||||||
name: Example builds (nightly)
|
name: Example builds (nightly)
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
# Skip intermediate builds: all builds except for builds on the `master`, `main`, or `release-*` branches
|
||||||
|
# Cancel intermediate builds: only pull request builds
|
||||||
|
group: ${{ github.workflow }}-${{ github.ref }}-${{ github.ref != 'refs/heads/master' || github.ref != 'refs/heads/main' || startsWith(github.ref, 'refs/heads/release-') || github.run_number }}
|
||||||
|
cancel-in-progress: ${{ startsWith(github.ref, 'refs/pull/') }}
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: ['main', 'master', 'releases/*']
|
branches: ['main', 'master', 'releases/*']
|
||||||
@@ -10,21 +16,28 @@ on:
|
|||||||
jobs:
|
jobs:
|
||||||
test:
|
test:
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
|
timeout-minutes: 60
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
julia-version: [nightly, 1.8-nightly]
|
julia-version: [nightly, 1.10-nightly]
|
||||||
julia-arch: [x64, x86]
|
julia-arch: [x64, x86]
|
||||||
os: [ubuntu-latest, macOS-latest, windows-latest]
|
os: [ubuntu-latest, macOS-latest, windows-latest]
|
||||||
# 32-bit Julia binaries are not available on macOS
|
# 32-bit Julia binaries are not available on macOS
|
||||||
exclude:
|
exclude:
|
||||||
- os: macOS-latest
|
- os: macOS-latest
|
||||||
julia-arch: x86
|
julia-arch: x86
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v1.0.0
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- uses: actions/setup-node@v4
|
||||||
|
if: ${{ ! startsWith(github.ref, 'refs/heads/releases') }}
|
||||||
|
with:
|
||||||
|
node-version-file: '.tool-versions'
|
||||||
|
|
||||||
- name: "Install dependencies"
|
- name: "Install dependencies"
|
||||||
|
if: ${{ ! startsWith(github.ref, 'refs/heads/releases') }}
|
||||||
run: |
|
run: |
|
||||||
npm install
|
npm install
|
||||||
npm run build
|
npm run build
|
||||||
@@ -37,3 +50,5 @@ jobs:
|
|||||||
arch: ${{ matrix.julia-arch }}
|
arch: ${{ matrix.julia-arch }}
|
||||||
- run: julia --version
|
- run: julia --version
|
||||||
- run: julia --compile=min -O0 -e 'import InteractiveUtils; InteractiveUtils.versioninfo()'
|
- run: julia --compile=min -O0 -e 'import InteractiveUtils; InteractiveUtils.versioninfo()'
|
||||||
|
- name: "Check that the correct julia is used and that archive mtimes are maintained"
|
||||||
|
run: julia --startup-file=no --color=yes ./.github/scripts/common-tests.jl
|
||||||
|
|||||||
26
.github/workflows/example-builds.yml
vendored
26
.github/workflows/example-builds.yml
vendored
@@ -1,5 +1,11 @@
|
|||||||
name: Example builds
|
name: Example builds
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
# Skip intermediate builds: all builds except for builds on the `master`, `main`, or `release-*` branches
|
||||||
|
# Cancel intermediate builds: only pull request builds
|
||||||
|
group: ${{ github.workflow }}-${{ github.ref }}-${{ github.ref != 'refs/heads/master' || github.ref != 'refs/heads/main' || startsWith(github.ref, 'refs/heads/release-') || github.run_number }}
|
||||||
|
cancel-in-progress: ${{ startsWith(github.ref, 'refs/pull/') }}
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: ['main', 'master', 'releases/*']
|
branches: ['main', 'master', 'releases/*']
|
||||||
@@ -9,36 +15,40 @@ on:
|
|||||||
jobs:
|
jobs:
|
||||||
test:
|
test:
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
|
timeout-minutes: 60
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
julia-version: ['1.0.5', '1', '^1.5.0-beta1']
|
julia-version: ['1.0.5', '1.2', '^1.5.0-beta1', '1', 'lts', 'pre']
|
||||||
julia-arch: [x64, x86]
|
julia-arch: [x64, x86]
|
||||||
os: [ubuntu-latest, macOS-latest, windows-latest]
|
os: [ubuntu-latest, macOS-latest, windows-latest]
|
||||||
# 32-bit Julia binaries are not available on macOS
|
# 32-bit Julia binaries are not available on macOS
|
||||||
exclude:
|
exclude:
|
||||||
- os: macOS-latest
|
- os: macOS-latest
|
||||||
julia-arch: x86
|
julia-arch: x86
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v1.0.0
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- uses: actions/setup-node@v4
|
||||||
|
if: ${{ ! startsWith(github.ref, 'refs/heads/releases') }}
|
||||||
|
with:
|
||||||
|
node-version-file: '.tool-versions'
|
||||||
|
|
||||||
- name: "Install dependencies"
|
- name: "Install dependencies"
|
||||||
|
if: ${{ ! startsWith(github.ref, 'refs/heads/releases') }}
|
||||||
run: |
|
run: |
|
||||||
npm install
|
npm install
|
||||||
npm run build
|
npm run build
|
||||||
npm run pack
|
npm run pack
|
||||||
|
|
||||||
- run: mkdir -p ${{ github.workspace }}/dilumtestcache # TODO: delete this line
|
|
||||||
- name: "Set up Julia"
|
- name: "Set up Julia"
|
||||||
id: setup-julia
|
id: setup-julia
|
||||||
uses: ./
|
uses: ./
|
||||||
env:
|
|
||||||
RUNNER_TOOL_CACHE: ${{ github.workspace }}/dilumtestcache
|
|
||||||
with:
|
with:
|
||||||
version: ${{ matrix.julia-version }}
|
version: ${{ matrix.julia-version }}
|
||||||
arch: ${{ matrix.julia-arch }}
|
arch: ${{ matrix.julia-arch }}
|
||||||
- run: which julia # TODO: delete this line
|
|
||||||
- run: which -a julia # TODO: delete this line
|
|
||||||
- run: julia --version
|
- run: julia --version
|
||||||
- run: julia --compile=min -O0 -e 'import InteractiveUtils; InteractiveUtils.versioninfo()'
|
- run: julia --compile=min -O0 -e 'import InteractiveUtils; InteractiveUtils.versioninfo()'
|
||||||
|
- name: "Check that the correct julia is used and that archive mtimes are maintained"
|
||||||
|
run: julia --startup-file=no --color=yes ./.github/scripts/common-tests.jl
|
||||||
|
|||||||
2
.gitignore
vendored
2
.gitignore
vendored
@@ -1,3 +1,3 @@
|
|||||||
node_modules/
|
node_modules/
|
||||||
__tests__/runner/*
|
__tests__/runner/*
|
||||||
dist/
|
!dist/
|
||||||
|
|||||||
1
.tool-versions
Normal file
1
.tool-versions
Normal file
@@ -0,0 +1 @@
|
|||||||
|
nodejs 20.11.1
|
||||||
@@ -1,11 +1,3 @@
|
|||||||
# Dev docs / Contributing guide
|
# Contributing
|
||||||
|
|
||||||
## Building and tagging a release (requires write access)
|
Please see the README in the [`devdocs/`](devdocs/) folder.
|
||||||
|
|
||||||
1. Test your changes, merge into `master`.
|
|
||||||
2. Checkout `master`.
|
|
||||||
3. Bump the version number in [`package.json`](package.json).
|
|
||||||
4. Run `./bin/build-release julia-actions/setup-julia` to create a release branch and build a release.
|
|
||||||
5. Push the branch (**without tags**) and verify that CI is passing on it.
|
|
||||||
6. Run `git push --tags --force` to update the tags.
|
|
||||||
7. Create a release for the `vX.Y.Z` tag.
|
|
||||||
|
|||||||
123
README.md
123
README.md
@@ -1,7 +1,6 @@
|
|||||||
# setup-julia Action
|
# setup-julia Action
|
||||||
|
|
||||||
[](https://securitylab.github.com/tools/codeql)
|
[](https://securitylab.github.com/tools/codeql)
|
||||||
[](https://dependabot.com)
|
|
||||||
|
|
||||||
This action sets up a Julia environment for use in actions by downloading a specified version of Julia and adding it to PATH.
|
This action sets up a Julia environment for use in actions by downloading a specified version of Julia and adding it to PATH.
|
||||||
|
|
||||||
@@ -23,7 +22,7 @@ This action sets up a Julia environment for use in actions by downloading a spec
|
|||||||
### Inputs
|
### Inputs
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- uses: julia-actions/setup-julia@v1
|
- uses: julia-actions/setup-julia@v2
|
||||||
with:
|
with:
|
||||||
# The Julia version that will be installed and added as `julia` to the PATH.
|
# The Julia version that will be installed and added as `julia` to the PATH.
|
||||||
# See "Julia Versions" below for a list of valid values.
|
# See "Julia Versions" below for a list of valid values.
|
||||||
@@ -38,9 +37,15 @@ This action sets up a Julia environment for use in actions by downloading a spec
|
|||||||
|
|
||||||
# The architecture of the Julia binaries.
|
# The architecture of the Julia binaries.
|
||||||
#
|
#
|
||||||
# Supported values: x64 | x86
|
# Please note that installing aarch64 binaries only makes sense on self-hosted aarch64 runners.
|
||||||
|
# We currently don't run test builds on that architecture, so we cannot guarantee that the input won't break randomly,
|
||||||
|
# although there is no reason why it would.
|
||||||
#
|
#
|
||||||
# Default: x64
|
# Supported values: x64 | x86 | aarch64 (untested)
|
||||||
|
#
|
||||||
|
# Note: you can use X64, X86, and ARM64 as synonyms for x64, x86, and aarch64, respectively.
|
||||||
|
#
|
||||||
|
# Defaults to the architecture of the runner executing the job.
|
||||||
arch: ''
|
arch: ''
|
||||||
|
|
||||||
# Set the display setting for printing InteractiveUtils.versioninfo() after installing.
|
# Set the display setting for printing InteractiveUtils.versioninfo() after installing.
|
||||||
@@ -81,10 +86,10 @@ outputs:
|
|||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v1.0.0
|
- uses: actions/checkout@v4
|
||||||
- uses: julia-actions/setup-julia@v1
|
- uses: julia-actions/setup-julia@v2
|
||||||
with:
|
with:
|
||||||
version: 1.0.4
|
version: '1.10'
|
||||||
- run: julia -e 'println("Hello, World!")'
|
- run: julia -e 'println("Hello, World!")'
|
||||||
```
|
```
|
||||||
|
|
||||||
@@ -92,22 +97,53 @@ steps:
|
|||||||
|
|
||||||
You can either specify specific Julia versions or version ranges. If you specify a version range, the **highest** available Julia version that matches the range will be selected.
|
You can either specify specific Julia versions or version ranges. If you specify a version range, the **highest** available Julia version that matches the range will be selected.
|
||||||
|
|
||||||
**Warning:** It is strongly recommended to wrap versions in quotes. Otherwise, the YAML parser used by GitHub Actions parses certain versions as numbers which causes the wrong version to be selected. For example, `1.0` may be parsed as `1`.
|
> **Warning**
|
||||||
|
>
|
||||||
|
> It is strongly recommended to wrap versions in quotes. Otherwise, the YAML parser used by GitHub Actions parses certain versions as numbers which causes the wrong version to be selected. For example, `1.0` may be parsed as `1`.
|
||||||
|
|
||||||
#### Examples
|
#### Examples
|
||||||
|
|
||||||
- `1.2.0` is a valid semver version. The action will try to download exactly this version. If it's not available, the build step will fail.
|
- `'1.2.0'` is a valid semver version. The action will try to download exactly this version. If it's not available, the build step will fail.
|
||||||
- `1.0` is a version range that will match the highest available Julia version that starts with `1.0`, e.g. `1.0.5`, excluding pre-releases.
|
- `'1.0'` is a version range that will match the highest available Julia version that starts with `1.0`, e.g. `1.0.5`, excluding pre-releases.
|
||||||
- `^1.3.0-rc1` is a **caret** version range that includes pre-releases starting at `rc1`. It matches all versions `≥ 1.3.0-rc1` and `< 2.0.0`.
|
- `'^1.3.0-rc1'` is a **caret** version range that includes pre-releases of `1.3.0` starting at `rc1`. It matches all versions `≥ 1.3.0-rc1` and `< 2.0.0`.
|
||||||
- `~1.3.0-rc1` is a **tilde** version range that includes pre-releases starting at `rc1`. It matches all versions `≥ 1.3.0-rc1` and `< 1.4.0`.
|
- `'~1.3.0-rc1'` is a **tilde** version range that includes pre-releases of `1.3.0` starting at `rc1`. It matches all versions `≥ 1.3.0-rc1` and `< 1.4.0`.
|
||||||
- `^1.3.0-0` is a **caret** version range that includes _all_ pre-releases. It matches all versions `≥ 1.3.0-` and `< 2.0.0`.
|
- `'^1.3.0-0'` is a **caret** version range that includes _all_ pre-releases of `1.3.0`. It matches all versions `≥ 1.3.0-` and `< 2.0.0`.
|
||||||
- `~1.3.0-0` is a **tilde** version range that includes _all_ pre-releases. It matches all versions `≥ 1.3.0-` and `< 1.4.0`.
|
- `'~1.3.0-0'` is a **tilde** version range that includes _all_ pre-releases of `1.3.0`. It matches all versions `≥ 1.3.0-` and `< 1.4.0`.
|
||||||
- `nightly` will install the latest nightly build.
|
- `'lts'` will install the latest LTS build.
|
||||||
- `1.7-nightly` will install the latest nightly build for the upcoming 1.7 release. This version will only be available during certain phases of the Julia release cycle.
|
- `'pre'` will install the latest prerelease build.
|
||||||
|
- `'nightly'` will install the latest nightly build.
|
||||||
|
- `'1.7-nightly'` will install the latest nightly build for the upcoming 1.7 release. This version will only be available during certain phases of the Julia release cycle.
|
||||||
|
|
||||||
Internally the action uses node's semver package to resolve version ranges. Its [documentation](https://github.com/npm/node-semver#advanced-range-syntax) contains more details on the version range syntax. You can test what version will be selected for a given input in this JavaScript [REPL](https://repl.it/@SaschaMann/setup-julia-version-logic).
|
Internally the action uses node's semver package to resolve version ranges. Its [documentation](https://github.com/npm/node-semver#advanced-range-syntax) contains more details on the version range syntax. You can test what version will be selected for a given input in this JavaScript [REPL](https://repl.it/@SaschaMann/setup-julia-version-logic).
|
||||||
|
|
||||||
The available Julia versions are pulled from [`versions.json`](https://julialang-s3.julialang.org/bin/versions.json). This file is automatically updated once a day. Therefore it may take up to 24 hours until a newly released Julia version is available in the action.
|
#### Prereleases
|
||||||
|
|
||||||
|
There are two methods of including pre-releases in version matching:
|
||||||
|
|
||||||
|
1. Including the pre-release tag in the version itself, e.g. `'^1.3.0-rc1'`.
|
||||||
|
2. Setting the input `include-all-prereleases` to `true`.
|
||||||
|
|
||||||
|
These behave slightly differently.
|
||||||
|
|
||||||
|
1. If the version `a.b.c` contains pre-release tag, all pre-releases of version `a.b.c` will be included in the version matching.
|
||||||
|
For example, `^1.3.0-rc1` would match `1.3.0-rc2` but would **not** match `1.4.0-rc1` once released.
|
||||||
|
2. If `include-preleases` is set to true, **all** pre-releases of all versions will be included in the version matching. In this case, `^1.3.0-rc1` would match `1.4.0-rc1` once released.
|
||||||
|
|
||||||
|
**Example:** Without `include-all-prereleases: true`, the version `^1.3.0-rc1` would match `1.3.0-rc1`, `1.3.0-rc2`, `1.3.0`, `1.4.0` once they are released.
|
||||||
|
With `include-all-prereleases: true`, it would match `1.3.0-rc1`, `1.3.0-rc2`, `1.3.0`, `1.4.0-rc1`, `1.4.0`.
|
||||||
|
|
||||||
|
If you want to run tests against the latest tagged version, no matter what version that is, you can use
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
- uses: julia-actions/setup-julia@v2
|
||||||
|
with:
|
||||||
|
version: '1'
|
||||||
|
include-all-prereleases: true
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Recently released versions
|
||||||
|
|
||||||
|
The available Julia versions are pulled from [`versions.json`](https://julialang-s3.julialang.org/bin/versions.json).
|
||||||
|
|
||||||
### Matrix Testing
|
### Matrix Testing
|
||||||
|
|
||||||
@@ -123,11 +159,11 @@ jobs:
|
|||||||
matrix:
|
matrix:
|
||||||
julia-version: ['1.0', '1.2.0', '^1.3.0-rc1']
|
julia-version: ['1.0', '1.2.0', '^1.3.0-rc1']
|
||||||
os: [ubuntu-latest, windows-latest, macOS-latest]
|
os: [ubuntu-latest, windows-latest, macOS-latest]
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v1.0.0
|
- uses: actions/checkout@v4
|
||||||
- name: "Set up Julia"
|
- name: "Set up Julia"
|
||||||
uses: julia-actions/setup-julia@v1
|
uses: julia-actions/setup-julia@v2
|
||||||
with:
|
with:
|
||||||
version: ${{ matrix.julia-version }}
|
version: ${{ matrix.julia-version }}
|
||||||
- run: julia -e 'println("Hello, World!")'
|
- run: julia -e 'println("Hello, World!")'
|
||||||
@@ -149,11 +185,11 @@ jobs:
|
|||||||
exclude:
|
exclude:
|
||||||
- os: macOS-latest
|
- os: macOS-latest
|
||||||
julia-arch: x86
|
julia-arch: x86
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v1.0.0
|
- uses: actions/checkout@v4
|
||||||
- name: "Set up Julia"
|
- name: "Set up Julia"
|
||||||
uses: julia-actions/setup-julia@v1
|
uses: julia-actions/setup-julia@v2
|
||||||
with:
|
with:
|
||||||
version: ${{ matrix.julia-version }}
|
version: ${{ matrix.julia-version }}
|
||||||
arch: ${{ matrix.julia-arch }}
|
arch: ${{ matrix.julia-arch }}
|
||||||
@@ -176,11 +212,11 @@ jobs:
|
|||||||
- os: windows-latest
|
- os: windows-latest
|
||||||
julia-version: ['1.0.4']
|
julia-version: ['1.0.4']
|
||||||
julia-arch: x86
|
julia-arch: x86
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v1.0.0
|
- uses: actions/checkout@v4
|
||||||
- name: "Set up Julia"
|
- name: "Set up Julia"
|
||||||
uses: julia-actions/setup-julia@v1
|
uses: julia-actions/setup-julia@v2
|
||||||
with:
|
with:
|
||||||
version: ${{ matrix.julia-version }}
|
version: ${{ matrix.julia-version }}
|
||||||
- run: julia -e 'println("Hello, World!")'
|
- run: julia -e 'println("Hello, World!")'
|
||||||
@@ -203,23 +239,44 @@ This action follows [GitHub's advice](https://help.github.com/en/articles/about-
|
|||||||
|
|
||||||
If you don't want to deal with updating the version of the action, similiarly to how Travis CI handles it, use `latest` or major version branches. [Dependabot](https://dependabot.com/) can also be used to automatically create Pull Requests to update actions used in your workflows.
|
If you don't want to deal with updating the version of the action, similiarly to how Travis CI handles it, use `latest` or major version branches. [Dependabot](https://dependabot.com/) can also be used to automatically create Pull Requests to update actions used in your workflows.
|
||||||
|
|
||||||
It's unlikely, but not impossible, that there will be breaking changes post-v1.0.0 unless a new major version of Julia is introduced.
|
It's unlikely, but not impossible, that there will be breaking changes post-v2.0.0 unless a new major version of Julia is introduced.
|
||||||
|
|
||||||
You can specify commits, branches or tags in your workflows as follows:
|
You can specify commits, branches or tags in your workflows as follows:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
- uses: julia-actions/setup-julia@d3ce119a16594ea9e5d7974813970c73b6ab9e94 # commit SHA of the tagged 1.4.1 commit
|
- uses: julia-actions/setup-julia@f2258781c657ad9b4b88072c5eeaf9ec8c370874 # commit SHA of the tagged 2.0.0 commit
|
||||||
- uses: julia-actions/setup-julia@latest # latest version tag (may break existing workflows)
|
- uses: julia-actions/setup-julia@latest # latest version tag (may break existing workflows)
|
||||||
- uses: julia-actions/setup-julia@v1 # major version tag
|
- uses: julia-actions/setup-julia@v2 # major version tag
|
||||||
- uses: julia-actions/setup-julia@v1.4 # minor version tag
|
- uses: julia-actions/setup-julia@v2.0 # minor version tag
|
||||||
- uses: julia-actions/setup-julia@v1.4.1 # specific version tag
|
- uses: julia-actions/setup-julia@v2.0.0 # specific version tag
|
||||||
```
|
```
|
||||||
|
|
||||||
If your workflow requires access to secrets, you should always pin it to a commit SHA instead of a tag.
|
If your workflow requires access to secrets, you should always pin it to a commit SHA instead of a tag.
|
||||||
This will protect you in case a bad actor gains access to the setup-julia repo.
|
This will protect you in case a bad actor gains access to the setup-julia repo.
|
||||||
You can find more information in [GitHub's security hardening guide](https://docs.github.com/en/free-pro-team@latest/actions/learn-github-actions/security-hardening-for-github-actions#using-third-party-actions).
|
You can find more information in [GitHub's security hardening guide](https://docs.github.com/en/free-pro-team@latest/actions/learn-github-actions/security-hardening-for-github-actions#using-third-party-actions).
|
||||||
|
|
||||||
|
## Using Dependabot version updates to keep your GitHub Actions up to date
|
||||||
|
|
||||||
|
We highly recommend that you set up Dependabot version updates on your repo to keep your GitHub Actions up to date.
|
||||||
|
|
||||||
|
To set up Dependabot version updates, create a file named `.github/dependabot.yml` in your repo with the following contents:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
version: 2
|
||||||
|
updates:
|
||||||
|
- package-ecosystem: "github-actions"
|
||||||
|
directory: "/"
|
||||||
|
schedule:
|
||||||
|
interval: "monthly"
|
||||||
|
open-pull-requests-limit: 99
|
||||||
|
labels:
|
||||||
|
- "dependencies"
|
||||||
|
- "github-actions"
|
||||||
|
```
|
||||||
|
|
||||||
|
For more details on Dependabot version updates, see the [GitHub Dependabot documentation](https://docs.github.com/en/code-security/dependabot/dependabot-version-updates).
|
||||||
|
|
||||||
## Debug logs
|
## Debug logs
|
||||||
|
|
||||||
You can enable [Step Debug Logs](https://github.com/actions/toolkit/blob/main/docs/action-debugging.md#step-debug-logs) for more detailed logs.
|
You can enable [Step Debug Logs](https://github.com/actions/toolkit/blob/main/docs/action-debugging.md#step-debug-logs) for more detailed logs.
|
||||||
@@ -228,3 +285,7 @@ Note that when debug logs are enabled, a request will be sent to `https://httpbi
|
|||||||
## Third party information
|
## Third party information
|
||||||
Parts of this software have been derived from other open source software.
|
Parts of this software have been derived from other open source software.
|
||||||
See [THIRD_PARTY_NOTICE.md](THIRD_PARTY_NOTICE.md) for details.
|
See [THIRD_PARTY_NOTICE.md](THIRD_PARTY_NOTICE.md) for details.
|
||||||
|
|
||||||
|
## Contributing to this repo
|
||||||
|
|
||||||
|
Please see the README in the [`devdocs/`](devdocs/) folder.
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -4,30 +4,30 @@
|
|||||||
import * as path from 'path'
|
import * as path from 'path'
|
||||||
|
|
||||||
import * as io from '@actions/io'
|
import * as io from '@actions/io'
|
||||||
|
|
||||||
import nock = require('nock')
|
|
||||||
import * as semver from 'semver'
|
import * as semver from 'semver'
|
||||||
|
|
||||||
|
import nock = require('nock')
|
||||||
|
|
||||||
const testVersions = [
|
const testVersions = [
|
||||||
'0.1.2', '0.2.0', '0.2.1', '0.3.0',
|
'0.1.2',
|
||||||
'0.3.1', '0.3.10', '0.3.11', '0.3.12',
|
'0.2.0', '0.2.1',
|
||||||
'0.3.2', '0.3.3', '0.3.4', '0.3.5',
|
'0.3.0', '0.3.1', '0.3.10', '0.3.11', '0.3.12', '0.3.2', '0.3.3', '0.3.4', '0.3.5', '0.3.6', '0.3.7', '0.3.8', '0.3.9',
|
||||||
'0.3.6', '0.3.7', '0.3.8', '0.3.9',
|
'0.4.0', '0.4.0-rc1', '0.4.0-rc2', '0.4.0-rc3', '0.4.0-rc4', '0.4.1', '0.4.2', '0.4.3', '0.4.4', '0.4.5', '0.4.6', '0.4.7',
|
||||||
'0.4.0', '0.4.0-rc1', '0.4.0-rc2', '0.4.0-rc3',
|
'0.5.0', '0.5.0-rc0', '0.5.0-rc1', '0.5.0-rc2', '0.5.0-rc3', '0.5.0-rc4', '0.5.1', '0.5.2',
|
||||||
'0.4.0-rc4', '0.4.1', '0.4.2', '0.4.3',
|
'0.6.0', '0.6.0-pre.alpha', '0.6.0-pre.beta', '0.6.0-rc1', '0.6.0-rc2', '0.6.0-rc3', '0.6.1', '0.6.2', '0.6.3', '0.6.4',
|
||||||
'0.4.4', '0.4.5', '0.4.6', '0.4.7',
|
'0.7.0', '0.7.0-alpha', '0.7.0-beta', '0.7.0-beta2', '0.7.0-rc1', '0.7.0-rc2', '0.7.0-rc3',
|
||||||
'0.5.0', '0.5.0-rc0', '0.5.0-rc1', '0.5.0-rc2',
|
'1.0.0', '1.0.0-rc1', '1.0.1', '1.0.2', '1.0.3', '1.0.4', '1.0.5',
|
||||||
'0.5.0-rc3', '0.5.0-rc4', '0.5.1', '0.5.2',
|
'1.1.0', '1.1.0-rc1', '1.1.0-rc2', '1.1.1',
|
||||||
'0.6.0', '0.6.0-pre.alpha', '0.6.0-pre.beta', '0.6.0-rc1',
|
'1.2.0', '1.2.0-rc1', '1.2.0-rc2', '1.2.0-rc3',
|
||||||
'0.6.0-rc2', '0.6.0-rc3', '0.6.1', '0.6.2',
|
'1.3.0', '1.3.0-alpha', '1.3.0-rc1', '1.3.0-rc2', '1.3.0-rc3', '1.3.0-rc4', '1.3.0-rc5', '1.3.1',
|
||||||
'0.6.3', '0.6.4', '0.7.0', '0.7.0-alpha',
|
'1.4.0', '1.4.0-rc1', '1.4.0-rc2', '1.4.1', '1.4.2',
|
||||||
'0.7.0-beta', '0.7.0-beta2', '0.7.0-rc1', '0.7.0-rc2',
|
'1.5.0', '1.5.0-beta1', '1.5.0-rc1', '1.5.0-rc2', '1.5.1', '1.5.2', '1.5.3', '1.5.4',
|
||||||
'0.7.0-rc3', '1.0.0', '1.0.0-rc1', '1.0.1',
|
'1.6.0', '1.6.0-beta1', '1.6.0-rc1', '1.6.0-rc2', '1.6.0-rc3', '1.6.1', '1.6.2', '1.6.3', '1.6.4', '1.6.5', '1.6.6', '1.6.7',
|
||||||
'1.0.2', '1.0.3', '1.0.4', '1.0.5',
|
'1.7.0', '1.7.0-beta1', '1.7.0-beta2', '1.7.0-beta3', '1.7.0-beta4', '1.7.0-rc1', '1.7.0-rc2', '1.7.0-rc3', '1.7.1', '1.7.2', '1.7.3',
|
||||||
'1.1.0', '1.1.0-rc1', '1.1.0-rc2', '1.1.1',
|
'1.8.0', '1.8.0-beta1', '1.8.0-beta2', '1.8.0-beta3', '1.8.0-rc1', '1.8.0-rc2', '1.8.0-rc3', '1.8.0-rc4', '1.8.1', '1.8.2', '1.8.3', '1.8.4', '1.8.5',
|
||||||
'1.2.0', '1.2.0-rc1', '1.2.0-rc2', '1.2.0-rc3',
|
'1.9.0', '1.9.0-alpha1', '1.9.0-beta1', '1.9.0-beta2', '1.9.0-beta3', '1.9.0-beta4', '1.9.0-rc1', '1.9.0-rc2', '1.9.0-rc3', '1.9.1', '1.9.2', '1.9.3', '1.9.4',
|
||||||
'1.3.0-alpha', '1.3.0-rc1', '1.3.0-rc2', '1.3.0-rc3',
|
'1.10.0', '1.10.0-alpha1', '1.10.0-beta1', '1.10.0-beta2', '1.10.0-beta3', '1.10.0-rc1', '1.10.0-rc2', '1.10.0-rc3', '1.10.1', '1.10.2',
|
||||||
'1.3.0-rc4'
|
'1.11.0-alpha1', '1.11.0-alpha2', '1.11.0-beta1'
|
||||||
]
|
]
|
||||||
|
|
||||||
const toolDir = path.join(__dirname, 'runner', 'tools')
|
const toolDir = path.join(__dirname, 'runner', 'tools')
|
||||||
@@ -55,14 +55,33 @@ describe('version matching tests', () => {
|
|||||||
expect(installer.getJuliaVersion([], 'nightly')).toEqual('nightly')
|
expect(installer.getJuliaVersion([], 'nightly')).toEqual('nightly')
|
||||||
expect(installer.getJuliaVersion(testVersions, 'nightly')).toEqual('nightly')
|
expect(installer.getJuliaVersion(testVersions, 'nightly')).toEqual('nightly')
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('LTS', () => {
|
||||||
|
// Update test when LTS is updated
|
||||||
|
expect(installer.getJuliaVersion(testVersions, 'lts')).toEqual(installer.getJuliaVersion(testVersions, '1.6'))
|
||||||
|
expect(installer.getJuliaVersion(testVersions, 'lts')).toEqual('1.6.7')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('pre', () => {
|
||||||
|
expect(installer.getJuliaVersion(testVersions, 'pre')).toEqual('1.11.0-beta1')
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('version ranges', () => {
|
describe('version ranges', () => {
|
||||||
it('Chooses the highest available version that matches the input', () => {
|
it('Chooses the highest available version that matches the input', () => {
|
||||||
expect(installer.getJuliaVersion(testVersions, '1')).toEqual('1.2.0')
|
expect(installer.getJuliaVersion(testVersions, '1')).toEqual('1.10.2')
|
||||||
expect(installer.getJuliaVersion(testVersions, '1.0')).toEqual('1.0.5')
|
expect(installer.getJuliaVersion(testVersions, '1.0')).toEqual('1.0.5')
|
||||||
expect(installer.getJuliaVersion(testVersions, '^1.3.0-rc1')).toEqual('1.3.0-rc4')
|
expect(installer.getJuliaVersion(testVersions, '^1.3.0-rc1')).toEqual('1.10.2')
|
||||||
expect(installer.getJuliaVersion(testVersions, '^1.2.0-rc1')).toEqual('1.2.0')
|
expect(installer.getJuliaVersion(testVersions, '^1.2.0-rc1')).toEqual('1.10.2')
|
||||||
|
expect(installer.getJuliaVersion(testVersions, '^1.10.0-rc1')).toEqual('1.10.2')
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('include-prereleases', () => {
|
||||||
|
it('Chooses the highest available version that matches the input including prereleases', () => {
|
||||||
|
expect(installer.getJuliaVersion(testVersions, '^1.2.0-0', true)).toEqual('1.11.0-beta1')
|
||||||
|
expect(installer.getJuliaVersion(testVersions, '1', true)).toEqual('1.11.0-beta1')
|
||||||
|
expect(installer.getJuliaVersion(testVersions, '^1.2.0-0', false)).toEqual('1.10.2')
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
12
action.yml
12
action.yml
@@ -5,10 +5,14 @@ inputs:
|
|||||||
version:
|
version:
|
||||||
description: 'The Julia version to download (if necessary) and use. Example: 1.0.4'
|
description: 'The Julia version to download (if necessary) and use. Example: 1.0.4'
|
||||||
default: '1'
|
default: '1'
|
||||||
arch:
|
include-all-prereleases:
|
||||||
description: 'Architecture of the Julia binaries. Defaults to x64.'
|
description: 'Include prereleases when matching the Julia version to available versions.'
|
||||||
required: false
|
required: false
|
||||||
default: 'x64'
|
default: 'false'
|
||||||
|
arch:
|
||||||
|
description: 'Architecture of the Julia binaries. Defaults to the architecture of the runner executing the job.'
|
||||||
|
required: false
|
||||||
|
default: '${{ runner.arch }}'
|
||||||
show-versioninfo:
|
show-versioninfo:
|
||||||
description: 'Display InteractiveUtils.versioninfo() after installing'
|
description: 'Display InteractiveUtils.versioninfo() after installing'
|
||||||
required: false
|
required: false
|
||||||
@@ -19,7 +23,7 @@ outputs:
|
|||||||
julia-bindir:
|
julia-bindir:
|
||||||
description: 'Path to the directory containing the Julia executable. Equivalent to JULIA_BINDIR: https://docs.julialang.org/en/v1/manual/environment-variables/#JULIA_BINDIR'
|
description: 'Path to the directory containing the Julia executable. Equivalent to JULIA_BINDIR: https://docs.julialang.org/en/v1/manual/environment-variables/#JULIA_BINDIR'
|
||||||
runs:
|
runs:
|
||||||
using: 'node12'
|
using: 'node20'
|
||||||
main: 'dist/index.js'
|
main: 'dist/index.js'
|
||||||
branding:
|
branding:
|
||||||
icon: 'download'
|
icon: 'download'
|
||||||
|
|||||||
7
devdocs/README.md
Normal file
7
devdocs/README.md
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
# Devdocs for the `setup-julia` repo
|
||||||
|
|
||||||
|
If you want to make a pull request to this repo, please read the following:
|
||||||
|
1. [Local development](local_setup.md)
|
||||||
|
|
||||||
|
If you have commit access to this repo, you may be interested in the following:
|
||||||
|
1. [Making a new release of this action](making_a_new_release.md)
|
||||||
47
devdocs/local_setup.md
Normal file
47
devdocs/local_setup.md
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
# Local development
|
||||||
|
|
||||||
|
## 1. Clone the repo
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git clone git@github.com:julia-actions/setup-julia.git
|
||||||
|
cd setup-julia
|
||||||
|
```
|
||||||
|
|
||||||
|
## 2. Install NodeJS
|
||||||
|
|
||||||
|
### Unix, using `asdf` (recommended, but not required)
|
||||||
|
|
||||||
|
First, make sure that you have installed [`asdf`](https://asdf-vm.com/) on your local machine.
|
||||||
|
|
||||||
|
Then, `cd` to your clone of the repo and run the following commands:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
asdf plugin add nodejs
|
||||||
|
asdf install
|
||||||
|
```
|
||||||
|
|
||||||
|
This will use `asdf` to install the correct version of NodeJS.
|
||||||
|
|
||||||
|
### Unix, but not using `asdf`
|
||||||
|
|
||||||
|
Instead of using `asdf`, you can instead choose to install NodeJS manually.
|
||||||
|
|
||||||
|
First, check the `.tool-versions` file in this repo, and see what version of NodeJS you need. Then, install that same version of NodejS on your local machine.
|
||||||
|
|
||||||
|
### Windows
|
||||||
|
|
||||||
|
`asdf` does not (currently) support Windows. So on Windows, you have to install NodeJS manually.
|
||||||
|
|
||||||
|
First, check the `.tool-versions` file in this repo, and see what version of NodeJS you need. Then, install that same version of NodejS on your local machine.
|
||||||
|
|
||||||
|
## 3. Working locally
|
||||||
|
|
||||||
|
First, `cd` to your clone of the repo. Now you can run the following commands:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
npm ci
|
||||||
|
|
||||||
|
npm run build
|
||||||
|
```
|
||||||
|
|
||||||
|
When you are ready, you can commit your changes and push them to your PR.
|
||||||
128
devdocs/making_a_new_release.md
Normal file
128
devdocs/making_a_new_release.md
Normal file
@@ -0,0 +1,128 @@
|
|||||||
|
# Making a new release of this action (requires commit access)
|
||||||
|
|
||||||
|
If you have commit access to this repo, you can make a new release.
|
||||||
|
|
||||||
|
Here are the instructions.
|
||||||
|
|
||||||
|
## Step 1: Clone a fresh copy of the repo
|
||||||
|
|
||||||
|
We intentionally work in a brand-new copy of the repo.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git clone git@github.com:julia-actions/setup-julia.git
|
||||||
|
cd setup-julia
|
||||||
|
git checkout master
|
||||||
|
git submodule init
|
||||||
|
git submodule update
|
||||||
|
```
|
||||||
|
|
||||||
|
## Step 2: Make sure you have the right version of NodeJS
|
||||||
|
|
||||||
|
If you use [`asdf`](https://asdf-vm.com/), this is as simple as:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
asdf plugin add nodejs
|
||||||
|
asdf install
|
||||||
|
```
|
||||||
|
|
||||||
|
If you don't use `asdf`, then you need to:
|
||||||
|
1. Open the `./tool-versions` file in the root of the repo.
|
||||||
|
2. Make note of the NodeJS version listed in the `.tool-versions` file.
|
||||||
|
3. Install that same version of NodeJS on your machine.
|
||||||
|
4. Make sure that you are currently using that version of NodeJS (i.e. it is at the front of your PATH).
|
||||||
|
|
||||||
|
## Step 3: Edit the `version` field in `package.json`
|
||||||
|
|
||||||
|
```bash
|
||||||
|
vim package.json
|
||||||
|
|
||||||
|
# Edit the `version` number (should be line 2)
|
||||||
|
# Save your changes in Vim. Then exit Vim.
|
||||||
|
|
||||||
|
# For the remaining of this guide, let MAJOR.MINOR.PATCH refer
|
||||||
|
# to the new version number that you set.
|
||||||
|
|
||||||
|
git add package.json
|
||||||
|
|
||||||
|
# No need to commit yet.
|
||||||
|
# The release script will run `git commit`.
|
||||||
|
```
|
||||||
|
|
||||||
|
## Step 4: Remove the `dist/` line from the `.gitignore` file
|
||||||
|
|
||||||
|
```bash
|
||||||
|
vim .gitignore
|
||||||
|
# Delete the line that says `dist/` (it should be line 3)
|
||||||
|
# Save your changes in Vim. Then exit Vim.
|
||||||
|
|
||||||
|
git add .gitignore
|
||||||
|
|
||||||
|
# No need to commit yet.
|
||||||
|
# The release script will run `git commit`.
|
||||||
|
```
|
||||||
|
|
||||||
|
## Step 5: Make sure you have the necessary dependencies
|
||||||
|
|
||||||
|
The `build-release.sh` script requires the following dependencies:
|
||||||
|
|
||||||
|
1. Bash
|
||||||
|
2. `curl`
|
||||||
|
3. `git`
|
||||||
|
4. `jq`
|
||||||
|
5. `sed`
|
||||||
|
|
||||||
|
## Step 6: Run the `build-release.sh` script
|
||||||
|
|
||||||
|
```bash
|
||||||
|
ls -l bin/build-release.sh
|
||||||
|
chmod +x bin/build-release.sh
|
||||||
|
ls -l bin/build-release.sh
|
||||||
|
|
||||||
|
./bin/build-release.sh julia-actions/setup-julia
|
||||||
|
```
|
||||||
|
|
||||||
|
Wait a minute or two. The script will build everything and will create a new release branch named `releases/vMAJOR.MINOR.PATCH`.
|
||||||
|
|
||||||
|
## Step 7: Push ONLY the `releases/vMAJOR.MINOR.PATCH` branch
|
||||||
|
|
||||||
|
Only push the `releases/` branch. Do NOT push any tags yet.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git push origin releases/vMAJOR.MINOR.PATCH
|
||||||
|
```
|
||||||
|
|
||||||
|
Now you need to go to https://github.com/julia-actions/setup-julia/tree/releases/vMAJOR.MINOR.PATCH and wait for CI to finish running.
|
||||||
|
|
||||||
|
Do NOT proceed to the next step until CI is all green on the `releases/vMAJOR.MINOR.PATCH` branch.
|
||||||
|
|
||||||
|
## Step 8: Push the tags (only after CI is all green)
|
||||||
|
|
||||||
|
Once CI is all green on the `releases/vMAJOR.MINOR.PATCH` branch, you can push the tags.
|
||||||
|
|
||||||
|
You need to force-push.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git push --tags --force
|
||||||
|
```
|
||||||
|
|
||||||
|
## Step 9: Use the GitHub web UI to create a new GitHub Release
|
||||||
|
|
||||||
|
Go to https://github.com/julia-actions/setup-julia/releases and create a new release for the now-existant `vMAJOR.MINOR.PATCH` tag using the GitHub web interface.
|
||||||
|
|
||||||
|
## Step 10: Clean up your local repo
|
||||||
|
|
||||||
|
```bash
|
||||||
|
git submodule deinit --force .
|
||||||
|
git submodule update --init
|
||||||
|
git fetch --all --prune
|
||||||
|
git checkout master
|
||||||
|
git reset --hard origin/master
|
||||||
|
```
|
||||||
|
|
||||||
|
## Step 11: Delete your local repo
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cd ..
|
||||||
|
ls setup-julia
|
||||||
|
rm -rf setup-julia
|
||||||
|
```
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
# Contributors
|
# Misc notes for contributors
|
||||||
|
|
||||||
### Checkin
|
### Checkin
|
||||||
|
|
||||||
@@ -19,4 +19,4 @@ git commit -m "Informative commit message" # Commit. This will run Husky
|
|||||||
```
|
```
|
||||||
|
|
||||||
During the commit step, Husky will take care of formatting all files with [Prettier](https://github.com/prettier/prettier) as well as pruning out devDependencies using `npm prune --production`.
|
During the commit step, Husky will take care of formatting all files with [Prettier](https://github.com/prettier/prettier) as well as pruning out devDependencies using `npm prune --production`.
|
||||||
It will also make sure these changes are appropriately included in your commit (no further work is needed)
|
It will also make sure these changes are appropriately included in your commit (no further work is needed)
|
||||||
10103
dist/index.js
vendored
Normal file
10103
dist/index.js
vendored
Normal file
File diff suppressed because it is too large
Load Diff
193
lib/installer.js
generated
193
lib/installer.js
generated
@@ -1,20 +1,38 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
||||||
return new (P || (P = Promise))(function (resolve, reject) {
|
if (k2 === undefined) k2 = k;
|
||||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
var desc = Object.getOwnPropertyDescriptor(m, k);
|
||||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
||||||
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
|
desc = { enumerable: true, get: function() { return m[k]; } };
|
||||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
}
|
||||||
});
|
Object.defineProperty(o, k2, desc);
|
||||||
};
|
}) : (function(o, m, k, k2) {
|
||||||
|
if (k2 === undefined) k2 = k;
|
||||||
|
o[k2] = m[k];
|
||||||
|
}));
|
||||||
|
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
||||||
|
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
||||||
|
}) : function(o, v) {
|
||||||
|
o["default"] = v;
|
||||||
|
});
|
||||||
var __importStar = (this && this.__importStar) || function (mod) {
|
var __importStar = (this && this.__importStar) || function (mod) {
|
||||||
if (mod && mod.__esModule) return mod;
|
if (mod && mod.__esModule) return mod;
|
||||||
var result = {};
|
var result = {};
|
||||||
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
|
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
||||||
result["default"] = mod;
|
__setModuleDefault(result, mod);
|
||||||
return result;
|
return result;
|
||||||
};
|
};
|
||||||
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||||
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||||
|
return new (P || (P = Promise))(function (resolve, reject) {
|
||||||
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||||
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||||
|
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||||
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||||
|
});
|
||||||
|
};
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
|
exports.showVersionInfo = exports.installJulia = exports.getDownloadURL = exports.getFileInfo = exports.getJuliaVersion = exports.getJuliaVersions = exports.getJuliaVersionInfo = void 0;
|
||||||
const core = __importStar(require("@actions/core"));
|
const core = __importStar(require("@actions/core"));
|
||||||
const exec = __importStar(require("@actions/exec"));
|
const exec = __importStar(require("@actions/exec"));
|
||||||
const tc = __importStar(require("@actions/tool-cache"));
|
const tc = __importStar(require("@actions/tool-cache"));
|
||||||
@@ -24,6 +42,8 @@ const os = __importStar(require("os"));
|
|||||||
const path = __importStar(require("path"));
|
const path = __importStar(require("path"));
|
||||||
const retry = require("async-retry");
|
const retry = require("async-retry");
|
||||||
const semver = __importStar(require("semver"));
|
const semver = __importStar(require("semver"));
|
||||||
|
const LTS_VERSION = '1.6';
|
||||||
|
const MAJOR_VERSION = '1'; // Could be deduced from versions.json
|
||||||
// Translations between actions input and Julia arch names
|
// Translations between actions input and Julia arch names
|
||||||
const osMap = {
|
const osMap = {
|
||||||
'win32': 'winnt',
|
'win32': 'winnt',
|
||||||
@@ -32,7 +52,8 @@ const osMap = {
|
|||||||
};
|
};
|
||||||
const archMap = {
|
const archMap = {
|
||||||
'x86': 'i686',
|
'x86': 'i686',
|
||||||
'x64': 'x86_64'
|
'x64': 'x86_64',
|
||||||
|
'aarch64': 'aarch64'
|
||||||
};
|
};
|
||||||
// Store information about the environment
|
// Store information about the environment
|
||||||
const osPlat = os.platform(); // possible values: win32 (Windows), linux (Linux), darwin (macOS)
|
const osPlat = os.platform(); // possible values: win32 (Windows), linux (Linux), darwin (macOS)
|
||||||
@@ -65,8 +86,9 @@ function getJuliaVersionInfo() {
|
|||||||
const versionsFile = yield retry((bail) => __awaiter(this, void 0, void 0, function* () {
|
const versionsFile = yield retry((bail) => __awaiter(this, void 0, void 0, function* () {
|
||||||
return yield tc.downloadTool('https://julialang-s3.julialang.org/bin/versions.json');
|
return yield tc.downloadTool('https://julialang-s3.julialang.org/bin/versions.json');
|
||||||
}), {
|
}), {
|
||||||
|
retries: 5,
|
||||||
onRetry: (err) => {
|
onRetry: (err) => {
|
||||||
core.debug(`Download of versions.json failed, trying again. Error: ${err}`);
|
core.info(`Download of versions.json failed, trying again. Error: ${err}`);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return JSON.parse(fs.readFileSync(versionsFile).toString());
|
return JSON.parse(fs.readFileSync(versionsFile).toString());
|
||||||
@@ -86,13 +108,19 @@ function getJuliaVersions(versionInfo) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
exports.getJuliaVersions = getJuliaVersions;
|
exports.getJuliaVersions = getJuliaVersions;
|
||||||
function getJuliaVersion(availableReleases, versionInput) {
|
function getJuliaVersion(availableReleases, versionInput, includePrerelease = false) {
|
||||||
if (semver.valid(versionInput) == versionInput || versionInput.endsWith('nightly')) {
|
if (semver.valid(versionInput) == versionInput || versionInput.endsWith('nightly')) {
|
||||||
// versionInput is a valid version or a nightly version, use it directly
|
// versionInput is a valid version or a nightly version, use it directly
|
||||||
return versionInput;
|
return versionInput;
|
||||||
}
|
}
|
||||||
|
if (versionInput == 'lts') {
|
||||||
|
return getJuliaVersion(availableReleases, LTS_VERSION, false);
|
||||||
|
}
|
||||||
|
if (versionInput == 'pre') {
|
||||||
|
return getJuliaVersion(availableReleases, MAJOR_VERSION, true);
|
||||||
|
}
|
||||||
// Use the highest available version that matches versionInput
|
// Use the highest available version that matches versionInput
|
||||||
let version = semver.maxSatisfying(availableReleases, versionInput);
|
let version = semver.maxSatisfying(availableReleases, versionInput, { includePrerelease });
|
||||||
if (version == null) {
|
if (version == null) {
|
||||||
throw new Error(`Could not find a Julia version that matches ${versionInput}`);
|
throw new Error(`Could not find a Julia version that matches ${versionInput}`);
|
||||||
}
|
}
|
||||||
@@ -101,30 +129,87 @@ function getJuliaVersion(availableReleases, versionInput) {
|
|||||||
return version;
|
return version;
|
||||||
}
|
}
|
||||||
exports.getJuliaVersion = getJuliaVersion;
|
exports.getJuliaVersion = getJuliaVersion;
|
||||||
function getNightlyFileName(arch) {
|
function getDesiredFileExts() {
|
||||||
let versionExt, ext;
|
let fileExt1;
|
||||||
|
let hasFileExt2;
|
||||||
|
let fileExt2;
|
||||||
if (osPlat == 'win32') {
|
if (osPlat == 'win32') {
|
||||||
versionExt = arch == 'x64' ? '-win64' : '-win32';
|
fileExt1 = 'tar.gz';
|
||||||
ext = 'exe';
|
hasFileExt2 = true;
|
||||||
|
fileExt2 = 'exe';
|
||||||
}
|
}
|
||||||
else if (osPlat == 'darwin') {
|
else if (osPlat == 'darwin') {
|
||||||
if (arch == 'x86') {
|
fileExt1 = 'tar.gz';
|
||||||
throw new Error('32-bit Julia is not available on macOS');
|
hasFileExt2 = true;
|
||||||
}
|
fileExt2 = 'dmg';
|
||||||
versionExt = '-mac64';
|
|
||||||
ext = 'dmg';
|
|
||||||
}
|
}
|
||||||
else if (osPlat === 'linux') {
|
else if (osPlat === 'linux') {
|
||||||
versionExt = arch == 'x64' ? '-linux64' : '-linux32';
|
fileExt1 = 'tar.gz';
|
||||||
ext = 'tar.gz';
|
hasFileExt2 = false;
|
||||||
|
fileExt2 = '';
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
throw new Error(`Platform ${osPlat} is not supported`);
|
throw new Error(`Platform ${osPlat} is not supported`);
|
||||||
}
|
}
|
||||||
return `julia-latest${versionExt}.${ext}`;
|
return [fileExt1, hasFileExt2, fileExt2];
|
||||||
|
}
|
||||||
|
function getNightlyFileName(arch) {
|
||||||
|
let versionExt;
|
||||||
|
let fileExt1;
|
||||||
|
[fileExt1, ,] = getDesiredFileExts();
|
||||||
|
if (osPlat == 'win32') {
|
||||||
|
if (arch == 'x86') {
|
||||||
|
versionExt = '-win32';
|
||||||
|
}
|
||||||
|
else if (arch == 'aarch64') {
|
||||||
|
throw new Error('Aarch64 Julia is not available on Windows');
|
||||||
|
}
|
||||||
|
else if (arch == 'x64') {
|
||||||
|
versionExt = '-win64';
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
throw new Error(`Architecture ${arch} is not supported on Windows`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (osPlat == 'darwin') {
|
||||||
|
if (arch == 'x86') {
|
||||||
|
throw new Error('32-bit (x86) Julia is not available on macOS');
|
||||||
|
}
|
||||||
|
else if (arch == 'aarch64') {
|
||||||
|
versionExt = '-macaarch64';
|
||||||
|
}
|
||||||
|
else if (arch == 'x64') {
|
||||||
|
versionExt = '-mac64';
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
throw new Error(`Architecture ${arch} is not supported on macOS`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (osPlat === 'linux') {
|
||||||
|
if (arch == 'x86') {
|
||||||
|
versionExt = '-linux32';
|
||||||
|
}
|
||||||
|
else if (arch == 'aarch64') {
|
||||||
|
versionExt = '-linux-aarch64';
|
||||||
|
}
|
||||||
|
else if (arch == 'x64') {
|
||||||
|
versionExt = '-linux64';
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
throw new Error(`Architecture ${arch} is not supported on Linux`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
throw new Error(`Platform ${osPlat} is not supported`);
|
||||||
|
}
|
||||||
|
return `julia-latest${versionExt}.${fileExt1}`;
|
||||||
}
|
}
|
||||||
function getFileInfo(versionInfo, version, arch) {
|
function getFileInfo(versionInfo, version, arch) {
|
||||||
const err = `Could not find ${archMap[arch]}/${version} binaries`;
|
const err = `Could not find ${archMap[arch]}/${version} binaries`;
|
||||||
|
let fileExt1;
|
||||||
|
let hasFileExt2;
|
||||||
|
let fileExt2;
|
||||||
|
[fileExt1, hasFileExt2, fileExt2] = getDesiredFileExts();
|
||||||
if (version.endsWith('nightly')) {
|
if (version.endsWith('nightly')) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@@ -133,7 +218,19 @@ function getFileInfo(versionInfo, version, arch) {
|
|||||||
}
|
}
|
||||||
for (let file of versionInfo[version].files) {
|
for (let file of versionInfo[version].files) {
|
||||||
if (file.os == osMap[osPlat] && file.arch == archMap[arch]) {
|
if (file.os == osMap[osPlat] && file.arch == archMap[arch]) {
|
||||||
return file;
|
if (file.extension == fileExt1) {
|
||||||
|
return file;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (hasFileExt2) {
|
||||||
|
core.debug(`Could not find ${fileExt1}; trying to find ${fileExt2} instead`);
|
||||||
|
for (let file of versionInfo[version].files) {
|
||||||
|
if (file.os == osMap[osPlat] && file.arch == archMap[arch]) {
|
||||||
|
if (file.extension == fileExt2) {
|
||||||
|
return file;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
throw err;
|
throw err;
|
||||||
@@ -157,7 +254,7 @@ function getDownloadURL(fileInfo, version, arch) {
|
|||||||
return fileInfo.url;
|
return fileInfo.url;
|
||||||
}
|
}
|
||||||
exports.getDownloadURL = getDownloadURL;
|
exports.getDownloadURL = getDownloadURL;
|
||||||
function installJulia(versionInfo, version, arch) {
|
function installJulia(dest, versionInfo, version, arch) {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
// Download Julia
|
// Download Julia
|
||||||
const fileInfo = getFileInfo(versionInfo, version, arch);
|
const fileInfo = getFileInfo(versionInfo, version, arch);
|
||||||
@@ -168,8 +265,9 @@ function installJulia(versionInfo, version, arch) {
|
|||||||
const juliaDownloadPath = yield retry((bail) => __awaiter(this, void 0, void 0, function* () {
|
const juliaDownloadPath = yield retry((bail) => __awaiter(this, void 0, void 0, function* () {
|
||||||
return yield tc.downloadTool(downloadURL);
|
return yield tc.downloadTool(downloadURL);
|
||||||
}), {
|
}), {
|
||||||
|
retries: 5,
|
||||||
onRetry: (err) => {
|
onRetry: (err) => {
|
||||||
core.debug(`Download of ${downloadURL} failed, trying again. Error: ${err}`);
|
core.info(`Download of ${downloadURL} failed, trying again. Error: ${err}`);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
// Verify checksum
|
// Verify checksum
|
||||||
@@ -183,26 +281,41 @@ function installJulia(versionInfo, version, arch) {
|
|||||||
else {
|
else {
|
||||||
core.debug('Skipping checksum check for nightly binaries.');
|
core.debug('Skipping checksum check for nightly binaries.');
|
||||||
}
|
}
|
||||||
const tempInstallDir = fs.mkdtempSync(`julia-${arch}-${version}-`);
|
|
||||||
// Install it
|
// Install it
|
||||||
switch (osPlat) {
|
switch (osPlat) {
|
||||||
case 'linux':
|
case 'linux':
|
||||||
// tc.extractTar doesn't support stripping components, so we have to call tar manually
|
// tc.extractTar doesn't support stripping components, so we have to call tar manually
|
||||||
yield exec.exec('tar', ['xf', juliaDownloadPath, '--strip-components=1', '-C', tempInstallDir]);
|
yield exec.exec('tar', ['xf', juliaDownloadPath, '--strip-components=1', '-C', dest]);
|
||||||
return tempInstallDir;
|
return dest;
|
||||||
case 'win32':
|
case 'win32':
|
||||||
if (version.endsWith('nightly') || semver.gtr(version, '1.3', { includePrerelease: true })) {
|
if (fileInfo !== null && fileInfo.extension == 'exe') {
|
||||||
// The installer changed in 1.4: https://github.com/JuliaLang/julia/blob/ef0c9108b12f3ae177c51037934351ffa703b0b5/NEWS.md#build-system-changes
|
if (version.endsWith('nightly') || semver.gtr(version, '1.3', { includePrerelease: true })) {
|
||||||
yield exec.exec('powershell', ['-Command', `Start-Process -FilePath ${juliaDownloadPath} -ArgumentList "/SILENT /dir=${path.join(process.cwd(), tempInstallDir)}" -NoNewWindow -Wait`]);
|
// The installer changed in 1.4: https://github.com/JuliaLang/julia/blob/ef0c9108b12f3ae177c51037934351ffa703b0b5/NEWS.md#build-system-changes
|
||||||
|
yield exec.exec('powershell', ['-Command', `Start-Process -FilePath ${juliaDownloadPath} -ArgumentList "/SILENT /dir=${path.join(process.cwd(), dest)}" -NoNewWindow -Wait`]);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
yield exec.exec('powershell', ['-Command', `Start-Process -FilePath ${juliaDownloadPath} -ArgumentList "/S /D=${path.join(process.cwd(), dest)}" -NoNewWindow -Wait`]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
yield exec.exec('powershell', ['-Command', `Start-Process -FilePath ${juliaDownloadPath} -ArgumentList "/S /D=${path.join(process.cwd(), tempInstallDir)}" -NoNewWindow -Wait`]);
|
// This is the more common path. Using .tar.gz is much faster
|
||||||
|
// don't use the Git bash provided tar. Issue #205
|
||||||
|
// https://github.com/julia-actions/setup-julia/issues/205
|
||||||
|
yield exec.exec('powershell', ['-Command', `& "$env:WINDIR/System32/tar" xf ${juliaDownloadPath} --strip-components=1 -C ${dest}`]);
|
||||||
}
|
}
|
||||||
return tempInstallDir;
|
return dest;
|
||||||
case 'darwin':
|
case 'darwin':
|
||||||
yield exec.exec('hdiutil', ['attach', juliaDownloadPath]);
|
if (fileInfo !== null && fileInfo.extension == 'dmg') {
|
||||||
yield exec.exec('/bin/bash', ['-c', `cp -a /Volumes/Julia-*/Julia-*.app/Contents/Resources/julia ${tempInstallDir}`]);
|
core.debug(`Support for .dmg files is deprecated and may be removed in a future release`);
|
||||||
return path.join(tempInstallDir, 'julia');
|
yield exec.exec('hdiutil', ['attach', juliaDownloadPath]);
|
||||||
|
yield exec.exec('/bin/bash', ['-c', `cp -a /Volumes/Julia-*/Julia-*.app/Contents/Resources/julia ${dest}`]);
|
||||||
|
return path.join(dest, 'julia');
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// tc.extractTar doesn't support stripping components, so we have to call tar manually
|
||||||
|
yield exec.exec('tar', ['xf', juliaDownloadPath, '--strip-components=1', '-C', dest]);
|
||||||
|
return dest;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
throw new Error(`Platform ${osPlat} is not supported`);
|
throw new Error(`Platform ${osPlat} is not supported`);
|
||||||
}
|
}
|
||||||
|
|||||||
70
lib/setup-julia.js
generated
70
lib/setup-julia.js
generated
@@ -1,19 +1,36 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
||||||
return new (P || (P = Promise))(function (resolve, reject) {
|
if (k2 === undefined) k2 = k;
|
||||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
var desc = Object.getOwnPropertyDescriptor(m, k);
|
||||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
||||||
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
|
desc = { enumerable: true, get: function() { return m[k]; } };
|
||||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
}
|
||||||
});
|
Object.defineProperty(o, k2, desc);
|
||||||
};
|
}) : (function(o, m, k, k2) {
|
||||||
|
if (k2 === undefined) k2 = k;
|
||||||
|
o[k2] = m[k];
|
||||||
|
}));
|
||||||
|
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
||||||
|
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
||||||
|
}) : function(o, v) {
|
||||||
|
o["default"] = v;
|
||||||
|
});
|
||||||
var __importStar = (this && this.__importStar) || function (mod) {
|
var __importStar = (this && this.__importStar) || function (mod) {
|
||||||
if (mod && mod.__esModule) return mod;
|
if (mod && mod.__esModule) return mod;
|
||||||
var result = {};
|
var result = {};
|
||||||
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
|
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
||||||
result["default"] = mod;
|
__setModuleDefault(result, mod);
|
||||||
return result;
|
return result;
|
||||||
};
|
};
|
||||||
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
||||||
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
||||||
|
return new (P || (P = Promise))(function (resolve, reject) {
|
||||||
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
||||||
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
||||||
|
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
||||||
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
||||||
|
});
|
||||||
|
};
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
const core = __importStar(require("@actions/core"));
|
const core = __importStar(require("@actions/core"));
|
||||||
const tc = __importStar(require("@actions/tool-cache"));
|
const tc = __importStar(require("@actions/tool-cache"));
|
||||||
@@ -21,6 +38,15 @@ const fs = __importStar(require("fs"));
|
|||||||
const https = __importStar(require("https"));
|
const https = __importStar(require("https"));
|
||||||
const path = __importStar(require("path"));
|
const path = __importStar(require("path"));
|
||||||
const installer = __importStar(require("./installer"));
|
const installer = __importStar(require("./installer"));
|
||||||
|
const archSynonyms = {
|
||||||
|
'x86': 'x86',
|
||||||
|
'X86': 'x86',
|
||||||
|
'x64': 'x64',
|
||||||
|
'X64': 'x64',
|
||||||
|
'aarch64': 'aarch64',
|
||||||
|
'ARM64': 'aarch64',
|
||||||
|
'arm64': 'aarch64'
|
||||||
|
};
|
||||||
function run() {
|
function run() {
|
||||||
return __awaiter(this, void 0, void 0, function* () {
|
return __awaiter(this, void 0, void 0, function* () {
|
||||||
try {
|
try {
|
||||||
@@ -41,7 +67,8 @@ function run() {
|
|||||||
}
|
}
|
||||||
// Inputs
|
// Inputs
|
||||||
const versionInput = core.getInput('version');
|
const versionInput = core.getInput('version');
|
||||||
const arch = core.getInput('arch');
|
const includePrereleases = core.getInput('include-all-prereleases') == 'true';
|
||||||
|
const originalArchInput = core.getInput('arch');
|
||||||
// It can easily happen that, for example, a workflow file contains an input `version: ${{ matrix.julia-version }}`
|
// It can easily happen that, for example, a workflow file contains an input `version: ${{ matrix.julia-version }}`
|
||||||
// while the strategy matrix only contains a key `${{ matrix.version }}`.
|
// while the strategy matrix only contains a key `${{ matrix.version }}`.
|
||||||
// In that case, we want the action to fail, rather than trying to download julia from an URL that's missing parts and 404ing.
|
// In that case, we want the action to fail, rather than trying to download julia from an URL that's missing parts and 404ing.
|
||||||
@@ -50,12 +77,13 @@ function run() {
|
|||||||
if (!versionInput) {
|
if (!versionInput) {
|
||||||
throw new Error('Version input must not be null');
|
throw new Error('Version input must not be null');
|
||||||
}
|
}
|
||||||
if (!arch) {
|
if (!originalArchInput) {
|
||||||
throw new Error(`Arch input must not be null`);
|
throw new Error(`Arch input must not be null`);
|
||||||
}
|
}
|
||||||
|
const arch = archSynonyms[originalArchInput];
|
||||||
const versionInfo = yield installer.getJuliaVersionInfo();
|
const versionInfo = yield installer.getJuliaVersionInfo();
|
||||||
const availableReleases = yield installer.getJuliaVersions(versionInfo);
|
const availableReleases = yield installer.getJuliaVersions(versionInfo);
|
||||||
const version = installer.getJuliaVersion(availableReleases, versionInput);
|
const version = installer.getJuliaVersion(availableReleases, versionInput, includePrereleases);
|
||||||
core.debug(`selected Julia version: ${arch}/${version}`);
|
core.debug(`selected Julia version: ${arch}/${version}`);
|
||||||
core.setOutput('julia-version', version);
|
core.setOutput('julia-version', version);
|
||||||
// Search in cache
|
// Search in cache
|
||||||
@@ -63,12 +91,18 @@ function run() {
|
|||||||
juliaPath = tc.find('julia', version, arch);
|
juliaPath = tc.find('julia', version, arch);
|
||||||
if (!juliaPath) {
|
if (!juliaPath) {
|
||||||
core.debug(`could not find Julia ${arch}/${version} in cache`);
|
core.debug(`could not find Julia ${arch}/${version} in cache`);
|
||||||
const juliaInstallationPath = yield installer.installJulia(versionInfo, version, arch);
|
// https://github.com/julia-actions/setup-julia/pull/196
|
||||||
// Add it to cache
|
// we want julia to be installed with unmodified file mtimes
|
||||||
juliaPath = yield tc.cacheDir(juliaInstallationPath, 'julia', version, arch);
|
// but `tc.cacheDir` uses `cp` internally which destroys mtime
|
||||||
|
// and `tc` provides no API to get the tool directory alone
|
||||||
|
// so hack it by installing a empty directory then use the path it returns
|
||||||
|
// and extract the archives directly to that location
|
||||||
|
const emptyDir = fs.mkdtempSync('empty');
|
||||||
|
juliaPath = yield tc.cacheDir(emptyDir, 'julia', version, arch);
|
||||||
|
yield installer.installJulia(juliaPath, versionInfo, version, arch);
|
||||||
core.debug(`added Julia to cache: ${juliaPath}`);
|
core.debug(`added Julia to cache: ${juliaPath}`);
|
||||||
// Remove temporary dir
|
// Remove empty dir
|
||||||
fs.rmdirSync(juliaInstallationPath, { recursive: true });
|
fs.rmdirSync(emptyDir);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
core.debug(`using cached version of Julia: ${juliaPath}`);
|
core.debug(`using cached version of Julia: ${juliaPath}`);
|
||||||
|
|||||||
18041
package-lock.json
generated
18041
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
37
package.json
37
package.json
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "setup-julia",
|
"name": "setup-julia",
|
||||||
"version": "1.6.1",
|
"version": "2.2.0",
|
||||||
"private": true,
|
"private": true,
|
||||||
"description": "setup Julia action",
|
"description": "setup Julia action",
|
||||||
"main": "lib/setup-julia.js",
|
"main": "lib/setup-julia.js",
|
||||||
@@ -21,24 +21,25 @@
|
|||||||
"author": "Sascha Mann <git@mail.saschamann.eu>",
|
"author": "Sascha Mann <git@mail.saschamann.eu>",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@actions/core": "^1.2.6",
|
"@actions/core": "^1.10.1",
|
||||||
"@actions/exec": "^1.0.0",
|
"@actions/exec": "^1.1.1",
|
||||||
"@actions/io": "^1.0.0",
|
"@actions/io": "^1.1.3",
|
||||||
"@actions/tool-cache": "^1.0.0",
|
"@actions/tool-cache": "^2.0.1",
|
||||||
"async-retry": "^1.3.1",
|
"async-retry": "^1.3.3",
|
||||||
"semver": "^6.3.0"
|
"semver": "^7.6.2"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/async-retry": "^1.4.2",
|
"@types/async-retry": "^1.4.8",
|
||||||
"@types/jest": "^24.0.13",
|
"@types/jest": "^29.5.12",
|
||||||
"@types/node": "^12.12.7",
|
"@types/node": "^20.14.6",
|
||||||
"@types/semver": "^6.0.0",
|
"@types/retry": "^0.12.5",
|
||||||
"@zeit/ncc": "^0.22.0",
|
"@types/semver": "^7.5.8",
|
||||||
"jest": "^24.8.0",
|
"@vercel/ncc": "^0.38.1",
|
||||||
"jest-circus": "^24.7.1",
|
"jest": "^29.7.0",
|
||||||
"nock": "^11.7.2",
|
"jest-circus": "^29.7.0",
|
||||||
"prettier": "^1.17.1",
|
"nock": "^13.5.4",
|
||||||
"ts-jest": "^26.0.0",
|
"prettier": "^3.3.2",
|
||||||
"typescript": "^3.5.1"
|
"ts-jest": "^29.1.5",
|
||||||
|
"typescript": "^5.4.5"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
151
src/installer.ts
151
src/installer.ts
@@ -10,6 +10,9 @@ import retry = require('async-retry')
|
|||||||
|
|
||||||
import * as semver from 'semver'
|
import * as semver from 'semver'
|
||||||
|
|
||||||
|
const LTS_VERSION = '1.6'
|
||||||
|
const MAJOR_VERSION = '1' // Could be deduced from versions.json
|
||||||
|
|
||||||
// Translations between actions input and Julia arch names
|
// Translations between actions input and Julia arch names
|
||||||
const osMap = {
|
const osMap = {
|
||||||
'win32': 'winnt',
|
'win32': 'winnt',
|
||||||
@@ -18,7 +21,8 @@ const osMap = {
|
|||||||
}
|
}
|
||||||
const archMap = {
|
const archMap = {
|
||||||
'x86': 'i686',
|
'x86': 'i686',
|
||||||
'x64': 'x86_64'
|
'x64': 'x86_64',
|
||||||
|
'aarch64': 'aarch64'
|
||||||
}
|
}
|
||||||
|
|
||||||
// Store information about the environment
|
// Store information about the environment
|
||||||
@@ -53,8 +57,9 @@ export async function getJuliaVersionInfo(): Promise<object> {
|
|||||||
const versionsFile = await retry(async (bail: Function) => {
|
const versionsFile = await retry(async (bail: Function) => {
|
||||||
return await tc.downloadTool('https://julialang-s3.julialang.org/bin/versions.json')
|
return await tc.downloadTool('https://julialang-s3.julialang.org/bin/versions.json')
|
||||||
}, {
|
}, {
|
||||||
|
retries: 5,
|
||||||
onRetry: (err: Error) => {
|
onRetry: (err: Error) => {
|
||||||
core.debug(`Download of versions.json failed, trying again. Error: ${err}`)
|
core.info(`Download of versions.json failed, trying again. Error: ${err}`)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
@@ -74,14 +79,22 @@ export async function getJuliaVersions(versionInfo): Promise<string[]> {
|
|||||||
return versions
|
return versions
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getJuliaVersion(availableReleases: string[], versionInput: string): string {
|
export function getJuliaVersion(availableReleases: string[], versionInput: string, includePrerelease: boolean = false): string {
|
||||||
if (semver.valid(versionInput) == versionInput || versionInput.endsWith('nightly')) {
|
if (semver.valid(versionInput) == versionInput || versionInput.endsWith('nightly')) {
|
||||||
// versionInput is a valid version or a nightly version, use it directly
|
// versionInput is a valid version or a nightly version, use it directly
|
||||||
return versionInput
|
return versionInput
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (versionInput == 'lts') {
|
||||||
|
return getJuliaVersion(availableReleases, LTS_VERSION, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (versionInput == 'pre') {
|
||||||
|
return getJuliaVersion(availableReleases, MAJOR_VERSION, true)
|
||||||
|
}
|
||||||
|
|
||||||
// Use the highest available version that matches versionInput
|
// Use the highest available version that matches versionInput
|
||||||
let version = semver.maxSatisfying(availableReleases, versionInput)
|
let version = semver.maxSatisfying(availableReleases, versionInput, {includePrerelease})
|
||||||
if (version == null) {
|
if (version == null) {
|
||||||
throw new Error(`Could not find a Julia version that matches ${versionInput}`)
|
throw new Error(`Could not find a Julia version that matches ${versionInput}`)
|
||||||
}
|
}
|
||||||
@@ -92,31 +105,80 @@ export function getJuliaVersion(availableReleases: string[], versionInput: strin
|
|||||||
return version
|
return version
|
||||||
}
|
}
|
||||||
|
|
||||||
function getNightlyFileName(arch: string): string {
|
function getDesiredFileExts(): [string, boolean, string] {
|
||||||
let versionExt: string, ext: string
|
let fileExt1: string
|
||||||
|
let hasFileExt2: boolean
|
||||||
|
let fileExt2: string
|
||||||
|
|
||||||
if (osPlat == 'win32') {
|
if (osPlat == 'win32') {
|
||||||
versionExt = arch == 'x64' ? '-win64' : '-win32'
|
fileExt1 = 'tar.gz'
|
||||||
ext = 'exe'
|
hasFileExt2 = true
|
||||||
|
fileExt2 = 'exe'
|
||||||
} else if (osPlat == 'darwin') {
|
} else if (osPlat == 'darwin') {
|
||||||
if (arch == 'x86') {
|
fileExt1 = 'tar.gz'
|
||||||
throw new Error('32-bit Julia is not available on macOS')
|
hasFileExt2 = true
|
||||||
}
|
fileExt2 = 'dmg'
|
||||||
versionExt = '-mac64'
|
|
||||||
ext = 'dmg'
|
|
||||||
} else if (osPlat === 'linux') {
|
} else if (osPlat === 'linux') {
|
||||||
versionExt = arch == 'x64' ? '-linux64' : '-linux32'
|
fileExt1 = 'tar.gz'
|
||||||
ext = 'tar.gz'
|
hasFileExt2 = false
|
||||||
|
fileExt2 = ''
|
||||||
} else {
|
} else {
|
||||||
throw new Error(`Platform ${osPlat} is not supported`)
|
throw new Error(`Platform ${osPlat} is not supported`)
|
||||||
}
|
}
|
||||||
|
|
||||||
return `julia-latest${versionExt}.${ext}`
|
return [fileExt1, hasFileExt2, fileExt2]
|
||||||
|
}
|
||||||
|
|
||||||
|
function getNightlyFileName(arch: string): string {
|
||||||
|
let versionExt: string
|
||||||
|
let fileExt1: string
|
||||||
|
[fileExt1, , ] = getDesiredFileExts()
|
||||||
|
|
||||||
|
if (osPlat == 'win32') {
|
||||||
|
if (arch == 'x86') {
|
||||||
|
versionExt = '-win32'
|
||||||
|
} else if (arch == 'aarch64') {
|
||||||
|
throw new Error('Aarch64 Julia is not available on Windows')
|
||||||
|
} else if (arch == 'x64') {
|
||||||
|
versionExt = '-win64'
|
||||||
|
} else {
|
||||||
|
throw new Error(`Architecture ${arch} is not supported on Windows`)
|
||||||
|
}
|
||||||
|
} else if (osPlat == 'darwin') {
|
||||||
|
if (arch == 'x86') {
|
||||||
|
throw new Error('32-bit (x86) Julia is not available on macOS')
|
||||||
|
} else if (arch == 'aarch64') {
|
||||||
|
versionExt = '-macaarch64'
|
||||||
|
} else if (arch == 'x64') {
|
||||||
|
versionExt = '-mac64'
|
||||||
|
} else {
|
||||||
|
throw new Error(`Architecture ${arch} is not supported on macOS`)
|
||||||
|
}
|
||||||
|
} else if (osPlat === 'linux') {
|
||||||
|
if (arch == 'x86') {
|
||||||
|
versionExt = '-linux32'
|
||||||
|
} else if (arch == 'aarch64') {
|
||||||
|
versionExt = '-linux-aarch64'
|
||||||
|
} else if (arch == 'x64') {
|
||||||
|
versionExt = '-linux64'
|
||||||
|
} else {
|
||||||
|
throw new Error(`Architecture ${arch} is not supported on Linux`)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
throw new Error(`Platform ${osPlat} is not supported`)
|
||||||
|
}
|
||||||
|
|
||||||
|
return `julia-latest${versionExt}.${fileExt1}`
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getFileInfo(versionInfo, version: string, arch: string) {
|
export function getFileInfo(versionInfo, version: string, arch: string) {
|
||||||
const err = `Could not find ${archMap[arch]}/${version} binaries`
|
const err = `Could not find ${archMap[arch]}/${version} binaries`
|
||||||
|
|
||||||
|
let fileExt1: string
|
||||||
|
let hasFileExt2: boolean
|
||||||
|
let fileExt2: string
|
||||||
|
[fileExt1, hasFileExt2, fileExt2] = getDesiredFileExts()
|
||||||
|
|
||||||
if (version.endsWith('nightly')) {
|
if (version.endsWith('nightly')) {
|
||||||
return null
|
return null
|
||||||
}
|
}
|
||||||
@@ -127,7 +189,20 @@ export function getFileInfo(versionInfo, version: string, arch: string) {
|
|||||||
|
|
||||||
for (let file of versionInfo[version].files) {
|
for (let file of versionInfo[version].files) {
|
||||||
if (file.os == osMap[osPlat] && file.arch == archMap[arch]) {
|
if (file.os == osMap[osPlat] && file.arch == archMap[arch]) {
|
||||||
return file
|
if (file.extension == fileExt1) {
|
||||||
|
return file
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hasFileExt2) {
|
||||||
|
core.debug(`Could not find ${fileExt1}; trying to find ${fileExt2} instead`)
|
||||||
|
for (let file of versionInfo[version].files) {
|
||||||
|
if (file.os == osMap[osPlat] && file.arch == archMap[arch]) {
|
||||||
|
if (file.extension == fileExt2) {
|
||||||
|
return file
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -155,7 +230,7 @@ export function getDownloadURL(fileInfo, version: string, arch: string): string
|
|||||||
return fileInfo.url
|
return fileInfo.url
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function installJulia(versionInfo, version: string, arch: string): Promise<string> {
|
export async function installJulia(dest: string, versionInfo, version: string, arch: string): Promise<string> {
|
||||||
// Download Julia
|
// Download Julia
|
||||||
const fileInfo = getFileInfo(versionInfo, version, arch)
|
const fileInfo = getFileInfo(versionInfo, version, arch)
|
||||||
const downloadURL = getDownloadURL(fileInfo, version, arch)
|
const downloadURL = getDownloadURL(fileInfo, version, arch)
|
||||||
@@ -166,12 +241,12 @@ export async function installJulia(versionInfo, version: string, arch: string):
|
|||||||
const juliaDownloadPath = await retry(async (bail: Function) => {
|
const juliaDownloadPath = await retry(async (bail: Function) => {
|
||||||
return await tc.downloadTool(downloadURL)
|
return await tc.downloadTool(downloadURL)
|
||||||
}, {
|
}, {
|
||||||
|
retries: 5,
|
||||||
onRetry: (err: Error) => {
|
onRetry: (err: Error) => {
|
||||||
core.debug(`Download of ${downloadURL} failed, trying again. Error: ${err}`)
|
core.info(`Download of ${downloadURL} failed, trying again. Error: ${err}`)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
// Verify checksum
|
// Verify checksum
|
||||||
if (!version.endsWith('nightly')) {
|
if (!version.endsWith('nightly')) {
|
||||||
const checkSum = await calculateChecksum(juliaDownloadPath)
|
const checkSum = await calculateChecksum(juliaDownloadPath)
|
||||||
@@ -183,26 +258,38 @@ export async function installJulia(versionInfo, version: string, arch: string):
|
|||||||
core.debug('Skipping checksum check for nightly binaries.')
|
core.debug('Skipping checksum check for nightly binaries.')
|
||||||
}
|
}
|
||||||
|
|
||||||
const tempInstallDir = fs.mkdtempSync(`julia-${arch}-${version}-`)
|
|
||||||
|
|
||||||
// Install it
|
// Install it
|
||||||
switch (osPlat) {
|
switch (osPlat) {
|
||||||
case 'linux':
|
case 'linux':
|
||||||
// tc.extractTar doesn't support stripping components, so we have to call tar manually
|
// tc.extractTar doesn't support stripping components, so we have to call tar manually
|
||||||
await exec.exec('tar', ['xf', juliaDownloadPath, '--strip-components=1', '-C', tempInstallDir])
|
await exec.exec('tar', ['xf', juliaDownloadPath, '--strip-components=1', '-C', dest])
|
||||||
return tempInstallDir
|
return dest
|
||||||
case 'win32':
|
case 'win32':
|
||||||
if (version.endsWith('nightly') || semver.gtr(version, '1.3', {includePrerelease: true})) {
|
if (fileInfo !== null && fileInfo.extension == 'exe') {
|
||||||
// The installer changed in 1.4: https://github.com/JuliaLang/julia/blob/ef0c9108b12f3ae177c51037934351ffa703b0b5/NEWS.md#build-system-changes
|
if (version.endsWith('nightly') || semver.gtr(version, '1.3', {includePrerelease: true})) {
|
||||||
await exec.exec('powershell', ['-Command', `Start-Process -FilePath ${juliaDownloadPath} -ArgumentList "/SILENT /dir=${path.join(process.cwd(), tempInstallDir)}" -NoNewWindow -Wait`])
|
// The installer changed in 1.4: https://github.com/JuliaLang/julia/blob/ef0c9108b12f3ae177c51037934351ffa703b0b5/NEWS.md#build-system-changes
|
||||||
|
await exec.exec('powershell', ['-Command', `Start-Process -FilePath ${juliaDownloadPath} -ArgumentList "/SILENT /dir=${path.join(process.cwd(), dest)}" -NoNewWindow -Wait`])
|
||||||
|
} else {
|
||||||
|
await exec.exec('powershell', ['-Command', `Start-Process -FilePath ${juliaDownloadPath} -ArgumentList "/S /D=${path.join(process.cwd(), dest)}" -NoNewWindow -Wait`])
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
await exec.exec('powershell', ['-Command', `Start-Process -FilePath ${juliaDownloadPath} -ArgumentList "/S /D=${path.join(process.cwd(), tempInstallDir)}" -NoNewWindow -Wait`])
|
// This is the more common path. Using .tar.gz is much faster
|
||||||
|
// don't use the Git bash provided tar. Issue #205
|
||||||
|
// https://github.com/julia-actions/setup-julia/issues/205
|
||||||
|
await exec.exec('powershell', ['-Command', `& "$env:WINDIR/System32/tar" xf ${juliaDownloadPath} --strip-components=1 -C ${dest}`])
|
||||||
}
|
}
|
||||||
return tempInstallDir
|
return dest
|
||||||
case 'darwin':
|
case 'darwin':
|
||||||
await exec.exec('hdiutil', ['attach', juliaDownloadPath])
|
if (fileInfo !== null && fileInfo.extension == 'dmg') {
|
||||||
await exec.exec('/bin/bash', ['-c', `cp -a /Volumes/Julia-*/Julia-*.app/Contents/Resources/julia ${tempInstallDir}`])
|
core.debug(`Support for .dmg files is deprecated and may be removed in a future release`)
|
||||||
return path.join(tempInstallDir, 'julia')
|
await exec.exec('hdiutil', ['attach', juliaDownloadPath])
|
||||||
|
await exec.exec('/bin/bash', ['-c', `cp -a /Volumes/Julia-*/Julia-*.app/Contents/Resources/julia ${dest}`])
|
||||||
|
return path.join(dest, 'julia')
|
||||||
|
} else {
|
||||||
|
// tc.extractTar doesn't support stripping components, so we have to call tar manually
|
||||||
|
await exec.exec('tar', ['xf', juliaDownloadPath, '--strip-components=1', '-C', dest])
|
||||||
|
return dest
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
throw new Error(`Platform ${osPlat} is not supported`)
|
throw new Error(`Platform ${osPlat} is not supported`)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
import * as core from '@actions/core'
|
import * as core from '@actions/core'
|
||||||
import * as exec from '@actions/exec'
|
|
||||||
import * as tc from '@actions/tool-cache'
|
import * as tc from '@actions/tool-cache'
|
||||||
|
|
||||||
import * as fs from 'fs'
|
import * as fs from 'fs'
|
||||||
@@ -8,6 +7,16 @@ import * as path from 'path'
|
|||||||
|
|
||||||
import * as installer from './installer'
|
import * as installer from './installer'
|
||||||
|
|
||||||
|
const archSynonyms = {
|
||||||
|
'x86': 'x86',
|
||||||
|
'X86': 'x86',
|
||||||
|
'x64': 'x64',
|
||||||
|
'X64': 'x64',
|
||||||
|
'aarch64': 'aarch64',
|
||||||
|
'ARM64': 'aarch64',
|
||||||
|
'arm64': 'aarch64'
|
||||||
|
}
|
||||||
|
|
||||||
async function run() {
|
async function run() {
|
||||||
try {
|
try {
|
||||||
// Debugging info
|
// Debugging info
|
||||||
@@ -30,7 +39,8 @@ async function run() {
|
|||||||
|
|
||||||
// Inputs
|
// Inputs
|
||||||
const versionInput = core.getInput('version')
|
const versionInput = core.getInput('version')
|
||||||
const arch = core.getInput('arch')
|
const includePrereleases = core.getInput('include-all-prereleases') == 'true'
|
||||||
|
const originalArchInput = core.getInput('arch')
|
||||||
|
|
||||||
// It can easily happen that, for example, a workflow file contains an input `version: ${{ matrix.julia-version }}`
|
// It can easily happen that, for example, a workflow file contains an input `version: ${{ matrix.julia-version }}`
|
||||||
// while the strategy matrix only contains a key `${{ matrix.version }}`.
|
// while the strategy matrix only contains a key `${{ matrix.version }}`.
|
||||||
@@ -40,13 +50,15 @@ async function run() {
|
|||||||
if (!versionInput) {
|
if (!versionInput) {
|
||||||
throw new Error('Version input must not be null')
|
throw new Error('Version input must not be null')
|
||||||
}
|
}
|
||||||
if (!arch) {
|
if (!originalArchInput) {
|
||||||
throw new Error(`Arch input must not be null`)
|
throw new Error(`Arch input must not be null`)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const arch = archSynonyms[originalArchInput]
|
||||||
|
|
||||||
const versionInfo = await installer.getJuliaVersionInfo()
|
const versionInfo = await installer.getJuliaVersionInfo()
|
||||||
const availableReleases = await installer.getJuliaVersions(versionInfo)
|
const availableReleases = await installer.getJuliaVersions(versionInfo)
|
||||||
const version = installer.getJuliaVersion(availableReleases, versionInput)
|
const version = installer.getJuliaVersion(availableReleases, versionInput, includePrereleases)
|
||||||
core.debug(`selected Julia version: ${arch}/${version}`)
|
core.debug(`selected Julia version: ${arch}/${version}`)
|
||||||
core.setOutput('julia-version', version)
|
core.setOutput('julia-version', version)
|
||||||
|
|
||||||
@@ -56,14 +68,21 @@ async function run() {
|
|||||||
|
|
||||||
if (!juliaPath) {
|
if (!juliaPath) {
|
||||||
core.debug(`could not find Julia ${arch}/${version} in cache`)
|
core.debug(`could not find Julia ${arch}/${version} in cache`)
|
||||||
const juliaInstallationPath = await installer.installJulia(versionInfo, version, arch)
|
|
||||||
|
|
||||||
// Add it to cache
|
// https://github.com/julia-actions/setup-julia/pull/196
|
||||||
juliaPath = await tc.cacheDir(juliaInstallationPath, 'julia', version, arch)
|
// we want julia to be installed with unmodified file mtimes
|
||||||
|
// but `tc.cacheDir` uses `cp` internally which destroys mtime
|
||||||
|
// and `tc` provides no API to get the tool directory alone
|
||||||
|
// so hack it by installing a empty directory then use the path it returns
|
||||||
|
// and extract the archives directly to that location
|
||||||
|
const emptyDir = fs.mkdtempSync('empty')
|
||||||
|
juliaPath = await tc.cacheDir(emptyDir, 'julia', version, arch)
|
||||||
|
await installer.installJulia(juliaPath, versionInfo, version, arch)
|
||||||
|
|
||||||
core.debug(`added Julia to cache: ${juliaPath}`)
|
core.debug(`added Julia to cache: ${juliaPath}`)
|
||||||
|
|
||||||
// Remove temporary dir
|
// Remove empty dir
|
||||||
fs.rmdirSync(juliaInstallationPath, {recursive: true})
|
fs.rmdirSync(emptyDir)
|
||||||
} else {
|
} else {
|
||||||
core.debug(`using cached version of Julia: ${juliaPath}`)
|
core.debug(`using cached version of Julia: ${juliaPath}`)
|
||||||
}
|
}
|
||||||
@@ -78,7 +97,7 @@ async function run() {
|
|||||||
const showVersionInfoInput = core.getInput('show-versioninfo')
|
const showVersionInfoInput = core.getInput('show-versioninfo')
|
||||||
await installer.showVersionInfo(showVersionInfoInput, version)
|
await installer.showVersionInfo(showVersionInfoInput, version)
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
core.setFailed(error.message)
|
core.setFailed((error as Error).message)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user