๐ฃ
Jive.jl Documentation | Build Status |
---|---|
Jive.jl
is a Julia package to help the writing tests.
โ๏ธ You can make a donation to support this project.
runtests
run the test files in a specific directory and path.
suppose you have some test files in the test/
directory for your package.
now let's make your test/runtests.jl
with
using Jive
runtests(@__DIR__)
for the runtests.jl
, ARGS
are used to filter the targets and to set the start offset of the tests.
~/.julia/dev/Jive/test $ julia runtests.jl jive/s start=3
1/4 jive/skip/skip-calls.jl --
2/4 jive/skip/skip-exprs.jl --
3/4 jive/skip/skip-functions.jl
Pass 4 (0.40 seconds)
4/4 jive/skip/skip-modules.jl
Pass 4 (0.01 seconds)
โ
All 8 tests have been completed. (0.62 seconds)
in the above example, test files are matched for only have jive/s
and jumping up to the 3rd file.
Examples
- run tests
~/.julia/dev/Jive/test $ julia runtests.jl
- run tests with target directory.
~/.julia/dev/Jive/test $ julia runtests.jl jive/If
- distributed run tests with
-p
~/.julia/dev/Jive/test $ julia -p3 runtests.jl
- distributed run tests for
Pkg.test()
, usingJIVE_PROCS
ENV.
~/.julia/dev/Jive $ JIVE_PROCS=2 julia --project=. -e 'using Pkg; Pkg.test()'
~/.julia/dev/Jive $ julia --project=. -e 'ENV["JIVE_PROCS"]="2"; using Pkg; Pkg.test()'
TestJive.jl is an example package for using Jive.
look at also the test/Project.toml
file for your own package.
[deps]
Test = "8dfed614-e22c-5e08-85e1-65c5234f0b40"
Jive = "ba5e3d4b-8524-549f-bc71-e76ad9e9deed"
[targets]
test = ["Test", "Jive"]
Watch package folders
You may need to install Revise.jl.
~/.julia/dev/Jive/test/Example/test $ cat runtests.jl
using Jive
runtests(@__DIR__, skip=["revise.jl"])
~/.julia/dev/Jive/test/Example/test $ cat revise.jl
# julia -i -q --project=. revise.jl example
using Revise, Jive
using Example
trigger = function (path)
printstyled("changed ", color=:cyan)
println(path)
revise()
runtests(@__DIR__, skip=["revise.jl"])
end
watch(trigger, @__DIR__, sources=[pathof(Example)])
trigger("")
Base.JLOptions().isinteractive==0 && wait()
~/.julia/dev/Jive/test/Example/test $ julia -e 'using Pkg; pkg"dev Revise .."'
~/.julia/dev/Jive/test/Example/test $ julia -i -q --project=. revise.jl example
watching folders ...
- ../src
- example
changed
1/1 example/test1.jl
Pass 1 (0.27 seconds)
โ
All 1 test has been completed. (0.55 seconds)
when saving any files in the watching folders, it automatically run tests.
@skip
skip the expression.
using Jive # @skip
@skip module want_to_skip_this_module
sleep(2)
end
@skip function want_to_skip_this_function()
sleep(2)
end
@skip println(1+2)
- Change to do not skip the code: set
ENV["JIVE_SKIP"] = "0"
@onlyonce
used to run the block only once.
using Jive # @onlyonce
for _ in 1:10
@onlyonce begin
println(42)
end
@onlyonce(println("hello"))
end
@If
evaluate the module by the condition.
using Jive # @If
@If VERSION >= v"1.1.0-DEV.764" module load_some_module
end
@useinside
use inside of the module.
using Jive # @useinside
@useinside module test_pkgs_flux_optimise
# ...
end
@__END__
throw(Jive.EndError())
using Jive
@__END__
@__REPL__
test/jive/__REPL__
- Use Infiltrator.jl to debug the local scope variables.
~/.julia/dev/Jive/test/jive/__REPL__ $ cat test.jl
using Jive
a = 1
@__REPL__
@info :a a
~/.julia/dev/Jive/test/jive/__REPL__ $ julia test.jl
julia> a += 2
3
julia> ^D # Ctrl + D to exit the REPL
โ Info: a
โ a = 3