Skip to content

Commit

Permalink
[build] Add support for code coverage
Browse files Browse the repository at this point in the history
Closes coq#10267
  • Loading branch information
ejgallego committed Jan 21, 2022
1 parent 06970e0 commit 755483b
Show file tree
Hide file tree
Showing 23 changed files with 52 additions and 4 deletions.
23 changes: 22 additions & 1 deletion .gitlab-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ variables:
# Format: $IMAGE-V$DATE-$hash
# The $hash is the first 10 characters of the md5 of the Dockerfile. e.g.
# echo $(md5sum dev/ci/docker/bionic_coq/Dockerfile | head -c 10)
CACHEKEY: "bionic_coq-V2021-10-01-f0e345042b"
CACHEKEY: "bionic_coq-V2022-01-22-adf32fb7dc"
IMAGE: "$CI_REGISTRY_IMAGE:$CACHEKEY"
# By default, jobs run in the base switch; override to select another switch
OPAM_SWITCH: "base"
Expand Down Expand Up @@ -567,6 +567,27 @@ test-suite:edge:dune:dev:
# variables:
# OCAMLVER: 4.12.0+trunk

test-suite:edge+coverage:
stage: build
script:
- ulimit -s 16384
- dune build --instrument-with bisect_ppx --workspace dev/dune-workspace.bisect @runtest
- find _build/coverage/ -name '*.coverage' -size 0 -exec rm {} \; # workaround truncated coverage file bug
- bisect-ppx-report html --source-path=_build/coverage --coverage-path=_build/coverage -o _build/coq-coverage --title="Coq's Test suite"
# TODO: deploy
# bisect-ppx-report send-to Codecov
variables:
OPAM_SWITCH: edge
OPAM_VARIANT: "+flambda"
artifacts:
name: "$CI_JOB_NAME.logs"
when: always
paths:
- _build/log
- _build/coq-coverage
expire_in: 2 week
allow_failure: true

test-suite:base+async:
extends: .test-suite-template
needs:
Expand Down
2 changes: 2 additions & 0 deletions checker/dune
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
(synopsis "Coq's Standalone Proof Checker")
(modules :standard \ coqchk votour)
(wrapped true)
(instrumentation (backend bisect_ppx))
(libraries coq-core.boot coq-core.kernel))

(executable
Expand All @@ -17,6 +18,7 @@
(package coq-core)
(modules coqchk)
(flags :standard -open Coq_checklib)
(instrumentation (backend bisect_ppx))
(libraries coq_checklib))

(executable
Expand Down
1 change: 1 addition & 0 deletions clib/dune
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,6 @@
(synopsis "Coq's Utility Library [general purpose]")
(public_name coq-core.clib)
(wrapped false)
(instrumentation (backend bisect_ppx))
(modules_without_implementation cSig)
(libraries str unix threads))
1 change: 1 addition & 0 deletions config/dune
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
(library
(name config)
(synopsis "Coq Configuration Variables")
(instrumentation (backend bisect_ppx))
(public_name coq-core.config)
(modules :standard \ list_plugins)
(wrapped false))
Expand Down
4 changes: 2 additions & 2 deletions dev/ci/docker/bionic_coq/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -62,8 +62,8 @@ RUN opam switch create "${COMPILER}+32bit" && eval $(opam env) && \
opam install $BASE_OPAM

# EDGE switch, dune 2.8 is required for OCaml 4.12
ENV COMPILER_EDGE="4.13.0" \
BASE_OPAM_EDGE="dune.2.9.1 dune-release.1.5.0"
ENV COMPILER_EDGE="4.13.1" \
BASE_OPAM_EDGE="dune.2.9.1 dune-release.1.5.1 bisect_ppx.2.7.0"

# EDGE+flambda switch, we install CI_OPAM as to be able to use
# `ci-template-flambda` with everything.
Expand Down
5 changes: 5 additions & 0 deletions dev/dune-workspace.bisect
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
(lang dune 2.7)

(context
(default
(name coverage)))
2 changes: 1 addition & 1 deletion dune-project
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
(lang dune 2.5)
(lang dune 2.7)
(name coq)
(using coq 0.2)

Expand Down
1 change: 1 addition & 0 deletions engine/dune
Original file line number Diff line number Diff line change
Expand Up @@ -5,4 +5,5 @@
(wrapped false)
; until ocaml/dune#4892 fixed
; (private_modules univSubst)
(instrumentation (backend bisect_ppx))
(libraries library))
1 change: 1 addition & 0 deletions gramlib/dune
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
(library
(name gramlib)
(public_name coq-core.gramlib)
(instrumentation (backend bisect_ppx))
(libraries coq-core.lib))
1 change: 1 addition & 0 deletions interp/dune
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,5 @@
(synopsis "Coq's Syntactic Interpretation for AST [notations, implicits]")
(public_name coq-core.interp)
(wrapped false)
(instrumentation (backend bisect_ppx))
(libraries zarith pretyping))
1 change: 1 addition & 0 deletions kernel/dune
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
(public_name coq-core.kernel)
(wrapped false)
(modules (:standard \ genOpcodeFiles uint63_31 uint63_63 float64_31 float64_63))
(instrumentation (backend bisect_ppx))
(libraries boot lib coqrun dynlink))

