src/HOL/Tools/Mirabelle/mirabelle_quickcheck.ML
author desharna
Tue, 28 Sep 2021 10:47:18 +0200
changeset 74370 d8dc8fdc46fc
parent 73847 58f6b41efe88
child 74948 15ce207f69c8
permissions -rw-r--r--
prefer veriT over Z3 in sledgehammer

(*  Title:      HOL/Mirabelle/Tools/mirabelle_quickcheck.ML
    Author:     Jasmin Blanchette, TU Munich
    Author:     Sascha Boehme, TU Munich
    Author:     Martin Desharnais, UniBw Munich

Mirabelle action: "quickcheck".
*)

structure Mirabelle_Quickcheck: MIRABELLE_ACTION =
struct

fun make_action ({arguments, timeout, ...} : Mirabelle.action_context) =
  let
    val has_valid_key = member (op =) ["iterations", "size", "generator"] o fst
    val quickcheck =
      Quickcheck.quickcheck (map (apsnd single) (filter has_valid_key arguments)) 1

    fun run_action ({pre, ...} : Mirabelle.command) =
      (case Timeout.apply timeout quickcheck pre of
        NONE => "no counterexample"
      | SOME _ => "counterexample found")
  in {run_action = run_action, finalize = K ""} end

val () = Mirabelle.register_action "quickcheck" make_action

end