2020-05-01 11:02:38 +00:00
|
|
|
|
;;; subr-tests.el --- Tests for subr.el -*- lexical-binding:t -*-
|
2015-05-20 13:38:55 +00:00
|
|
|
|
|
2021-01-01 09:13:56 +00:00
|
|
|
|
;; Copyright (C) 2015-2021 Free Software Foundation, Inc.
|
2015-05-20 13:38:55 +00:00
|
|
|
|
|
2015-06-04 16:20:18 +00:00
|
|
|
|
;; Author: Oleh Krehel <ohwoeowho@gmail.com>,
|
|
|
|
|
;; Nicolas Petton <nicolas@petton.fr>
|
2015-05-20 13:38:55 +00:00
|
|
|
|
;; Keywords:
|
|
|
|
|
|
2015-05-20 15:34:53 +00:00
|
|
|
|
;; This file is part of GNU Emacs.
|
|
|
|
|
|
|
|
|
|
;; GNU Emacs is free software: you can redistribute it and/or modify
|
2015-05-20 13:38:55 +00:00
|
|
|
|
;; 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.
|
|
|
|
|
|
2015-05-20 15:34:53 +00:00
|
|
|
|
;; GNU Emacs is distributed in the hope that it will be useful,
|
2015-05-20 13:38:55 +00:00
|
|
|
|
;; 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
|
2017-09-13 22:52:52 +00:00
|
|
|
|
;; along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
|
2015-05-20 13:38:55 +00:00
|
|
|
|
|
|
|
|
|
;;; Commentary:
|
|
|
|
|
|
|
|
|
|
;;
|
|
|
|
|
|
|
|
|
|
;;; Code:
|
|
|
|
|
(require 'ert)
|
2017-06-05 00:35:29 +00:00
|
|
|
|
(eval-when-compile (require 'cl-lib))
|
2015-05-20 13:38:55 +00:00
|
|
|
|
|
|
|
|
|
(ert-deftest let-when-compile ()
|
|
|
|
|
;; good case
|
|
|
|
|
(should (equal (macroexpand '(let-when-compile ((foo (+ 2 3)))
|
|
|
|
|
(setq bar (eval-when-compile (+ foo foo)))
|
|
|
|
|
(setq boo (eval-when-compile (* foo foo)))))
|
|
|
|
|
'(progn
|
|
|
|
|
(setq bar (quote 10))
|
|
|
|
|
(setq boo (quote 25)))))
|
|
|
|
|
;; bad case: `eval-when-compile' omitted, byte compiler should catch this
|
|
|
|
|
(should (equal (macroexpand
|
|
|
|
|
'(let-when-compile ((foo (+ 2 3)))
|
|
|
|
|
(setq bar (+ foo foo))
|
|
|
|
|
(setq boo (eval-when-compile (* foo foo)))))
|
|
|
|
|
'(progn
|
|
|
|
|
(setq bar (+ foo foo))
|
|
|
|
|
(setq boo (quote 25)))))
|
|
|
|
|
;; something practical
|
|
|
|
|
(should (equal (macroexpand
|
|
|
|
|
'(let-when-compile ((keywords '("true" "false")))
|
|
|
|
|
(font-lock-add-keywords
|
|
|
|
|
'c++-mode
|
|
|
|
|
`((,(eval-when-compile
|
|
|
|
|
(format "\\<%s\\>" (regexp-opt keywords)))
|
|
|
|
|
0 font-lock-keyword-face)))))
|
|
|
|
|
'(font-lock-add-keywords
|
|
|
|
|
(quote c++-mode)
|
|
|
|
|
(list
|
|
|
|
|
(cons (quote
|
|
|
|
|
"\\<\\(?:\\(?:fals\\|tru\\)e\\)\\>")
|
|
|
|
|
(quote
|
|
|
|
|
(0 font-lock-keyword-face))))))))
|
|
|
|
|
|
2021-07-28 11:31:40 +00:00
|
|
|
|
|
|
|
|
|
;;;; List functions.
|
|
|
|
|
|
|
|
|
|
(ert-deftest subr-test-caaar ()
|
|
|
|
|
(should (null (caaar '())))
|
|
|
|
|
(should (null (caaar '(() (2)))))
|
|
|
|
|
(should (null (caaar '((() (2)) (a b)))))
|
|
|
|
|
(should-error (caaar '(1 2)) :type 'wrong-type-argument)
|
|
|
|
|
(should-error (caaar '((1 2))) :type 'wrong-type-argument)
|
|
|
|
|
(should (= 1 (caaar '(((1 2) (3 4))))))
|
|
|
|
|
(should (null (caaar '((() (3 4)))))))
|
|
|
|
|
|
|
|
|
|
(ert-deftest subr-test-caadr ()
|
|
|
|
|
(should (null (caadr '())))
|
|
|
|
|
(should (null (caadr '(1))))
|
|
|
|
|
(should-error (caadr '(1 2)) :type 'wrong-type-argument)
|
|
|
|
|
(should (= 2 (caadr '(1 (2 3)))))
|
|
|
|
|
(should (equal '((2) (3)) (caadr '((1) (((2) (3))) (4))))))
|
|
|
|
|
|
2021-01-08 11:27:32 +00:00
|
|
|
|
|
|
|
|
|
;;;; Keymap support.
|
|
|
|
|
|
|
|
|
|
(ert-deftest subr-test-kbd ()
|
|
|
|
|
(should (equal (kbd "f") "f"))
|
2021-01-08 14:26:02 +00:00
|
|
|
|
(should (equal (kbd "<f1>") [f1]))
|
2021-01-08 11:27:32 +00:00
|
|
|
|
(should (equal (kbd "RET") "\C-m"))
|
2021-01-08 14:26:02 +00:00
|
|
|
|
(should (equal (kbd "C-x a") "\C-xa"))
|
|
|
|
|
;; Check that kbd handles both new and old style key descriptions
|
|
|
|
|
;; (bug#45536).
|
|
|
|
|
(should (equal (kbd "s-<return>") [s-return]))
|
|
|
|
|
(should (equal (kbd "<s-return>") [s-return]))
|
|
|
|
|
(should (equal (kbd "C-M-<return>") [C-M-return]))
|
|
|
|
|
(should (equal (kbd "<C-M-return>") [C-M-return])))
|
2021-01-08 11:27:32 +00:00
|
|
|
|
|
2021-01-08 14:16:02 +00:00
|
|
|
|
(ert-deftest subr-test-define-prefix-command ()
|
|
|
|
|
(define-prefix-command 'foo-prefix-map)
|
2021-03-07 14:55:15 +00:00
|
|
|
|
(defvar foo-prefix-map)
|
|
|
|
|
(declare-function foo-prefix-map "subr-tests")
|
2021-01-08 14:16:02 +00:00
|
|
|
|
(should (keymapp foo-prefix-map))
|
|
|
|
|
(should (fboundp #'foo-prefix-map))
|
|
|
|
|
;; With optional argument.
|
|
|
|
|
(define-prefix-command 'bar-prefix 'bar-prefix-map)
|
2021-03-07 14:55:15 +00:00
|
|
|
|
(defvar bar-prefix-map)
|
|
|
|
|
(declare-function bar-prefix "subr-tests")
|
2021-01-08 14:16:02 +00:00
|
|
|
|
(should (keymapp bar-prefix-map))
|
|
|
|
|
(should (fboundp #'bar-prefix))
|
|
|
|
|
;; Returns the symbol.
|
|
|
|
|
(should (eq (define-prefix-command 'foo-bar) 'foo-bar)))
|
|
|
|
|
|
2021-01-13 17:54:09 +00:00
|
|
|
|
(ert-deftest subr-test-local-key-binding ()
|
|
|
|
|
(with-temp-buffer
|
|
|
|
|
(emacs-lisp-mode)
|
|
|
|
|
(should (keymapp (local-key-binding [menu-bar])))
|
|
|
|
|
(should-not (local-key-binding [f12]))))
|
|
|
|
|
|
|
|
|
|
(ert-deftest subr-test-global-key-binding ()
|
|
|
|
|
(should (eq (global-key-binding [f1]) 'help-command))
|
|
|
|
|
(should (eq (global-key-binding "x") 'self-insert-command))
|
|
|
|
|
(should-not (global-key-binding [f12])))
|
|
|
|
|
|
2021-01-08 11:27:32 +00:00
|
|
|
|
|
|
|
|
|
;;;; Mode hooks.
|
|
|
|
|
|
2019-05-29 19:56:14 +00:00
|
|
|
|
(defalias 'subr-tests--parent-mode
|
|
|
|
|
(if (fboundp 'prog-mode) 'prog-mode 'fundamental-mode))
|
|
|
|
|
|
2018-09-25 04:09:39 +00:00
|
|
|
|
(ert-deftest provided-mode-derived-p ()
|
|
|
|
|
;; base case: `derived-mode' directly derives `prog-mode'
|
|
|
|
|
(should (progn
|
|
|
|
|
(define-derived-mode derived-mode prog-mode "test")
|
|
|
|
|
(provided-mode-derived-p 'derived-mode 'prog-mode)))
|
|
|
|
|
;; edge case: `derived-mode' derives an alias of `prog-mode'
|
|
|
|
|
(should (progn
|
2019-05-29 19:56:14 +00:00
|
|
|
|
(define-derived-mode derived-mode subr-tests--parent-mode "test")
|
2018-09-25 04:09:39 +00:00
|
|
|
|
(provided-mode-derived-p 'derived-mode 'prog-mode))))
|
|
|
|
|
|
2016-05-27 09:17:15 +00:00
|
|
|
|
(ert-deftest number-sequence-test ()
|
|
|
|
|
(should (= (length
|
|
|
|
|
(number-sequence (1- most-positive-fixnum) most-positive-fixnum))
|
|
|
|
|
2))
|
|
|
|
|
(should (= (length
|
|
|
|
|
(number-sequence
|
|
|
|
|
(1+ most-negative-fixnum) most-negative-fixnum -1))
|
|
|
|
|
2)))
|
|
|
|
|
|
2015-06-04 16:20:18 +00:00
|
|
|
|
(ert-deftest string-comparison-test ()
|
|
|
|
|
(should (string-lessp "abc" "acb"))
|
|
|
|
|
(should (string-lessp "aBc" "abc"))
|
|
|
|
|
(should (string-lessp "abc" "abcd"))
|
|
|
|
|
(should (string-lessp "abc" "abcd"))
|
|
|
|
|
(should-not (string-lessp "abc" "abc"))
|
|
|
|
|
(should-not (string-lessp "" ""))
|
|
|
|
|
|
|
|
|
|
(should (string-greaterp "acb" "abc"))
|
|
|
|
|
(should (string-greaterp "abc" "aBc"))
|
|
|
|
|
(should (string-greaterp "abcd" "abc"))
|
|
|
|
|
(should (string-greaterp "abcd" "abc"))
|
|
|
|
|
(should-not (string-greaterp "abc" "abc"))
|
|
|
|
|
(should-not (string-greaterp "" ""))
|
|
|
|
|
|
|
|
|
|
;; Symbols are also accepted
|
|
|
|
|
(should (string-lessp 'abc 'acb))
|
|
|
|
|
(should (string-lessp "abc" 'acb))
|
|
|
|
|
(should (string-greaterp 'acb 'abc))
|
|
|
|
|
(should (string-greaterp "acb" 'abc)))
|
|
|
|
|
|
2015-11-04 12:54:53 +00:00
|
|
|
|
(ert-deftest subr-test-when ()
|
|
|
|
|
(should (equal (when t 1) 1))
|
|
|
|
|
(should (equal (when t 2) 2))
|
|
|
|
|
(should (equal (when nil 1) nil))
|
|
|
|
|
(should (equal (when nil 2) nil))
|
|
|
|
|
(should (equal (when t 'x 1) 1))
|
|
|
|
|
(should (equal (when t 'x 2) 2))
|
|
|
|
|
(should (equal (when nil 'x 1) nil))
|
|
|
|
|
(should (equal (when nil 'x 2) nil))
|
2015-11-06 11:18:23 +00:00
|
|
|
|
(let ((x 1))
|
|
|
|
|
(should-not (when nil
|
|
|
|
|
(setq x (1+ x))
|
|
|
|
|
x))
|
|
|
|
|
(should (= x 1))
|
2015-11-06 15:53:23 +00:00
|
|
|
|
(should (= 2 (when t
|
2015-11-06 11:18:23 +00:00
|
|
|
|
(setq x (1+ x))
|
|
|
|
|
x)))
|
|
|
|
|
(should (= x 2)))
|
2015-11-04 12:54:53 +00:00
|
|
|
|
(should (equal (macroexpand-all '(when a b c d))
|
|
|
|
|
'(if a (progn b c d)))))
|
|
|
|
|
|
2019-07-31 17:45:06 +00:00
|
|
|
|
(ert-deftest subr-test-xor ()
|
|
|
|
|
"Test `xor'."
|
|
|
|
|
(should-not (xor nil nil))
|
|
|
|
|
(should (eq (xor nil 'true) 'true))
|
|
|
|
|
(should (eq (xor 'true nil) 'true))
|
|
|
|
|
(should-not (xor t t)))
|
|
|
|
|
|
2015-12-05 09:32:01 +00:00
|
|
|
|
(ert-deftest subr-test-version-parsing ()
|
|
|
|
|
(should (equal (version-to-list ".5") '(0 5)))
|
|
|
|
|
(should (equal (version-to-list "0.9 alpha1") '(0 9 -3 1)))
|
|
|
|
|
(should (equal (version-to-list "0.9 snapshot") '(0 9 -4)))
|
|
|
|
|
(should (equal (version-to-list "0.9-alpha1") '(0 9 -3 1)))
|
|
|
|
|
(should (equal (version-to-list "0.9-snapshot") '(0 9 -4)))
|
|
|
|
|
(should (equal (version-to-list "0.9.snapshot") '(0 9 -4)))
|
|
|
|
|
(should (equal (version-to-list "0.9_snapshot") '(0 9 -4)))
|
|
|
|
|
(should (equal (version-to-list "0.9alpha1") '(0 9 -3 1)))
|
|
|
|
|
(should (equal (version-to-list "0.9snapshot") '(0 9 -4)))
|
|
|
|
|
(should (equal (version-to-list "1.0 git") '(1 0 -4)))
|
|
|
|
|
(should (equal (version-to-list "1.0 pre2") '(1 0 -1 2)))
|
|
|
|
|
(should (equal (version-to-list "1.0-git") '(1 0 -4)))
|
|
|
|
|
(should (equal (version-to-list "1.0-pre2") '(1 0 -1 2)))
|
|
|
|
|
(should (equal (version-to-list "1.0.1-a") '(1 0 1 1)))
|
|
|
|
|
(should (equal (version-to-list "1.0.1-f") '(1 0 1 6)))
|
|
|
|
|
(should (equal (version-to-list "1.0.1.a") '(1 0 1 1)))
|
|
|
|
|
(should (equal (version-to-list "1.0.1.f") '(1 0 1 6)))
|
|
|
|
|
(should (equal (version-to-list "1.0.1_a") '(1 0 1 1)))
|
|
|
|
|
(should (equal (version-to-list "1.0.1_f") '(1 0 1 6)))
|
|
|
|
|
(should (equal (version-to-list "1.0.1a") '(1 0 1 1)))
|
|
|
|
|
(should (equal (version-to-list "1.0.1f") '(1 0 1 6)))
|
|
|
|
|
(should (equal (version-to-list "1.0.7.5") '(1 0 7 5)))
|
|
|
|
|
(should (equal (version-to-list "1.0.git") '(1 0 -4)))
|
|
|
|
|
(should (equal (version-to-list "1.0.pre2") '(1 0 -1 2)))
|
|
|
|
|
(should (equal (version-to-list "1.0_git") '(1 0 -4)))
|
|
|
|
|
(should (equal (version-to-list "1.0_pre2") '(1 0 -1 2)))
|
|
|
|
|
(should (equal (version-to-list "1.0git") '(1 0 -4)))
|
|
|
|
|
(should (equal (version-to-list "1.0pre2") '(1 0 -1 2)))
|
|
|
|
|
(should (equal (version-to-list "22.8 beta3") '(22 8 -2 3)))
|
|
|
|
|
(should (equal (version-to-list "22.8-beta3") '(22 8 -2 3)))
|
|
|
|
|
(should (equal (version-to-list "22.8.beta3") '(22 8 -2 3)))
|
|
|
|
|
(should (equal (version-to-list "22.8_beta3") '(22 8 -2 3)))
|
|
|
|
|
(should (equal (version-to-list "22.8beta3") '(22 8 -2 3)))
|
|
|
|
|
(should (equal (version-to-list "6.9.30 Beta") '(6 9 30 -2)))
|
|
|
|
|
(should (equal (version-to-list "6.9.30-Beta") '(6 9 30 -2)))
|
|
|
|
|
(should (equal (version-to-list "6.9.30.Beta") '(6 9 30 -2)))
|
|
|
|
|
(should (equal (version-to-list "6.9.30Beta") '(6 9 30 -2)))
|
|
|
|
|
(should (equal (version-to-list "6.9.30_Beta") '(6 9 30 -2)))
|
|
|
|
|
|
2020-09-12 18:57:42 +00:00
|
|
|
|
(let ((text-quoting-style 'grave))
|
|
|
|
|
(should (equal
|
|
|
|
|
(error-message-string (should-error (version-to-list "OTP-18.1.5")))
|
|
|
|
|
"Invalid version syntax: `OTP-18.1.5' (must start with a number)"))
|
|
|
|
|
(should (equal
|
|
|
|
|
(error-message-string (should-error (version-to-list "")))
|
|
|
|
|
"Invalid version syntax: `' (must start with a number)"))
|
|
|
|
|
(should (equal
|
|
|
|
|
(error-message-string (should-error (version-to-list "1.0..7.5")))
|
|
|
|
|
"Invalid version syntax: `1.0..7.5'"))
|
|
|
|
|
(should (equal
|
|
|
|
|
(error-message-string (should-error (version-to-list "1.0prepre2")))
|
|
|
|
|
"Invalid version syntax: `1.0prepre2'"))
|
|
|
|
|
(should (equal
|
|
|
|
|
(error-message-string (should-error (version-to-list "22.8X3")))
|
|
|
|
|
"Invalid version syntax: `22.8X3'"))
|
|
|
|
|
(should (equal
|
|
|
|
|
(error-message-string (should-error (version-to-list "beta22.8alpha3")))
|
|
|
|
|
"Invalid version syntax: `beta22.8alpha3' (must start with a number)"))
|
|
|
|
|
(should (equal
|
|
|
|
|
(error-message-string (should-error (version-to-list "honk")))
|
|
|
|
|
"Invalid version syntax: `honk' (must start with a number)")))
|
2015-12-05 09:32:01 +00:00
|
|
|
|
(should (equal
|
|
|
|
|
(error-message-string (should-error (version-to-list 9)))
|
|
|
|
|
"Version must be a string"))
|
|
|
|
|
|
|
|
|
|
(let ((version-separator "_"))
|
|
|
|
|
(should (equal (version-to-list "_5") '(0 5)))
|
|
|
|
|
(should (equal (version-to-list "0_9 alpha1") '(0 9 -3 1)))
|
|
|
|
|
(should (equal (version-to-list "0_9 snapshot") '(0 9 -4)))
|
|
|
|
|
(should (equal (version-to-list "0_9-alpha1") '(0 9 -3 1)))
|
|
|
|
|
(should (equal (version-to-list "0_9-snapshot") '(0 9 -4)))
|
|
|
|
|
(should (equal (version-to-list "0_9.alpha1") '(0 9 -3 1)))
|
|
|
|
|
(should (equal (version-to-list "0_9.snapshot") '(0 9 -4)))
|
|
|
|
|
(should (equal (version-to-list "0_9alpha1") '(0 9 -3 1)))
|
|
|
|
|
(should (equal (version-to-list "0_9snapshot") '(0 9 -4)))
|
|
|
|
|
(should (equal (version-to-list "1_0 git") '(1 0 -4)))
|
|
|
|
|
(should (equal (version-to-list "1_0 pre2") '(1 0 -1 2)))
|
|
|
|
|
(should (equal (version-to-list "1_0-git") '(1 0 -4)))
|
|
|
|
|
(should (equal (version-to-list "1_0.pre2") '(1 0 -1 2)))
|
|
|
|
|
(should (equal (version-to-list "1_0_1-a") '(1 0 1 1)))
|
|
|
|
|
(should (equal (version-to-list "1_0_1-f") '(1 0 1 6)))
|
|
|
|
|
(should (equal (version-to-list "1_0_1.a") '(1 0 1 1)))
|
|
|
|
|
(should (equal (version-to-list "1_0_1.f") '(1 0 1 6)))
|
|
|
|
|
(should (equal (version-to-list "1_0_1_a") '(1 0 1 1)))
|
|
|
|
|
(should (equal (version-to-list "1_0_1_f") '(1 0 1 6)))
|
|
|
|
|
(should (equal (version-to-list "1_0_1a") '(1 0 1 1)))
|
|
|
|
|
(should (equal (version-to-list "1_0_1f") '(1 0 1 6)))
|
|
|
|
|
(should (equal (version-to-list "1_0_7_5") '(1 0 7 5)))
|
|
|
|
|
(should (equal (version-to-list "1_0_git") '(1 0 -4)))
|
|
|
|
|
(should (equal (version-to-list "1_0pre2") '(1 0 -1 2)))
|
|
|
|
|
(should (equal (version-to-list "22_8 beta3") '(22 8 -2 3)))
|
|
|
|
|
(should (equal (version-to-list "22_8-beta3") '(22 8 -2 3)))
|
|
|
|
|
(should (equal (version-to-list "22_8.beta3") '(22 8 -2 3)))
|
|
|
|
|
(should (equal (version-to-list "22_8beta3") '(22 8 -2 3)))
|
|
|
|
|
(should (equal (version-to-list "6_9_30 Beta") '(6 9 30 -2)))
|
|
|
|
|
(should (equal (version-to-list "6_9_30-Beta") '(6 9 30 -2)))
|
|
|
|
|
(should (equal (version-to-list "6_9_30.Beta") '(6 9 30 -2)))
|
|
|
|
|
(should (equal (version-to-list "6_9_30Beta") '(6 9 30 -2)))
|
|
|
|
|
|
2020-09-12 18:57:42 +00:00
|
|
|
|
(let ((text-quoting-style 'grave))
|
|
|
|
|
(should (equal
|
|
|
|
|
(error-message-string (should-error (version-to-list "1_0__7_5")))
|
|
|
|
|
"Invalid version syntax: `1_0__7_5'"))
|
|
|
|
|
(should (equal
|
|
|
|
|
(error-message-string (should-error (version-to-list "1_0prepre2")))
|
|
|
|
|
"Invalid version syntax: `1_0prepre2'"))
|
|
|
|
|
(should (equal
|
|
|
|
|
(error-message-string (should-error (version-to-list "22.8X3")))
|
|
|
|
|
"Invalid version syntax: `22.8X3'"))
|
|
|
|
|
(should (equal
|
|
|
|
|
(error-message-string (should-error (version-to-list "beta22_8alpha3")))
|
|
|
|
|
"Invalid version syntax: `beta22_8alpha3' (must start with a number)")))))
|
2015-12-05 09:32:01 +00:00
|
|
|
|
|
2019-11-12 01:01:22 +00:00
|
|
|
|
(ert-deftest subr-test-version-list-< ()
|
|
|
|
|
(should (version-list-< '(0) '(1)))
|
|
|
|
|
(should (version-list-< '(0 9) '(1 0)))
|
|
|
|
|
(should (version-list-< '(1 -1) '(1 0)))
|
|
|
|
|
(should (version-list-< '(1 -2) '(1 -1)))
|
|
|
|
|
(should (not (version-list-< '(1) '(0))))
|
|
|
|
|
(should (not (version-list-< '(1 1) '(1 0))))
|
|
|
|
|
(should (not (version-list-< '(1) '(1 0))))
|
|
|
|
|
(should (not (version-list-< '(1 0) '(1 0 0)))))
|
|
|
|
|
|
|
|
|
|
(ert-deftest subr-test-version-list-= ()
|
|
|
|
|
(should (version-list-= '(1) '(1)))
|
|
|
|
|
(should (version-list-= '(1 0) '(1)))
|
|
|
|
|
(should (not (version-list-= '(0) '(1)))))
|
|
|
|
|
|
|
|
|
|
(ert-deftest subr-test-version-list-<= ()
|
|
|
|
|
(should (version-list-<= '(0) '(1)))
|
|
|
|
|
(should (version-list-<= '(1) '(1)))
|
|
|
|
|
(should (version-list-<= '(1 0) '(1)))
|
|
|
|
|
(should (not (version-list-<= '(1) '(0)))))
|
|
|
|
|
|
2016-12-05 05:52:14 +00:00
|
|
|
|
(defun subr-test--backtrace-frames-with-backtrace-frame (base)
|
|
|
|
|
"Reference implementation of `backtrace-frames'."
|
|
|
|
|
(let ((idx 0)
|
|
|
|
|
(frame nil)
|
|
|
|
|
(frames nil))
|
|
|
|
|
(while (setq frame (backtrace-frame idx base))
|
|
|
|
|
(push frame frames)
|
|
|
|
|
(setq idx (1+ idx)))
|
|
|
|
|
(nreverse frames)))
|
|
|
|
|
|
|
|
|
|
(defun subr-test--frames-2 (base)
|
|
|
|
|
(let ((_dummy nil))
|
|
|
|
|
(progn ;; Add a few frames to top of stack
|
|
|
|
|
(unwind-protect
|
|
|
|
|
(cons (mapcar (pcase-lambda (`(,evald ,func ,args ,_))
|
|
|
|
|
`(,evald ,func ,@args))
|
|
|
|
|
(backtrace-frames base))
|
|
|
|
|
(subr-test--backtrace-frames-with-backtrace-frame base))))))
|
|
|
|
|
|
|
|
|
|
(defun subr-test--frames-1 (base)
|
|
|
|
|
(subr-test--frames-2 base))
|
|
|
|
|
|
|
|
|
|
(ert-deftest subr-test-backtrace-simple-tests ()
|
|
|
|
|
"Test backtrace-related functions (simple tests).
|
|
|
|
|
This exercises `backtrace-frame', and indirectly `mapbacktrace'."
|
|
|
|
|
;; `mapbacktrace' returns nil
|
|
|
|
|
(should (equal (mapbacktrace #'ignore) nil))
|
|
|
|
|
;; Unbound BASE is silently ignored
|
|
|
|
|
(let ((unbound (make-symbol "ub")))
|
|
|
|
|
(should (equal (backtrace-frame 0 unbound) nil))
|
|
|
|
|
(should (equal (mapbacktrace #'error unbound) nil)))
|
|
|
|
|
;; First frame is backtrace-related function
|
|
|
|
|
(should (equal (backtrace-frame 0) '(t backtrace-frame 0)))
|
2017-07-15 16:12:17 +00:00
|
|
|
|
(let ((throw-args (lambda (&rest args) (throw 'ret args))))
|
|
|
|
|
(should (equal (catch 'ret (mapbacktrace throw-args))
|
|
|
|
|
`(t mapbacktrace (,throw-args) nil))))
|
2016-12-05 05:52:14 +00:00
|
|
|
|
;; Past-end NFRAMES is silently ignored
|
|
|
|
|
(should (equal (backtrace-frame most-positive-fixnum) nil)))
|
|
|
|
|
|
|
|
|
|
(ert-deftest subr-test-backtrace-integration-test ()
|
|
|
|
|
"Test backtrace-related functions (integration test).
|
|
|
|
|
This exercises `backtrace-frame', `backtrace-frames', and
|
|
|
|
|
indirectly `mapbacktrace'."
|
|
|
|
|
;; Compare two implementations of backtrace-frames
|
|
|
|
|
(let ((frame-lists (subr-test--frames-1 'subr-test--frames-2)))
|
|
|
|
|
(should (equal (car frame-lists) (cdr frame-lists)))))
|
|
|
|
|
|
2017-01-06 14:56:51 +00:00
|
|
|
|
(ert-deftest subr-tests--string-match-p--blank ()
|
|
|
|
|
"Test that [:blank:] matches horizontal whitespace, cf. Bug#25366."
|
|
|
|
|
(should (equal (string-match-p "\\`[[:blank:]]\\'" " ") 0))
|
|
|
|
|
(should (equal (string-match-p "\\`[[:blank:]]\\'" "\t") 0))
|
|
|
|
|
(should-not (string-match-p "\\`[[:blank:]]\\'" "\n"))
|
|
|
|
|
(should-not (string-match-p "\\`[[:blank:]]\\'" "a"))
|
|
|
|
|
(should (equal (string-match-p "\\`[[:blank:]]\\'" "\N{HAIR SPACE}") 0))
|
|
|
|
|
(should (equal (string-match-p "\\`[[:blank:]]\\'" "\u3000") 0))
|
|
|
|
|
(should-not (string-match-p "\\`[[:blank:]]\\'" "\N{LINE SEPARATOR}")))
|
|
|
|
|
|
2017-03-26 18:53:43 +00:00
|
|
|
|
(ert-deftest subr-tests--dolist--wrong-number-of-args ()
|
|
|
|
|
"Test that `dolist' doesn't accept wrong types or length of SPEC,
|
|
|
|
|
cf. Bug#25477."
|
|
|
|
|
(should-error (eval '(dolist (a)))
|
|
|
|
|
:type 'wrong-number-of-arguments)
|
|
|
|
|
(should-error (eval '(dolist (a () 'result 'invalid)) t)
|
|
|
|
|
:type 'wrong-number-of-arguments)
|
|
|
|
|
(should-error (eval '(dolist "foo") t)
|
|
|
|
|
:type 'wrong-type-argument))
|
|
|
|
|
|
2017-06-05 00:35:29 +00:00
|
|
|
|
(ert-deftest subr-tests-bug22027 ()
|
2017-09-13 22:52:52 +00:00
|
|
|
|
"Test for https://debbugs.gnu.org/22027 ."
|
2017-06-05 00:35:29 +00:00
|
|
|
|
(let ((default "foo") res)
|
2020-10-04 18:09:04 +00:00
|
|
|
|
(cl-letf (((symbol-function 'read-string)
|
2021-04-26 23:31:52 +00:00
|
|
|
|
(lambda (_prompt &optional _init _hist def _inher-input) def)))
|
2017-06-05 00:35:29 +00:00
|
|
|
|
(setq res (read-passwd "pass: " 'confirm (mapconcat #'string default "")))
|
|
|
|
|
(should (string= default res)))))
|
|
|
|
|
|
2017-09-18 13:00:45 +00:00
|
|
|
|
(ert-deftest subr-tests--gensym ()
|
|
|
|
|
"Test `gensym' behavior."
|
|
|
|
|
(should (equal (symbol-name (let ((gensym-counter 0)) (gensym)))
|
|
|
|
|
"g0"))
|
|
|
|
|
(should (eq (string-to-char (symbol-name (gensym))) ?g))
|
|
|
|
|
(should (eq (string-to-char (symbol-name (gensym "X"))) ?X)))
|
2017-06-05 00:35:29 +00:00
|
|
|
|
|
2018-01-28 04:05:54 +00:00
|
|
|
|
(ert-deftest subr-tests--assq-delete-all ()
|
|
|
|
|
"Test `assq-delete-all' behavior."
|
|
|
|
|
(cl-flet ((new-list-fn
|
|
|
|
|
()
|
|
|
|
|
(list (cons 'a 1) (cons 'b 2) (cons 'c 3) 'd (cons "foo" "bar"))))
|
|
|
|
|
(should (equal (cdr (new-list-fn)) (assq-delete-all 'a (new-list-fn))))
|
|
|
|
|
(should (equal (new-list-fn) (assq-delete-all 'd (new-list-fn))))
|
|
|
|
|
(should (equal (new-list-fn) (assq-delete-all "foo" (new-list-fn))))))
|
|
|
|
|
|
|
|
|
|
(ert-deftest subr-tests--assoc-delete-all ()
|
|
|
|
|
"Test `assoc-delete-all' behavior."
|
|
|
|
|
(cl-flet ((new-list-fn
|
|
|
|
|
()
|
|
|
|
|
(list (cons 'a 1) (cons 'b 2) (cons 'c 3) 'd (cons "foo" "bar"))))
|
|
|
|
|
(should (equal (cdr (new-list-fn)) (assoc-delete-all 'a (new-list-fn))))
|
|
|
|
|
(should (equal (new-list-fn) (assoc-delete-all 'd (new-list-fn))))
|
|
|
|
|
(should (equal (butlast (new-list-fn))
|
|
|
|
|
(assoc-delete-all "foo" (new-list-fn))))))
|
|
|
|
|
|
2018-02-06 18:17:07 +00:00
|
|
|
|
(ert-deftest shell-quote-argument-%-on-w32 ()
|
|
|
|
|
"Quoting of `%' in w32 shells isn't perfect.
|
|
|
|
|
See https://debbugs.gnu.org/cgi/bugreport.cgi?bug=19350."
|
|
|
|
|
:expected-result :failed
|
|
|
|
|
(skip-unless (and (fboundp 'w32-shell-dos-semantics)
|
|
|
|
|
(w32-shell-dos-semantics)))
|
|
|
|
|
(let ((process-environment (append '("ca^=with-caret"
|
|
|
|
|
"ca=without-caret")
|
|
|
|
|
process-environment)))
|
|
|
|
|
;; It actually results in
|
|
|
|
|
;; without-caret with-caret
|
|
|
|
|
(should (equal (shell-command-to-string
|
|
|
|
|
(format "echo %s %s"
|
|
|
|
|
"%ca%"
|
|
|
|
|
(shell-quote-argument "%ca%")))
|
|
|
|
|
"without-caret %ca%"))))
|
|
|
|
|
|
New function flatten-tree
Co-authored-by: Basil L. Contovounesios <contovob@tcd.ie>
* doc/lispref/lists.texi: Document `flatten-tree'.
* lisp/progmodes/js.el (js--maybe-join):
* lisp/printing.el (pr-switches):
* lisp/lpr.el (lpr-print-region):
* lisp/gnus/nnimap.el (nnimap-find-wanted-parts):
* lisp/gnus/message.el (message-talkative-question):
* lisp/gnus/gnus-sum.el (gnus-remove-thread)
(gnus-thread-highest-number, gnus-thread-latest-date):
* lisp/eshell/esh-util.el (eshell-flatten-and-stringify):
* lisp/eshell/esh-opt.el (eshell-eval-using-options):
* lisp/eshell/esh-ext.el (eshell-external-command):
* lisp/eshell/em-xtra.el (eshell/expr):
* lisp/eshell/em-unix.el (eshell/rm, eshell-mvcpln-template)
(eshell/cat, eshell/make, eshell-poor-mans-grep, eshell-grep)
(eshell/du, eshell/time, eshell/diff, eshell/locate):
* lisp/eshell/em-tramp.el (eshell/su, eshell/sudo):
* lisp/eshell/em-term.el (eshell-exec-visual):
* lisp/eshell/em-dirs.el (eshell-dirs-substitute-cd, eshell/cd):
* lisp/eshell/em-basic.el (eshell/printnl):
Use new flatten-tree.
* lisp/progmodes/js.el (js--flatten-list):
* lisp/lpr.el (lpr-flatten-list):
* lisp/gnus/message.el (message-flatten-list):
* lisp/eshell/esh-util.el (eshell-flatten-list):
Obsolete in favor of Emacs-wide `flatten-tree'.
* lisp/subr.el (flatten-list): Alias to `flatten-tree' for
discoverability.
* lisp/subr.el (flatten-tree): New defun.
* test/lisp/subr-tests.el (subr-tests-flatten-tree): New test.
2018-12-17 11:15:09 +00:00
|
|
|
|
(ert-deftest subr-tests-flatten-tree ()
|
|
|
|
|
"Test `flatten-tree' behavior."
|
|
|
|
|
(should (equal (flatten-tree '(1 (2 . 3) nil (4 5 (6)) 7))
|
|
|
|
|
'(1 2 3 4 5 6 7)))
|
|
|
|
|
(should (equal (flatten-tree '((1 . 2)))
|
|
|
|
|
'(1 2)))
|
|
|
|
|
(should (equal (flatten-tree '(1 nil 2))
|
|
|
|
|
'(1 2)))
|
|
|
|
|
(should (equal (flatten-tree 42)
|
|
|
|
|
'(42)))
|
|
|
|
|
(should (equal (flatten-tree t)
|
2018-12-17 18:19:48 +00:00
|
|
|
|
'(t)))
|
New function flatten-tree
Co-authored-by: Basil L. Contovounesios <contovob@tcd.ie>
* doc/lispref/lists.texi: Document `flatten-tree'.
* lisp/progmodes/js.el (js--maybe-join):
* lisp/printing.el (pr-switches):
* lisp/lpr.el (lpr-print-region):
* lisp/gnus/nnimap.el (nnimap-find-wanted-parts):
* lisp/gnus/message.el (message-talkative-question):
* lisp/gnus/gnus-sum.el (gnus-remove-thread)
(gnus-thread-highest-number, gnus-thread-latest-date):
* lisp/eshell/esh-util.el (eshell-flatten-and-stringify):
* lisp/eshell/esh-opt.el (eshell-eval-using-options):
* lisp/eshell/esh-ext.el (eshell-external-command):
* lisp/eshell/em-xtra.el (eshell/expr):
* lisp/eshell/em-unix.el (eshell/rm, eshell-mvcpln-template)
(eshell/cat, eshell/make, eshell-poor-mans-grep, eshell-grep)
(eshell/du, eshell/time, eshell/diff, eshell/locate):
* lisp/eshell/em-tramp.el (eshell/su, eshell/sudo):
* lisp/eshell/em-term.el (eshell-exec-visual):
* lisp/eshell/em-dirs.el (eshell-dirs-substitute-cd, eshell/cd):
* lisp/eshell/em-basic.el (eshell/printnl):
Use new flatten-tree.
* lisp/progmodes/js.el (js--flatten-list):
* lisp/lpr.el (lpr-flatten-list):
* lisp/gnus/message.el (message-flatten-list):
* lisp/eshell/esh-util.el (eshell-flatten-list):
Obsolete in favor of Emacs-wide `flatten-tree'.
* lisp/subr.el (flatten-list): Alias to `flatten-tree' for
discoverability.
* lisp/subr.el (flatten-tree): New defun.
* test/lisp/subr-tests.el (subr-tests-flatten-tree): New test.
2018-12-17 11:15:09 +00:00
|
|
|
|
(should (equal (flatten-tree nil)
|
2018-12-17 18:19:48 +00:00
|
|
|
|
nil))
|
|
|
|
|
(should (equal (flatten-tree '((nil) ((((nil)))) nil))
|
|
|
|
|
nil))
|
New function flatten-tree
Co-authored-by: Basil L. Contovounesios <contovob@tcd.ie>
* doc/lispref/lists.texi: Document `flatten-tree'.
* lisp/progmodes/js.el (js--maybe-join):
* lisp/printing.el (pr-switches):
* lisp/lpr.el (lpr-print-region):
* lisp/gnus/nnimap.el (nnimap-find-wanted-parts):
* lisp/gnus/message.el (message-talkative-question):
* lisp/gnus/gnus-sum.el (gnus-remove-thread)
(gnus-thread-highest-number, gnus-thread-latest-date):
* lisp/eshell/esh-util.el (eshell-flatten-and-stringify):
* lisp/eshell/esh-opt.el (eshell-eval-using-options):
* lisp/eshell/esh-ext.el (eshell-external-command):
* lisp/eshell/em-xtra.el (eshell/expr):
* lisp/eshell/em-unix.el (eshell/rm, eshell-mvcpln-template)
(eshell/cat, eshell/make, eshell-poor-mans-grep, eshell-grep)
(eshell/du, eshell/time, eshell/diff, eshell/locate):
* lisp/eshell/em-tramp.el (eshell/su, eshell/sudo):
* lisp/eshell/em-term.el (eshell-exec-visual):
* lisp/eshell/em-dirs.el (eshell-dirs-substitute-cd, eshell/cd):
* lisp/eshell/em-basic.el (eshell/printnl):
Use new flatten-tree.
* lisp/progmodes/js.el (js--flatten-list):
* lisp/lpr.el (lpr-flatten-list):
* lisp/gnus/message.el (message-flatten-list):
* lisp/eshell/esh-util.el (eshell-flatten-list):
Obsolete in favor of Emacs-wide `flatten-tree'.
* lisp/subr.el (flatten-list): Alias to `flatten-tree' for
discoverability.
* lisp/subr.el (flatten-tree): New defun.
* test/lisp/subr-tests.el (subr-tests-flatten-tree): New test.
2018-12-17 11:15:09 +00:00
|
|
|
|
(should (equal (flatten-tree '(1 ("foo" "bar") 2))
|
|
|
|
|
'(1 "foo" "bar" 2))))
|
|
|
|
|
|
2021-01-08 23:44:13 +00:00
|
|
|
|
(ert-deftest subr--tests-letrec ()
|
|
|
|
|
;; Test that simple cases of `letrec' get optimized back to `let*'.
|
|
|
|
|
(should (equal (macroexpand '(letrec ((subr-tests-var1 1)
|
|
|
|
|
(subr-tests-var2 subr-tests-var1))
|
|
|
|
|
(+ subr-tests-var1 subr-tests-var2)))
|
|
|
|
|
'(let* ((subr-tests-var1 1)
|
|
|
|
|
(subr-tests-var2 subr-tests-var1))
|
|
|
|
|
(+ subr-tests-var1 subr-tests-var2)))))
|
|
|
|
|
|
2019-05-29 19:56:14 +00:00
|
|
|
|
(defvar subr-tests--hook nil)
|
|
|
|
|
|
|
|
|
|
(ert-deftest subr-tests-add-hook-depth ()
|
|
|
|
|
"Test the `depth' arg of `add-hook'."
|
|
|
|
|
(setq-default subr-tests--hook nil)
|
|
|
|
|
(add-hook 'subr-tests--hook 'f1)
|
|
|
|
|
(add-hook 'subr-tests--hook 'f2)
|
|
|
|
|
(should (equal subr-tests--hook '(f2 f1)))
|
|
|
|
|
(add-hook 'subr-tests--hook 'f3 t)
|
|
|
|
|
(should (equal subr-tests--hook '(f2 f1 f3)))
|
|
|
|
|
(add-hook 'subr-tests--hook 'f4 50)
|
|
|
|
|
(should (equal subr-tests--hook '(f2 f1 f4 f3)))
|
|
|
|
|
(add-hook 'subr-tests--hook 'f5 -50)
|
|
|
|
|
(should (equal subr-tests--hook '(f5 f2 f1 f4 f3)))
|
|
|
|
|
(add-hook 'subr-tests--hook 'f6)
|
|
|
|
|
(should (equal subr-tests--hook '(f5 f6 f2 f1 f4 f3)))
|
|
|
|
|
;; Make sure `t' is equivalent to 90.
|
|
|
|
|
(add-hook 'subr-tests--hook 'f7 90)
|
|
|
|
|
(add-hook 'subr-tests--hook 'f8 t)
|
|
|
|
|
(should (equal subr-tests--hook '(f5 f6 f2 f1 f4 f3 f7 f8)))
|
2021-07-05 18:34:36 +00:00
|
|
|
|
;; Make sure `nil' is equivalent to 0.
|
2019-05-29 19:56:14 +00:00
|
|
|
|
(add-hook 'subr-tests--hook 'f9 0)
|
|
|
|
|
(add-hook 'subr-tests--hook 'f10)
|
|
|
|
|
(should (equal subr-tests--hook '(f5 f10 f9 f6 f2 f1 f4 f3 f7 f8)))
|
|
|
|
|
)
|
|
|
|
|
|
2019-07-26 07:58:23 +00:00
|
|
|
|
(ert-deftest ignore-error-tests ()
|
|
|
|
|
(should (equal (ignore-error (end-of-file)
|
|
|
|
|
(read ""))
|
|
|
|
|
nil))
|
|
|
|
|
(should (equal (ignore-error end-of-file
|
|
|
|
|
(read ""))
|
|
|
|
|
nil))
|
|
|
|
|
(should-error (ignore-error foo
|
|
|
|
|
(read ""))))
|
|
|
|
|
|
2020-09-26 22:24:50 +00:00
|
|
|
|
(ert-deftest string-replace ()
|
|
|
|
|
(should (equal (string-replace "foo" "bar" "zot")
|
2020-09-15 14:50:44 +00:00
|
|
|
|
"zot"))
|
2020-09-26 22:24:50 +00:00
|
|
|
|
(should (equal (string-replace "foo" "bar" "foozot")
|
2020-09-15 14:50:44 +00:00
|
|
|
|
"barzot"))
|
2020-09-26 22:24:50 +00:00
|
|
|
|
(should (equal (string-replace "foo" "bar" "barfoozot")
|
2020-09-15 14:50:44 +00:00
|
|
|
|
"barbarzot"))
|
2020-09-26 22:24:50 +00:00
|
|
|
|
(should (equal (string-replace "zot" "bar" "barfoozot")
|
2020-09-15 14:50:44 +00:00
|
|
|
|
"barfoobar"))
|
2020-09-26 22:24:50 +00:00
|
|
|
|
(should (equal (string-replace "z" "bar" "barfoozot")
|
2020-09-15 15:36:36 +00:00
|
|
|
|
"barfoobarot"))
|
2020-09-26 22:24:50 +00:00
|
|
|
|
(should (equal (string-replace "zot" "bar" "zat")
|
2020-09-15 15:36:36 +00:00
|
|
|
|
"zat"))
|
2020-09-26 22:24:50 +00:00
|
|
|
|
(should (equal (string-replace "azot" "bar" "zat")
|
2020-09-15 15:36:36 +00:00
|
|
|
|
"zat"))
|
2020-09-26 22:24:50 +00:00
|
|
|
|
(should (equal (string-replace "azot" "bar" "azot")
|
2020-09-24 23:53:07 +00:00
|
|
|
|
"bar"))
|
|
|
|
|
|
2020-09-26 22:24:50 +00:00
|
|
|
|
(should (equal (string-replace "azot" "bar" "foozotbar")
|
2020-09-24 23:53:07 +00:00
|
|
|
|
"foozotbar"))
|
|
|
|
|
|
2020-09-26 22:35:11 +00:00
|
|
|
|
(should (equal (string-replace "fo" "bar" "lafofofozot")
|
|
|
|
|
"labarbarbarzot"))
|
|
|
|
|
|
2020-09-26 22:24:50 +00:00
|
|
|
|
(should (equal (string-replace "\377" "x" "a\377b")
|
2020-09-25 00:07:05 +00:00
|
|
|
|
"axb"))
|
2020-09-26 22:24:50 +00:00
|
|
|
|
(should (equal (string-replace "\377" "x" "a\377ø")
|
2020-09-25 11:15:42 +00:00
|
|
|
|
"axø"))
|
2020-09-27 11:32:27 +00:00
|
|
|
|
(should (equal (string-replace (string-to-multibyte "\377") "x" "a\377b")
|
|
|
|
|
"axb"))
|
|
|
|
|
(should (equal (string-replace (string-to-multibyte "\377") "x" "a\377ø")
|
|
|
|
|
"axø"))
|
|
|
|
|
|
|
|
|
|
(should (equal (string-replace "ana" "ANA" "ananas") "ANAnas"))
|
|
|
|
|
|
|
|
|
|
(should (equal (string-replace "a" "" "") ""))
|
|
|
|
|
(should (equal (string-replace "a" "" "aaaaa") ""))
|
|
|
|
|
(should (equal (string-replace "ab" "" "ababab") ""))
|
|
|
|
|
(should (equal (string-replace "ab" "" "abcabcabc") "ccc"))
|
|
|
|
|
(should (equal (string-replace "a" "aa" "aaa") "aaaaaa"))
|
|
|
|
|
(should (equal (string-replace "abc" "defg" "abc") "defg"))
|
2020-09-25 11:15:42 +00:00
|
|
|
|
|
2021-03-07 14:55:15 +00:00
|
|
|
|
(should (equal (should-error (string-replace "" "x" "abc"))
|
|
|
|
|
'(wrong-length-argument 0))))
|
2020-09-15 14:50:44 +00:00
|
|
|
|
|
2020-11-25 12:56:39 +00:00
|
|
|
|
(ert-deftest subr-replace-regexp-in-string ()
|
|
|
|
|
(should (equal (replace-regexp-in-string "a+" "xy" "abaabbabaaba")
|
|
|
|
|
"xybxybbxybxybxy"))
|
|
|
|
|
;; FIXEDCASE
|
|
|
|
|
(let ((case-fold-search t))
|
|
|
|
|
(should (equal (replace-regexp-in-string "a+" "xy" "ABAABBABAABA")
|
|
|
|
|
"XYBXYBBXYBXYBXY"))
|
|
|
|
|
(should (equal (replace-regexp-in-string "a+" "xy" "ABAABBABAABA" t)
|
|
|
|
|
"xyBxyBBxyBxyBxy"))
|
|
|
|
|
(should (equal (replace-regexp-in-string
|
|
|
|
|
"a[bc]*" "xyz"
|
|
|
|
|
"a A ab AB Ab aB abc ABC Abc AbC aBc")
|
|
|
|
|
"xyz XYZ xyz XYZ Xyz xyz xyz XYZ Xyz Xyz xyz"))
|
|
|
|
|
(should (equal (replace-regexp-in-string
|
|
|
|
|
"a[bc]*" "xyz"
|
|
|
|
|
"a A ab AB Ab aB abc ABC Abc AbC aBc" t)
|
|
|
|
|
"xyz xyz xyz xyz xyz xyz xyz xyz xyz xyz xyz")))
|
|
|
|
|
(let ((case-fold-search nil))
|
|
|
|
|
(should (equal (replace-regexp-in-string "a+" "xy" "ABAABBABAABA")
|
|
|
|
|
"ABAABBABAABA")))
|
|
|
|
|
;; group substitution
|
|
|
|
|
(should (equal (replace-regexp-in-string
|
|
|
|
|
"a\\(b*\\)" "<\\1,\\&>" "babbcaabacbab")
|
|
|
|
|
"b<bb,abb>c<,a><b,ab><,a>cb<b,ab>"))
|
|
|
|
|
(should (equal (replace-regexp-in-string
|
|
|
|
|
"x\\(?2:..\\)\\(?1:..\\)\\(..\\)\\(..\\)\\(..\\)"
|
|
|
|
|
"<\\3,\\5,\\4,\\1,\\2>" "yxabcdefghijkl")
|
|
|
|
|
"y<ef,ij,gh,cd,ab>kl"))
|
|
|
|
|
;; LITERAL
|
|
|
|
|
(should (equal (replace-regexp-in-string
|
|
|
|
|
"a\\(b*\\)" "<\\1,\\&>" "babbcaabacbab" nil t)
|
|
|
|
|
"b<\\1,\\&>c<\\1,\\&><\\1,\\&><\\1,\\&>cb<\\1,\\&>"))
|
|
|
|
|
(should (equal (replace-regexp-in-string
|
|
|
|
|
"a" "\\\\,\\?" "aba")
|
|
|
|
|
"\\,\\?b\\,\\?"))
|
|
|
|
|
(should (equal (replace-regexp-in-string
|
|
|
|
|
"a" "\\\\,\\?" "aba" nil t)
|
|
|
|
|
"\\\\,\\?b\\\\,\\?"))
|
|
|
|
|
;; SUBEXP
|
|
|
|
|
(should (equal (replace-regexp-in-string
|
|
|
|
|
"\\(a\\)\\(b*\\)c" "xy" "babbcdacd" nil nil 2)
|
|
|
|
|
"baxycdaxycd"))
|
|
|
|
|
;; START
|
|
|
|
|
(should (equal (replace-regexp-in-string
|
|
|
|
|
"ab" "x" "abcabdabeabf" nil nil nil 4)
|
|
|
|
|
"bdxexf"))
|
|
|
|
|
;; An empty pattern matches once before every character.
|
|
|
|
|
(should (equal (replace-regexp-in-string "" "x" "abc")
|
|
|
|
|
"xaxbxc"))
|
|
|
|
|
(should (equal (replace-regexp-in-string "y*" "x" "abc")
|
|
|
|
|
"xaxbxc"))
|
|
|
|
|
;; replacement function
|
|
|
|
|
(should (equal (replace-regexp-in-string
|
|
|
|
|
"a\\(b*\\)c"
|
|
|
|
|
(lambda (s)
|
|
|
|
|
(format "<%s,%s,%s,%s,%s>"
|
|
|
|
|
s
|
|
|
|
|
(match-beginning 0) (match-end 0)
|
|
|
|
|
(match-beginning 1) (match-end 1)))
|
|
|
|
|
"babbcaacabc")
|
|
|
|
|
"b<abbc,0,4,1,3>a<ac,0,2,1,1><abc,0,3,1,2>"))
|
2020-11-25 14:32:08 +00:00
|
|
|
|
;; anchors (bug#15107, bug#44861)
|
|
|
|
|
(should (equal (replace-regexp-in-string "a\\B" "b" "a aaaa")
|
|
|
|
|
"a bbba"))
|
|
|
|
|
(should (equal (replace-regexp-in-string "\\`\\|x" "z" "--xx--")
|
|
|
|
|
"z--zz--")))
|
2020-11-25 12:56:39 +00:00
|
|
|
|
|
2020-12-04 17:37:21 +00:00
|
|
|
|
(ert-deftest subr-match-substitute-replacement ()
|
|
|
|
|
(with-temp-buffer
|
|
|
|
|
(insert "Alpha Beta Gamma Delta Epsilon")
|
|
|
|
|
(goto-char (point-min))
|
|
|
|
|
(re-search-forward "B\\(..\\)a")
|
|
|
|
|
(should (equal (match-substitute-replacement "carrot")
|
|
|
|
|
"Carrot"))
|
|
|
|
|
(should (equal (match-substitute-replacement "<\\&>")
|
|
|
|
|
"<Beta>"))
|
|
|
|
|
(should (equal (match-substitute-replacement "m\\1a")
|
|
|
|
|
"Meta"))
|
|
|
|
|
(should (equal (match-substitute-replacement "ernin" nil nil nil 1)
|
|
|
|
|
"Bernina")))
|
|
|
|
|
(let ((s "Tau Beta Gamma Delta Epsilon"))
|
|
|
|
|
(string-match "B\\(..\\)a" s)
|
|
|
|
|
(should (equal (match-substitute-replacement "carrot" nil nil s)
|
|
|
|
|
"Carrot"))
|
|
|
|
|
(should (equal (match-substitute-replacement "<\\&>" nil nil s)
|
|
|
|
|
"<Beta>"))
|
|
|
|
|
(should (equal (match-substitute-replacement "m\\1a" nil nil s)
|
|
|
|
|
"Meta"))
|
|
|
|
|
(should (equal (match-substitute-replacement "ernin" nil nil s 1)
|
|
|
|
|
"Bernina"))))
|
|
|
|
|
|
2020-11-27 14:43:56 +00:00
|
|
|
|
(ert-deftest subr-tests--change-group-33341 ()
|
|
|
|
|
(with-temp-buffer
|
|
|
|
|
(buffer-enable-undo)
|
|
|
|
|
(insert "0\n")
|
|
|
|
|
(let ((g (prepare-change-group)))
|
|
|
|
|
(activate-change-group g)
|
|
|
|
|
(insert "b\n")
|
|
|
|
|
(insert "c\n")
|
|
|
|
|
(cancel-change-group g))
|
2020-11-27 15:19:21 +00:00
|
|
|
|
(should (equal (buffer-string) "0\n"))
|
|
|
|
|
(erase-buffer)
|
|
|
|
|
(setq buffer-undo-list nil)
|
|
|
|
|
(insert "0\n")
|
|
|
|
|
(let ((g (prepare-change-group)))
|
|
|
|
|
(activate-change-group g)
|
|
|
|
|
(insert "b\n")
|
|
|
|
|
(insert "c\n")
|
|
|
|
|
(accept-change-group g))
|
|
|
|
|
(should (equal (buffer-string) "0\nb\nc\n"))
|
|
|
|
|
(undo-boundary)
|
|
|
|
|
(undo)
|
|
|
|
|
(should (equal (buffer-string) ""))))
|
2020-12-31 04:00:45 +00:00
|
|
|
|
|
|
|
|
|
(defvar subr--ordered nil)
|
|
|
|
|
|
2020-12-31 04:28:47 +00:00
|
|
|
|
(ert-deftest subr--add-to-ordered-list-eq ()
|
2020-12-31 04:00:45 +00:00
|
|
|
|
(setq subr--ordered nil)
|
|
|
|
|
(add-to-ordered-list 'subr--ordered 'b 2)
|
|
|
|
|
(should (equal subr--ordered '(b)))
|
|
|
|
|
(add-to-ordered-list 'subr--ordered 'c 3)
|
|
|
|
|
(should (equal subr--ordered '(b c)))
|
|
|
|
|
(add-to-ordered-list 'subr--ordered 'a 1)
|
|
|
|
|
(should (equal subr--ordered '(a b c)))
|
|
|
|
|
(add-to-ordered-list 'subr--ordered 'e)
|
|
|
|
|
(should (equal subr--ordered '(a b c e)))
|
|
|
|
|
(add-to-ordered-list 'subr--ordered 'd 4)
|
2020-12-31 04:28:47 +00:00
|
|
|
|
(should (equal subr--ordered '(a b c d e)))
|
|
|
|
|
(add-to-ordered-list 'subr--ordered 'e)
|
|
|
|
|
(should (equal subr--ordered '(a b c d e)))
|
|
|
|
|
(add-to-ordered-list 'subr--ordered 'b 5)
|
|
|
|
|
(should (equal subr--ordered '(a c d b e))))
|
|
|
|
|
|
2020-12-19 18:54:46 +00:00
|
|
|
|
|
|
|
|
|
;;; Apropos.
|
|
|
|
|
|
|
|
|
|
(ert-deftest apropos-apropos-internal ()
|
|
|
|
|
(should (equal (apropos-internal "^next-line$") '(next-line)))
|
|
|
|
|
(should (>= (length (apropos-internal "^help")) 100))
|
|
|
|
|
(should-not (apropos-internal "^test-a-missing-symbol-foo-bar-zot$")))
|
|
|
|
|
|
|
|
|
|
(ert-deftest apropos-apropos-internal/predicate ()
|
|
|
|
|
(should (equal (apropos-internal "^next-line$" #'commandp) '(next-line)))
|
|
|
|
|
(should (>= (length (apropos-internal "^help" #'commandp)) 15))
|
|
|
|
|
(should-not (apropos-internal "^next-line$" #'keymapp)))
|
2020-11-27 14:43:56 +00:00
|
|
|
|
|
2021-05-31 05:21:09 +00:00
|
|
|
|
|
|
|
|
|
(ert-deftest test-buffer-local-boundp ()
|
|
|
|
|
(let ((buf (generate-new-buffer "boundp")))
|
|
|
|
|
(with-current-buffer buf
|
|
|
|
|
(setq-local test-boundp t))
|
|
|
|
|
(setq test-global-boundp t)
|
|
|
|
|
(should (buffer-local-boundp 'test-boundp buf))
|
|
|
|
|
(should-not (buffer-local-boundp 'test-not-boundp buf))
|
|
|
|
|
(should (buffer-local-boundp 'test-global-boundp buf))))
|
|
|
|
|
|
2021-08-16 11:20:35 +00:00
|
|
|
|
(ert-deftest test-replace-string-in-region ()
|
|
|
|
|
(with-temp-buffer
|
|
|
|
|
(insert "foo bar zot foobar")
|
|
|
|
|
(should (= (replace-string-in-region "foo" "new" (point-min) (point-max))
|
|
|
|
|
2))
|
|
|
|
|
(should (equal (buffer-string) "new bar zot newbar")))
|
|
|
|
|
|
|
|
|
|
(with-temp-buffer
|
|
|
|
|
(insert "foo bar zot foobar")
|
|
|
|
|
(should (= (replace-string-in-region "foo" "new" (point-min) 14)
|
|
|
|
|
1))
|
|
|
|
|
(should (equal (buffer-string) "new bar zot foobar")))
|
|
|
|
|
|
|
|
|
|
(with-temp-buffer
|
|
|
|
|
(insert "foo bar zot foobar")
|
|
|
|
|
(should-error (replace-string-in-region "foo" "new" (point-min) 30)))
|
|
|
|
|
|
|
|
|
|
(with-temp-buffer
|
|
|
|
|
(insert "Foo bar zot foobar")
|
|
|
|
|
(should (= (replace-string-in-region "Foo" "new" (point-min))
|
|
|
|
|
1))
|
|
|
|
|
(should (equal (buffer-string) "new bar zot foobar"))))
|
|
|
|
|
|
|
|
|
|
(ert-deftest test-replace-regexp-in-region ()
|
|
|
|
|
(with-temp-buffer
|
|
|
|
|
(insert "foo bar zot foobar")
|
|
|
|
|
(should (= (replace-regexp-in-region "fo+" "new" (point-min) (point-max))
|
|
|
|
|
2))
|
|
|
|
|
(should (equal (buffer-string) "new bar zot newbar")))
|
|
|
|
|
|
|
|
|
|
(with-temp-buffer
|
|
|
|
|
(insert "foo bar zot foobar")
|
|
|
|
|
(should (= (replace-regexp-in-region "fo+" "new" (point-min) 14)
|
|
|
|
|
1))
|
|
|
|
|
(should (equal (buffer-string) "new bar zot foobar")))
|
|
|
|
|
|
|
|
|
|
(with-temp-buffer
|
|
|
|
|
(insert "foo bar zot foobar")
|
|
|
|
|
(should-error (replace-regexp-in-region "fo+" "new" (point-min) 30)))
|
|
|
|
|
|
|
|
|
|
(with-temp-buffer
|
|
|
|
|
(insert "Foo bar zot foobar")
|
|
|
|
|
(should (= (replace-regexp-in-region "Fo+" "new" (point-min))
|
|
|
|
|
1))
|
|
|
|
|
(should (equal (buffer-string) "new bar zot foobar"))))
|
|
|
|
|
|
2021-09-01 10:13:19 +00:00
|
|
|
|
(ert-deftest test-with-existing-directory ()
|
|
|
|
|
(let ((dir (make-temp-name "/tmp/not-exist-")))
|
|
|
|
|
(let ((default-directory dir))
|
|
|
|
|
(should-not (file-exists-p default-directory)))
|
|
|
|
|
(with-existing-directory
|
|
|
|
|
(should-not (equal dir default-directory))
|
|
|
|
|
(should (file-exists-p default-directory)))))
|
|
|
|
|
|
2015-05-20 13:38:55 +00:00
|
|
|
|
(provide 'subr-tests)
|
|
|
|
|
;;; subr-tests.el ends here
|