(executable
Expand Down
1 change: 1 addition & 0 deletions lib/dune
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,6 @@
(synopsis "Coq's Utility Library [coq-specific]")
(public_name coq-core.lib)
(wrapped false)
(instrumentation (backend bisect_ppx))
(modules_without_implementation xml_datatype)
(libraries coq-core.boot coq-core.clib coq-core.config))
1 change: 1 addition & 0 deletions library/dune
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
(synopsis "Coq's Loadable Libraries (vo) Support")
(public_name coq-core.library)
(wrapped false)
(instrumentation (backend bisect_ppx))
(libraries kernel))

(documentation
Expand Down
1 change: 1 addition & 0 deletions parsing/dune
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
(name parsing)
(public_name coq-core.parsing)
(wrapped false)
(instrumentation (backend bisect_ppx))
(libraries coq-core.gramlib interp))

(coq.pp (modules g_prim g_constr))
2 changes: 2 additions & 0 deletions plugins/ltac/dune
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,15 @@
(public_name coq-core.plugins.ltac)
(synopsis "Coq's LTAC tactic language")
(modules :standard \ tauto)
(instrumentation (backend bisect_ppx))
(libraries coq-core.stm))

(library
(name tauto_plugin)
(public_name coq-core.plugins.tauto)
(synopsis "Coq's tauto tactic")
(modules tauto)
(instrumentation (backend bisect_ppx))
(libraries coq-core.plugins.ltac))

(coq.pp (modules extratactics g_tactic g_rewrite g_eqdecide g_auto g_obligations g_ltac profile_ltac_tactics coretactics g_class extraargs))
1 change: 1 addition & 0 deletions plugins/ssr/dune
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
(public_name coq-core.plugins.ssreflect)
(synopsis "Coq's ssreflect plugin")
(modules_without_implementation ssrast)
(instrumentation (backend bisect_ppx))
(flags :standard -open Gramlib)
(libraries coq-core.plugins.ssrmatching))

Expand Down
1 change: 1 addition & 0 deletions pretyping/dune
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,5 @@
(synopsis "Coq's Type Inference Component (Pretyper)")
(public_name coq-core.pretyping)
(wrapped false)
(instrumentation (backend bisect_ppx))
(libraries engine))
1 change: 1 addition & 0 deletions printing/dune
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,5 @@
(synopsis "Coq's Term Pretty Printing Library")
(public_name coq-core.printing)
(wrapped false)
(instrumentation (backend bisect_ppx))
(libraries parsing proofs))
1 change: 1 addition & 0 deletions proofs/dune
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,5 @@
(synopsis "Coq's Higher-level Refinement Proof Engine and Top-level Proof Structure")
(public_name coq-core.proofs)
(wrapped false)
(instrumentation (backend bisect_ppx))
(libraries pretyping))
1 change: 1 addition & 0 deletions stm/dune
Original file line number Diff line number Diff line change
Expand Up @@ -5,4 +5,5 @@
(wrapped false)
; until ocaml/dune#4892 fixed
; (private_modules dag proofBlockDelimiter tQueue vcs workerPool)
(instrumentation (backend bisect_ppx))
(libraries sysinit))
1 change: 1 addition & 0 deletions tactics/dune
Original file line number Diff line number Diff line change
Expand Up @@ -5,4 +5,5 @@
(wrapped false)
; until ocaml/dune#4892 fixed
; (private_modules btermdn dnet dn term_dnet)
(instrumentation (backend bisect_ppx))
(libraries printing))
2 changes: 2 additions & 0 deletions topbin/dune
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
(public_name coqtop.opt)
(package coq-core)
(modules coqtop_bin)
(instrumentation (backend bisect_ppx))
(libraries coq-core.toplevel)
(link_flags -linkall))

Expand All @@ -25,6 +26,7 @@
(public_name coqc)
(package coq-core)
(modules coqc_bin)
(instrumentation (backend bisect_ppx))
(libraries coq-core.toplevel)
(modes native byte)
; Adding -ccopt -flto to links options could be interesting, however,
Expand Down
1 change: 1 addition & 0 deletions vernac/dune
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
(wrapped false)
; until ocaml/dune#4892 fixed
; (private_modules comProgramFixpoint egramcoq)
(instrumentation (backend bisect_ppx))
(libraries tactics parsing))

(coq.pp (modules g_proofs g_vernac))

0 comments on commit 755483b

Please sign in to comment.