diff --git a/src/LocalCoverage.jl b/src/LocalCoverage.jl index f41f5d2..a9db431 100644 --- a/src/LocalCoverage.jl +++ b/src/LocalCoverage.jl @@ -233,13 +233,34 @@ function generate_coverage(pkg = nothing; test_args = [""], folder_list = ["src"], file_list = [])::PackageCoverage - if run_test - if isnothing(pkg) - Pkg.test(; coverage = true, test_args = test_args) - else - Pkg.test(pkg; coverage = true, test_args = test_args) + + try + if run_test + if isnothing(pkg) + Pkg.test(; coverage = true, test_args = test_args) + else + Pkg.test(pkg; coverage = true, test_args = test_args) + end end + catch e + coverage = process_coverage(pkg; folder_list, file_list) + println(stdout, coverage) + rethrow(e) end + return process_coverage(pkg; folder_list, file_list) +end + +""" +$(SIGNATURES) + +Process coverage files for a package within folder. + +Called by [`generate_coverage`](@ref). + +""" +function process_coverage(pkg=nothing; + folder_list=["src"], + file_list=[])::PackageCoverage package_dir = pkgdir(pkg) cd(package_dir) do # initialize empty vector of coverage data diff --git a/test/DummyPackage/test/runtests.jl b/test/DummyPackage/test/runtests.jl index da33367..c45a711 100644 --- a/test/DummyPackage/test/runtests.jl +++ b/test/DummyPackage/test/runtests.jl @@ -9,4 +9,10 @@ end @testset "testset 2" begin @test corge() == "corge" +end + +if "testset 3" ∈ ARGS + @testset "testset 3" begin + @test 1 == 2 + end end \ No newline at end of file diff --git a/test/runtests.jl b/test/runtests.jl index d75f1ae..f702d79 100644 --- a/test/runtests.jl +++ b/test/runtests.jl @@ -18,18 +18,39 @@ function test_coverage(pkg; test_args = [""], folder_list = ["src"], file_list = [], - css = nothing) + css = nothing, + should_throw = false) @info "Testing coverage for $pkg" test_args folder_list file_list clean_coverage(pkg) @test isdir(LocalCoverage.pkgdir(pkg)) lcovtrace = joinpath(covdir, "lcov.info") @test !isfile(lcovtrace) - cov = generate_coverage(pkg; - run_test = run_test, - test_args = test_args, - folder_list = folder_list, - file_list = file_list) + if should_throw + @test_throws Pkg.Types.PkgError generate_coverage(pkg; + run_test=run_test, + test_args=test_args, + folder_list=folder_list, + file_list=file_list) + else + cov = generate_coverage(pkg; + run_test = run_test, + test_args = test_args, + folder_list = folder_list, + file_list = file_list) + + buffer = IOBuffer() + show(buffer, cov) + table = String(take!(buffer)) + println(table) + @test !isnothing(match(table_header, table)) + @test !isnothing(match(table_line, table)) + @test !isnothing(match(table_footer, table)) + + @info "Printing coverage information for visual debugging" + show(stdout, cov) + show(IOContext(stdout, :print_gaps => true), cov) + end xmltrace = joinpath(covdir,"lcov.xml") write_lcov_to_xml(xmltrace, lcovtrace) @@ -40,14 +61,6 @@ function test_coverage(pkg; @test startswith(doctype, " true), cov) end @testset verbose = true "Testing coverage with" begin @@ -93,6 +102,10 @@ end @test_throws TypeError test_coverage("DummyPackage", css=1) test_coverage("DummyPackage", css=joinpath(dirname(@__FILE__), "dummy.css")) end + + @testset "failing tests" begin + test_coverage("DummyPackage"; test_args = ["testset 3"], should_throw = true) + end end @test LocalCoverage.find_gaps([nothing, 0, 0, 0, 2, 3, 0, nothing, 0, 3, 0, 6, 2]) ==