Skip to content

Commit

Permalink
Fix "juliadir" test (#867)
Browse files Browse the repository at this point in the history
The test was ineffective because it was relying on binding replacement,
which is undefined behavior on all versions of Julia (ironically it will
not be in 1.12, but that change is not done yet). As a result,
the redefinition of `juliadir` was not taking effect and the
test was simply running with the old juliadir. Change `juliadir`
to a (typed) global and update the test to make sure it's actually
working.
  • Loading branch information
Keno authored Nov 18, 2024
1 parent ec869e7 commit 71d8e61
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 5 deletions.
10 changes: 9 additions & 1 deletion src/packagedef.jl
Original file line number Diff line number Diff line change
Expand Up @@ -178,13 +178,21 @@ function fallback_juliadir()
normpath(candidate)
end

if VERSION >= v"1.8"
Core.eval(@__MODULE__, :(global juliadir::String))
else
Core.eval(@__MODULE__, :(global juliadir #= ::Any =#; nothing))
end

"""
Revise.juliadir
Constant specifying full path to julia top-level source directory.
This should be reliable even for local builds, cross-builds, and binary installs.
"""
const juliadir = normpath(
juliadir

juliadir = normpath(
if isdir(joinpath(basebuilddir, "base"))
basebuilddir
else
Expand Down
9 changes: 5 additions & 4 deletions test/juliadir.jl
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
using Revise, InteractiveUtils, Test

@eval Revise const juliadir = ARGS[1]
@eval Revise juliadir = ARGS[1]

@test Revise.juliadir != Revise.basebuilddir
@test Revise.juliadir != Revise.fallback_juliadir()

@show Revise.juliadir

# https://github.com/timholy/Revise.jl/issues/697
@test Revise.definition(@which(Float32(π))) isa Expr
let def = Revise.definition(@which(Float32(π)))
@test isa(def, Expr)
@test Meta.isexpr(def, :macrocall)
end

0 comments on commit 71d8e61

Please sign in to comment.