From 91aa3db7720d066cb25fbc089a28b7b41ef33fe9 Mon Sep 17 00:00:00 2001 From: Hendrik Tews Date: Thu, 28 Mar 2024 21:29:29 +0100 Subject: [PATCH] CI: add proof-check tests --- ci/simple-tests/README.md | 2 + ci/simple-tests/coq-test-proof-stat.el | 89 ++++++++++++++++++++++++++ 2 files changed, 91 insertions(+) create mode 100644 ci/simple-tests/coq-test-proof-stat.el diff --git a/ci/simple-tests/README.md b/ci/simple-tests/README.md index c949d58d7..e917a37e4 100644 --- a/ci/simple-tests/README.md +++ b/ci/simple-tests/README.md @@ -15,6 +15,8 @@ coq-test-prelude-correct coq-test-goals-present : test that Proof General shows goals correctly in various situations +coq-test-proof-stat +: test proof-check-proofs # Overview of existing tests for qRHL diff --git a/ci/simple-tests/coq-test-proof-stat.el b/ci/simple-tests/coq-test-proof-stat.el new file mode 100644 index 000000000..d725d01e5 --- /dev/null +++ b/ci/simple-tests/coq-test-proof-stat.el @@ -0,0 +1,89 @@ +;; This file is part of Proof General. +;; +;; © Copyright 2024 Hendrik Tews +;; +;; Authors: Hendrik Tews +;; Maintainer: Hendrik Tews +;; +;; SPDX-License-Identifier: GPL-3.0-or-later + +;;; Commentary: +;; +;; Test proof-check-proofs. + +;; For seq-group-by inside `proof-check-report'. This is +;; apparently not automatically loaded in Emacs 26.3. Though in a real +;; PG session it is apparently present. +(require 'seq) + +(defun reset-coq () + "Reset Coq and Proof General. +Do `proof-shell-exit' to kill Coq and reset the locked region and +a lot of other internal state of Proof General. Used at the +beginning of the test when several tests work on the same Coq +source file." + (when (and (boundp 'proof-shell-buffer) + (buffer-live-p proof-shell-buffer)) + (proof-shell-exit t) + (message "Coq and Proof General reseted"))) + + +(ert-deftest proof-check-correct-stat () + "Test `proof-check-proofs' on a file that is correct in non-opaque parts. +Test that the report buffer contains the expected output." + (setq proof-three-window-enable nil) + (reset-coq) + (find-file "proof_stat.v") + + ;; run check on file where all errors are in opaque parts + (proof-check-proofs) + + ;; the result buffer should exist + (should (buffer-live-p (get-buffer "*proof-check-report*"))) + (with-current-buffer "*proof-check-report*" + ;; the summary should be correct + (goto-char (point-min)) + (should + (search-forward "3 opaque proofs recognized: 1 successful 2 FAILING" + nil t)) + ;; results for all 3 test lemmas should be correct + (mapc + (lambda (s) (should (search-forward s nil t))) + '("FAIL a1_equal_4" + "OK b_equal_6" + "FAIL b2_equal_6")))) + + +(ert-deftest proof-check-error-on-error () + "Test `proof-check-proofs' with errors in non-opaque parts. +Check that `proof-check-proofs' signals an error with the expected message." + (setq proof-three-window-enable nil) + (reset-coq) + (let (buffer) + (unwind-protect + (progn + (find-file "proof_stat.v") + (setq buffer (current-buffer)) + + ;; insert an error in non-opaque part + (goto-char (point-min)) + (should (search-forward "automatic test marker 1" nil t)) + (end-of-line) + (insert " X ") + + ;; proof-check-proofs should abort now with an error + (condition-case err-desc + (progn + (proof-check-proofs) + ;; Still here? Make test fail! + (should nil)) + (error + (should + (equal (error-message-string err-desc) + "Error encountered outside opaque proofs after line 10"))))) + + ;; clean-up modified file in any case + (when buffer + (with-current-buffer buffer + (set-buffer-modified-p nil)) + (kill-buffer buffer)))))