mirror of
https://github.com/julia-actions/julia-runtest.git
synced 2026-02-12 11:06:54 +08:00
Compare commits
9 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
8d8f445e06 | ||
|
|
eda4346d69 | ||
|
|
07b45fecd2 | ||
|
|
f8a636d3f0 | ||
|
|
b32c73084a | ||
|
|
8ff46c6486 | ||
|
|
78a53ba947 | ||
|
|
6fedc3006b | ||
|
|
82358847b3 |
1
.github/CODEOWNERS
vendored
Normal file
1
.github/CODEOWNERS
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
* @julia-actions/reviewers
|
||||||
33
.github/workflows/backup.yml
vendored
Normal file
33
.github/workflows/backup.yml
vendored
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
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 }}
|
||||||
6
.github/workflows/ci.yml
vendored
6
.github/workflows/ci.yml
vendored
@@ -5,7 +5,13 @@ on:
|
|||||||
branches:
|
branches:
|
||||||
- "main"
|
- "main"
|
||||||
- "master"
|
- "master"
|
||||||
|
paths-ignore:
|
||||||
|
- "README.md"
|
||||||
|
- "LICENSE"
|
||||||
pull_request:
|
pull_request:
|
||||||
|
paths-ignore:
|
||||||
|
- "README.md"
|
||||||
|
- "LICENSE"
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
test:
|
test:
|
||||||
|
|||||||
2
LICENSE
2
LICENSE
@@ -1,6 +1,6 @@
|
|||||||
The MIT License (MIT)
|
The MIT License (MIT)
|
||||||
|
|
||||||
Copyright (c) 2018-2020 GitHub, Inc., David Anthoff and contributors
|
Copyright (c) 2018-2021 GitHub, Inc., David Anthoff and contributors
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
|||||||
@@ -27,11 +27,11 @@ jobs:
|
|||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
- uses: julia-actions/setup-julia@latest
|
- uses: julia-actions/setup-julia@v1
|
||||||
with:
|
with:
|
||||||
version: ${{ matrix.julia-version }}
|
version: ${{ matrix.julia-version }}
|
||||||
- uses: julia-actions/julia-buildpkg@latest
|
- uses: julia-actions/julia-buildpkg@v1
|
||||||
- uses: julia-actions/julia-runtest@latest
|
- uses: julia-actions/julia-runtest@v1
|
||||||
```
|
```
|
||||||
|
|
||||||
### Prefixing the Julia command
|
### Prefixing the Julia command
|
||||||
|
|||||||
19
action.yml
19
action.yml
@@ -7,22 +7,25 @@ branding:
|
|||||||
color: 'gray-dark'
|
color: 'gray-dark'
|
||||||
|
|
||||||
inputs:
|
inputs:
|
||||||
inline:
|
|
||||||
description: 'Value passed to the --inline flag. Options: yes | no. Default value: yes.'
|
|
||||||
default: 'yes'
|
|
||||||
coverage:
|
coverage:
|
||||||
description: 'Value determining whether to test with coverage or not. Options: true | false. Default value: true.'
|
description: 'Value determining whether to test with coverage or not. Options: true | false. Default value: true.'
|
||||||
default: 'true'
|
default: 'true'
|
||||||
depwarn:
|
depwarn:
|
||||||
description: 'Value passed to the --depwarn flag. Options: yes | no | error. Default value: yes.'
|
description: 'Value passed to the --depwarn flag. Options: yes | no | error. Default value: yes.'
|
||||||
default: 'yes'
|
default: 'yes'
|
||||||
project:
|
force_latest_compatible_version:
|
||||||
description: 'Value passed to the --project flag. The default value is the repository root: "@."'
|
description: 'If true, then, for each [compat] entry in the active project, only allow the latest compatible version. If the value is auto and the pull request has been opened by Dependabot or CompatHelper, then force_latest_compatible_version will be set to true, otherwise it will be set to false. Options: true | false | auto. Default value: auto.'
|
||||||
default: '@.'
|
default: 'auto'
|
||||||
|
inline:
|
||||||
|
description: 'Value passed to the --inline flag. Options: yes | no. Default value: yes.'
|
||||||
|
default: 'yes'
|
||||||
prefix:
|
prefix:
|
||||||
description: 'Value inserted in front of the julia command, e.g. for running xvfb-run julia [...]'
|
description: 'Value inserted in front of the julia command, e.g. for running xvfb-run julia [...]'
|
||||||
default: ''
|
default: ''
|
||||||
required: false
|
required: false
|
||||||
|
project:
|
||||||
|
description: 'Value passed to the --project flag. The default value is the repository root: "@."'
|
||||||
|
default: '@.'
|
||||||
|
|
||||||
runs:
|
runs:
|
||||||
using: 'composite'
|
using: 'composite'
|
||||||
@@ -35,7 +38,7 @@ runs:
|
|||||||
# * https://github.com/JuliaLang/Pkg.jl/issues/2011
|
# * https://github.com/JuliaLang/Pkg.jl/issues/2011
|
||||||
# * https://github.com/JuliaRegistries/General/issues/16777
|
# * https://github.com/JuliaRegistries/General/issues/16777
|
||||||
# * https://github.com/JuliaPackaging/PkgServer.jl/issues/60
|
# * https://github.com/JuliaPackaging/PkgServer.jl/issues/60
|
||||||
- run: julia --color=yes -e 'using Pkg; VERSION >= v"1.5-" && !isdir(joinpath(DEPOT_PATH[1], "registries", "General")) && Pkg.Registry.add("General")'
|
- run: julia --color=yes "$GITHUB_ACTION_PATH"/add_general_registry.jl
|
||||||
shell: bash
|
shell: bash
|
||||||
env:
|
env:
|
||||||
# We set `JULIA_PKG_SERVER` only for this step to enforce
|
# We set `JULIA_PKG_SERVER` only for this step to enforce
|
||||||
@@ -45,7 +48,7 @@ runs:
|
|||||||
JULIA_PKG_SERVER: ""
|
JULIA_PKG_SERVER: ""
|
||||||
- run: |
|
- run: |
|
||||||
# The Julia command that will be executed
|
# The Julia command that will be executed
|
||||||
julia_cmd=( julia --color=yes --check-bounds=yes --inline=${{ inputs.inline }} --depwarn=${{ inputs.depwarn }} --project=${{ inputs.project }} -e 'using Pkg; Pkg.test(coverage=${{ inputs.coverage }})' )
|
julia_cmd=( julia --check-bounds=yes --color=yes --depwarn=${{ inputs.depwarn }} --inline=${{ inputs.inline }} --project=${{ inputs.project }} -e 'import Pkg;include(joinpath(ENV["GITHUB_ACTION_PATH"], "kwargs.jl"));kwargs = Kwargs.kwargs(;coverage = :(${{ inputs.coverage }}),force_latest_compatible_version = :(${{ inputs.force_latest_compatible_version }}),);Pkg.test(; kwargs...)' )
|
||||||
|
|
||||||
# Add the prefix in front of the command if there is one
|
# Add the prefix in front of the command if there is one
|
||||||
prefix="${{ inputs.prefix }}"
|
prefix="${{ inputs.prefix }}"
|
||||||
|
|||||||
49
add_general_registry.jl
Normal file
49
add_general_registry.jl
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
using Pkg
|
||||||
|
|
||||||
|
function general_registry_location()
|
||||||
|
general_registry_dir = joinpath(DEPOT_PATH[1], "registries", "General")
|
||||||
|
registry_toml_file = joinpath(general_registry_dir, "Registry.toml")
|
||||||
|
return general_registry_dir, registry_toml_file
|
||||||
|
end
|
||||||
|
|
||||||
|
function general_registry_exists()
|
||||||
|
general_registry_dir, registry_toml_file = general_registry_location()
|
||||||
|
if !isdir(general_registry_dir)
|
||||||
|
return false
|
||||||
|
elseif !isfile(registry_toml_file)
|
||||||
|
return false
|
||||||
|
else
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function add_general_registry()
|
||||||
|
@info("Attempting to clone the General registry")
|
||||||
|
general_registry_dir, registry_toml_file = general_registry_location()
|
||||||
|
rm(general_registry_dir; force = true, recursive = true)
|
||||||
|
Pkg.Registry.add("General")
|
||||||
|
isfile(registry_toml_file) || throw(ErrorException("the Registry.toml file does not exist"))
|
||||||
|
return nothing
|
||||||
|
end
|
||||||
|
|
||||||
|
function main(; n = 10, max_delay = 120)
|
||||||
|
VERSION >= v"1.5-" || return
|
||||||
|
|
||||||
|
if general_registry_exists()
|
||||||
|
@info("The General registry already exists locally")
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
delays = ExponentialBackOff(; n = n, max_delay = max_delay)
|
||||||
|
try
|
||||||
|
retry(add_general_registry; delays = delays)()
|
||||||
|
@info("Successfully added the General registry")
|
||||||
|
catch ex
|
||||||
|
msg = "I was unable to add the General registry. However, the build will continue."
|
||||||
|
@error(msg, exception=(ex,catch_backtrace()))
|
||||||
|
end
|
||||||
|
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
main()
|
||||||
25
autodetect-dependabot.jl
Normal file
25
autodetect-dependabot.jl
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
module AutodetectDependabot
|
||||||
|
|
||||||
|
function _get_possible_branch_names()
|
||||||
|
possible_branch_names = [
|
||||||
|
get(ENV, "GITHUB_BASE_REF", ""),
|
||||||
|
get(ENV, "GITHUB_HEAD_REF", ""),
|
||||||
|
get(ENV, "GITHUB_REF", ""),
|
||||||
|
]
|
||||||
|
return possible_branch_names
|
||||||
|
end
|
||||||
|
|
||||||
|
function _chop_refs_head(branch_name::AbstractString)
|
||||||
|
replace(branch_name, r"^(refs\/heads\/)" => "")
|
||||||
|
end
|
||||||
|
|
||||||
|
function _is_dependabot_branch(branch_name::AbstractString)
|
||||||
|
return startswith(branch_name, "dependabot/julia") || startswith(branch_name, "compathelper/")
|
||||||
|
end
|
||||||
|
|
||||||
|
function is_dependabot_job()
|
||||||
|
possible_branch_names = _get_possible_branch_names()
|
||||||
|
return any(_is_dependabot_branch.(_chop_refs_head.(possible_branch_names)))
|
||||||
|
end
|
||||||
|
|
||||||
|
end # module
|
||||||
32
kwargs.jl
Normal file
32
kwargs.jl
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
module Kwargs
|
||||||
|
|
||||||
|
import Pkg
|
||||||
|
|
||||||
|
include(joinpath(@__DIR__, "autodetect-dependabot.jl"))
|
||||||
|
|
||||||
|
function kwargs(; coverage::Bool,
|
||||||
|
force_latest_compatible_version::Union{Bool, Symbol})
|
||||||
|
if !(force_latest_compatible_version isa Bool) && (force_latest_compatible_version != :auto)
|
||||||
|
throw(ArgumentError("Invalid value for force_latest_compatible_version: $(force_latest_compatible_version)"))
|
||||||
|
end
|
||||||
|
|
||||||
|
kwargs_dict = Dict{Symbol, Any}()
|
||||||
|
kwargs_dict[:coverage] = coverage
|
||||||
|
|
||||||
|
if VERSION < v"1.7.0-" || !hasmethod(Pkg.Operations.test, Tuple{Pkg.Types.Context, Vector{Pkg.Types.PackageSpec}}, (:force_latest_compatible_version,))
|
||||||
|
(force_latest_compatible_version != :auto) && @warn("The `force_latest_compatible_version` option requires at least Julia 1.7", VERSION, force_latest_compatible_version)
|
||||||
|
return kwargs_dict
|
||||||
|
end
|
||||||
|
|
||||||
|
if force_latest_compatible_version == :auto
|
||||||
|
is_dependabot_job = AutodetectDependabot.is_dependabot_job()
|
||||||
|
is_dependabot_job && @info("This is a Dependabot/CompatHelper job, so `force_latest_compatible_version` has been set to `true`")
|
||||||
|
kwargs_dict[:force_latest_compatible_version] = is_dependabot_job
|
||||||
|
else
|
||||||
|
kwargs_dict[:force_latest_compatible_version] = force_latest_compatible_version::Bool
|
||||||
|
end
|
||||||
|
|
||||||
|
return kwargs_dict
|
||||||
|
end
|
||||||
|
|
||||||
|
end # module
|
||||||
Reference in New Issue
Block a user