;;; nxml-mode-tests.el --- Test NXML Mode -*- lexical-binding: t; -*-
;; Copyright (C) 2019 Free Software Foundation, Inc.
;; 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 .
;;; Code:
(require 'ert)
(require 'nxml-mode)
(defun nxml-mode-tests-correctly-indented-string (str)
(with-temp-buffer
(nxml-mode)
(insert str)
(indent-region (point-min) (point-max))
(equal (buffer-string) str)))
(ert-deftest nxml-indent-line-after-attribute ()
(should (nxml-mode-tests-correctly-indented-string "
...
"))
(should (nxml-mode-tests-correctly-indented-string "\
")))
(ert-deftest nxml-balanced-close-start-tag-inline ()
(with-temp-buffer
(nxml-mode)
(insert "")
(search-backward "")
(nxml-balanced-close-start-tag-inline)
(should (equal (buffer-string) ""))))
(ert-deftest nxml-mode-font-lock-quotes ()
(with-temp-buffer
(nxml-mode)
(insert "\"dquote text\"'squote text'")
(font-lock-ensure)
(let ((squote-txt-pos (search-backward "squote text"))
(dquote-txt-pos (search-backward "dquote text"))
(squote-att-pos (search-backward "squote attr"))
(dquote-att-pos (search-backward "dquote attr")))
;; Just make sure that each quote uses the same face for quoted
;; attribute values, and a different face for quoted text
;; outside tags. Don't test `font-lock-string-face' vs
;; `nxml-attribute-value' here.
(should (equal (get-text-property squote-att-pos 'face)
(get-text-property dquote-att-pos 'face)))
(should (equal (get-text-property squote-txt-pos 'face)
(get-text-property dquote-txt-pos 'face)))
(should-not (equal (get-text-property squote-txt-pos 'face)
(get-text-property dquote-att-pos 'face))))))
(ert-deftest nxml-mode-doctype-and-quote-syntax ()
(with-temp-buffer
(insert "\n]>\n'")
(nxml-mode)
;; Check that last tag is parsed as a tag.
(should (= 1 (car (syntax-ppss (1- (point-max))))))
(should (= 0 (car (syntax-ppss (point-max)))))))
(ert-deftest nxml-mode-prolog-comment ()
(with-temp-buffer
(insert "
")
(nxml-mode)
;; Check that all comments are parsed as comments
(goto-char (point-min))
(search-forward "comment1")
(should (nth 4 (syntax-ppss)))
(search-forward "comment2")
(should (nth 4 (syntax-ppss)))
(search-forward "comment3")))
(ert-deftest nxml-mode->-after-quote ()
"Reduction from Bug#36092."
(with-temp-buffer
(insert "\n"
(make-string 1794 ?a) "\n"
"'>"
(make-string 196 ?a) "\n"
"")
(nxml-mode)
(syntax-propertize 2001)
(syntax-propertize (point-max)) ; Triggered an assert failure.
;; Check that last tag is parsed as a tag.
(should (= 1 (- (car (syntax-ppss (1- (point-max))))
(car (syntax-ppss (point-max))))))))
(provide 'nxml-mode-tests)
;;; nxml-mode-tests.el ends here