;;; nxml-mode-tests.el --- Test NXML Mode -*- lexical-binding: t; -*- ;; Copyright (C) 2019-2023 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 . ;;; 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)))))))) (ert-deftest nxml-mode-edit-prolog () "Test for Bug#23668." (with-temp-buffer (insert " ") (nxml-mode) ;; The leading "\n " before "" is the prolog, indenting will ;; delete the space hence changing the prolog size. If that is ;; not taken into account, then the tag won't be indented ;; correctly. (indent-region (point-min) (point-max)) (should (equal (buffer-string) " ")))) (ert-deftest nxml-mode-test-comment-bug-17264 () "Test for Bug#17264." (with-temp-buffer (nxml-mode) (let ((data " ")) (insert data) (goto-char (point-min)) (search-forward "