TestTools
Documentation | |
Build Status | |
TestTools is a collection of CLI tools and APIs that simplifies code testing, coverage analysis, and style checking. Our goal is to make it a joy to do software testing (or at least save effort and keystrokes).
Why TestTools?
-
Easy-to-use (and fast) CLI tools for testing
-
Compatible with
Pkg.test()
-
Enhanced test set functionality – diffs for failed comparisons and fail-fast support
-
Noninvasive – introduces no package-level dependencies
Quick Start
-
Start Julia in the default (global) environment.
- Note. Installation in the default environment makes the CLI tools available from within all projects.
-
Install the
TestTools
package.pkg> add TestTools # Press ']' to enter the Pkg REPL mode.
-
Install the CLI tools (to
~/.julia/bin
).julia> using TestTools; TestTools.install()
Usage
CLI Utilities
jltest
Run unit tests in a single file.
$ jltest test/tests.jl
Run all unit tests contained in a directory.
$ jltest test/
Run unit tests with fail-fast enabled (i.e., halt testing after the first failing test).
$ jltest -x test/tests.jl
jlcoverage
Generate a coverage report (after running unit tests while collecting coverage data).
$ julia -e 'import Pkg; Pkg.test("TestTools"; coverage=true)' # run unit tests
$ jlcoverage # generate coverage report
-------------------------------------------------------------------------------
File Lines of Code Missed Coverage
-------------------------------------------------------------------------------
src/TestTools.jl 0 0 N/A
src/jlcodestyle/cli/cli.jl 34 0 100.0%
...
src/pkg.jl 42 3 92.9%
-------------------------------------------------------------------------------
TOTAL 289 7 97.6%
jlcodestyle
Run basic code style check (reformatting of source file disabled).
$ jlcodestyle src/TestTools.jl
$ jlcodestyle --verbose src/TestTools.jl
[ Info: Style = BlueStyle
[ Info: Overwrite = false
Formatting src/TestTools.jl
No style errors found.
$ jlcodestyle examples/jlcodestyle/not-blue-style.jl
Style errors found. Files not modified.
Run code style check with reformatting of source file enabled.
$ jlcodestyle --overwrite examples/jlcodestyle/not-blue-style.jl
Style errors found. Files modified to correct errors.
Acknowledgements
-
TestTools leverages several excellent Julia packages to support its core capabilities.
-
TestTools borrows ideas (and some code) from the following great Julia packages.
-
-
The base code for
EnhancedTestSet
(which implements diffs for comparisons and progress dots) comes directly fromTestsetExtensions.ExtendedTestSet
. -
The
run_tests()
andfind_tests()
methods are essentially a re-implementation and refactoring of theTestsetExtensions.@includetests
macro as methods.
-
-
- The strategy for isolating tests came from the
SafeTestsets.@safetestset
macro.
- The strategy for isolating tests came from the
-
- The strategy for installing CLI executables came from
jlpkg.install()
.
- The strategy for installing CLI executables came from
-
-
TestTools was inspired by analogous code testing packages in the Python ecosystem: