;;; sgml-mode-tests.el --- Tests for sgml-mode ;; Copyright (C) 2015-2019 Free Software Foundation, Inc. ;; Author: Przemysław Wojnowski ;; Keywords: tests ;; 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 . ;;; Commentary: ;;; Code: (require 'sgml-mode) (require 'ert) (defmacro sgml-with-content (content &rest body) "Insert CONTENT into a temporary `sgml-mode' buffer and execute BODY on it. The point is set to the beginning of the buffer." `(with-temp-buffer (sgml-mode) (insert ,content) (goto-char (point-min)) ,@body)) ;;; sgml-delete-tag (ert-deftest sgml-delete-tag-should-not-delete-tags-when-wrong-args () "Don't delete tag, when number of tags to delete is not positive number." (let ((content "

Valar Morghulis

")) (sgml-with-content content (sgml-delete-tag -1) (should (string= content (buffer-string))) (sgml-delete-tag 0) (should (string= content (buffer-string)))))) (ert-deftest sgml-delete-tag-should-delete-tags-n-times () ;; Delete only 1, when 1 available: (sgml-with-content "
" (sgml-delete-tag 1) (should (string= "" (buffer-string)))) ;; Delete from position on whitespaces before tag: (sgml-with-content " \t\n
" (sgml-delete-tag 1) (should (string= "" (buffer-string)))) ;; Delete from position on tag: (sgml-with-content "
" (goto-char 3) (sgml-delete-tag 1) (should (string= "" (buffer-string)))) ;; Delete one by one: (sgml-with-content "

You know nothing, Jon Snow.

" (sgml-delete-tag 1) (should (string= "

You know nothing, Jon Snow.

" (buffer-string))) (sgml-delete-tag 1) (should (string= "You know nothing, Jon Snow." (buffer-string)))) ;; Delete 2 at a time, when 2 available: (sgml-with-content "

You know nothing, Jon Snow.

" (sgml-delete-tag 2) (should (string= "You know nothing, Jon Snow." (buffer-string))))) (ert-deftest sgml-delete-tag-should-delete-unclosed-tag () (sgml-with-content "" (goto-char 5) ; position on "li" tag (sgml-delete-tag 1) (should (string= "" (buffer-string))))) (ert-deftest sgml-delete-tag-should-signal-error-for-malformed-tags () (let ((content "

Drakaris!

")) ;; Delete outside tag: (sgml-with-content content (sgml-delete-tag 1) (should (string= "

Drakaris!

" (buffer-string)))) ;; Delete inner tag: (sgml-with-content content (goto-char 5) ; position the inner tag (sgml-delete-tag 1) (should (string= "

Drakaris!

" (buffer-string)))))) (ert-deftest sgml-delete-tag-should-signal-error-when-deleting-too-much () (let ((content "Drakaris!")) ;; No tags to delete: (sgml-with-content "Drakaris!" (should-error (sgml-delete-tag 1) :type 'error) (should (string= "Drakaris!" (buffer-string)))) ;; Trying to delete 2 tags, when only 1 available: (sgml-with-content content (should-error (sgml-delete-tag 2) :type 'error) (should (string= "Drakaris!" (buffer-string)))) ;; Trying to delete a tag, but not on/before a tag: (sgml-with-content content (goto-char 7) ; D in Drakaris (should-error (sgml-delete-tag 1) :type 'error) (should (string= content (buffer-string)))) ;; Trying to delete a tag from position outside tag: (sgml-with-content content (goto-char (point-max)) (should-error (sgml-delete-tag 1) :type 'error) (should (string= content (buffer-string)))))) (ert-deftest sgml-delete-tag-bug-8203-should-not-delete-apostrophe () (sgml-with-content "Winter is comin'" (sgml-delete-tag 1) (should (string= "Winter is comin'" (buffer-string))))) (ert-deftest sgml-tests--quotes-syntax () (dolist (str '("a\"b c'd" "a'b c\"d" "\"a'" "'a\"" "\"a'\"" "'a\"'" "a\"b c'd" ;;"c>'d" Fixed in master. "" "" "(')" "(\")" )) (with-temp-buffer (sgml-mode) (insert str) (ert-info ((format "%S" str) :prefix "Test case: ") ;; Check that last tag is parsed as a tag. (should (= 1 (car (syntax-ppss (1- (point-max)))))) (should (= 0 (car (syntax-ppss (point-max))))))))) (provide 'sgml-mode-tests) ;;; sgml-mode-tests.el ends here