emacs/test/lisp/cedet/srecode-utest-getset.el

179 lines
5.2 KiB
EmacsLisp

;;; srecode/test-getset.el --- Test the getset inserter. -*- lexical-binding:t -*-
;; Copyright (C) 2008-2009, 2011, 2019-2024 Free Software Foundation,
;; Inc.
;; This file is part of GNU Emacs.
;; GNU Emacs is free software: you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.
;; GNU Emacs is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
;;; Commentary:
;;
;; Unit tests for the getset inserter application.
(require 'srecode/semantic)
;;; Code:
(defvar srecode-utest-getset-pre-fill
"// Test Class for getset tests in c++.
class myClass {
public:
myClass() { };
~myClass() { };
/** miscFunction
*/
int miscFunction(int);
private:
int fStartingField;
};
"
"The pre-fill class for the getset tests.")
;;; Master Harness
;;
(defvar srecode-utest-getset-testfile
(expand-file-name
(concat (make-temp-name "srecode-utest-getset-") ".cpp")
temporary-file-directory)
"File used to do testing.")
(defvar srecode-insert-getset-fully-automatic-flag) ; Silence byte-compiler.
(ert-deftest srecode-utest-getset-output ()
"Test various template insertion options."
:tags '(:expensive-test)
(save-excursion
(let ((testbuff (find-file-noselect srecode-utest-getset-testfile))
(srecode-insert-getset-fully-automatic-flag t))
(set-buffer testbuff)
(semantic-mode 1)
(srecode-load-tables-for-mode major-mode)
(srecode-load-tables-for-mode major-mode 'getset)
(should (srecode-table))
;;(error "No template table found for mode %s" major-mode))
(condition-case nil
(erase-buffer)
(error nil))
(insert srecode-utest-getset-pre-fill)
(goto-char (point-min))
;; Test PRE FILL
(should-not
(srecode-utest-getset-tagcheck '("public"
"myClass"
"myClass"
"miscFunction"
"private"
"fStartingField")))
(should-not
(srecode-utest-getset-jumptotag "fStartingField"))
;; Startup with fully automatic selection.
(srecode-insert-getset)
;; * Post get-set "StartingField"
(should-not
(srecode-utest-getset-tagcheck '("public"
"myClass"
"myClass"
"getStartingField"
"setStartingField"
"miscFunction"
"private"
"fStartingField")))
;; Now try convenience args.
(goto-char (point-min))
(should-not
(srecode-utest-getset-jumptotag "fStartingField"))
(end-of-line)
(insert "\n")
(srecode-insert-getset nil "AutoInsertField")
;; * Post get-set "AutoInsertField"
(should-not
(srecode-utest-getset-tagcheck '("public"
"myClass"
"myClass"
"getStartingField"
"setStartingField"
"getAutoInsertField"
"setAutoInsertField"
"miscFunction"
"private"
"fStartingField"
"fAutoInsertField")))
;; Make sure all the comments are in the right place.
(should-not
(srecode-utest-getset-jumptotag "miscFunction"))
(let ((pos (point)))
(forward-comment -1)
(re-search-forward "miscFunction" pos))
))
(when (file-exists-p srecode-utest-getset-testfile)
(delete-file srecode-utest-getset-testfile))
)
(defun srecode-utest-getset-tagcheck (expected-members)
"Make sure that the tags in myClass have EXPECTED-MEMBERS."
(semantic-fetch-tags)
(let* ((mc (semantic-find-tags-by-name "myClass" (current-buffer)))
(mem (semantic-tag-type-members (car mc)))
(fail nil))
(catch 'fail-early
(while (and mem expected-members)
(when (not (string= (semantic-tag-name (car mem))
(car expected-members)))
(switch-to-buffer (current-buffer))
(setq fail (format "Did not find %s in %s" (car expected-members)
(buffer-file-name)))
(throw 'fail-early nil))
(setq mem (cdr mem)
expected-members (cdr expected-members)))
(when expected-members
(switch-to-buffer (current-buffer))
(setq fail (format "Did not find all expected tags in class: %s" (buffer-file-name)))
(throw 'fail-early t))
(when mem
(switch-to-buffer (current-buffer))
(setq fail (format "Found extra tags in class: %s" (buffer-file-name)))))
(when fail (message "%s" (buffer-string)))
fail))
(defun srecode-utest-getset-jumptotag (tagname)
"Jump to the tag named TAGNAME."
(semantic-fetch-tags)
(let ((fail nil)
(tag (semantic-deep-find-tags-by-name tagname (current-buffer))))
(if tag
(semantic-go-to-tag (car tag))
(setq fail (format "Failed to jump to tag %s" tagname)))
fail))
(provide 'cedet/srecode/test-getset)
;;; srecode/test-getset.el ends here