diff --git a/action.yml b/action.yml index 6923474..bafbcd4 100644 --- a/action.yml +++ b/action.yml @@ -7,6 +7,9 @@ branding: color: 'gray-dark' inputs: + check_bounds: + description: 'Value determining which bounds checking setting to use. Options: yes | no | auto. Default value: yes.' + default: 'yes' coverage: description: 'Value determining whether to test with coverage or not. Options: true | false. Default value: true.' default: 'true' @@ -48,7 +51,7 @@ runs: JULIA_PKG_SERVER: "" - run: | # The Julia command that will be executed - 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...)' ) + julia_cmd=( julia --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 }}), julia_args = ["--check-bounds=${{ inputs.check_bounds }}"]);Pkg.test(; kwargs...)' ) # Add the prefix in front of the command if there is one prefix="${{ inputs.prefix }}" diff --git a/kwargs.jl b/kwargs.jl index 804b32b..b581768 100644 --- a/kwargs.jl +++ b/kwargs.jl @@ -5,7 +5,8 @@ import Pkg include(joinpath(@__DIR__, "autodetect-dependabot.jl")) function kwargs(; coverage::Bool, - force_latest_compatible_version::Union{Bool, Symbol}) + force_latest_compatible_version::Union{Bool, Symbol}, + julia_args::AbstractVector{<:AbstractString}=String[]) 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 @@ -13,6 +14,14 @@ function kwargs(; coverage::Bool, kwargs_dict = Dict{Symbol, Any}() kwargs_dict[:coverage] = coverage + if VERSION >= v"1.6.0" + kwargs_dict[:julia_args] = julia_args + elseif julia_args == ["--check-bounds=yes"] + # silently don't add this default julia_args value as < 1.6 doesn't support julia_args, but it's the default state + else + println("::warning::The Pkg.test bounds checking behavior cannot be changed before Julia 1.6. VERSION=$VERSION, julia_args=$julia_args") + end + 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