forked from ProofGeneral/PG
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
06cea8d
commit 1f7c3d7
Showing
2 changed files
with
91 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
;; This file is part of Proof General. | ||
;; | ||
;; © Copyright 2024 Hendrik Tews | ||
;; | ||
;; Authors: Hendrik Tews | ||
;; Maintainer: Hendrik Tews <[email protected]> | ||
;; | ||
;; SPDX-License-Identifier: GPL-3.0-or-later | ||
|
||
;;; Commentary: | ||
;; | ||
;; Test proof-check-proofs. | ||
|
||
;; For seq-group-by inside `proof-script-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-script-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-script-check-proofs should abort now with an error | ||
(condition-case err-desc | ||
(progn | ||
(proof-script-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))))) |