subr-tests.el 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. ;;; subr-tests.el --- Tests for subr.el
  2. ;; Copyright (C) 2015-2016 Free Software Foundation, Inc.
  3. ;; Author: Oleh Krehel <ohwoeowho@gmail.com>,
  4. ;; Nicolas Petton <nicolas@petton.fr>
  5. ;; Keywords:
  6. ;; This file is part of GNU Emacs.
  7. ;; GNU Emacs is free software: you can redistribute it and/or modify
  8. ;; it under the terms of the GNU General Public License as published by
  9. ;; the Free Software Foundation, either version 3 of the License, or
  10. ;; (at your option) any later version.
  11. ;; GNU Emacs is distributed in the hope that it will be useful,
  12. ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. ;; GNU General Public License for more details.
  15. ;; You should have received a copy of the GNU General Public License
  16. ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
  17. ;;; Commentary:
  18. ;;
  19. ;;; Code:
  20. (require 'ert)
  21. (ert-deftest let-when-compile ()
  22. ;; good case
  23. (should (equal (macroexpand '(let-when-compile ((foo (+ 2 3)))
  24. (setq bar (eval-when-compile (+ foo foo)))
  25. (setq boo (eval-when-compile (* foo foo)))))
  26. '(progn
  27. (setq bar (quote 10))
  28. (setq boo (quote 25)))))
  29. ;; bad case: `eval-when-compile' omitted, byte compiler should catch this
  30. (should (equal (macroexpand
  31. '(let-when-compile ((foo (+ 2 3)))
  32. (setq bar (+ foo foo))
  33. (setq boo (eval-when-compile (* foo foo)))))
  34. '(progn
  35. (setq bar (+ foo foo))
  36. (setq boo (quote 25)))))
  37. ;; something practical
  38. (should (equal (macroexpand
  39. '(let-when-compile ((keywords '("true" "false")))
  40. (font-lock-add-keywords
  41. 'c++-mode
  42. `((,(eval-when-compile
  43. (format "\\<%s\\>" (regexp-opt keywords)))
  44. 0 font-lock-keyword-face)))))
  45. '(font-lock-add-keywords
  46. (quote c++-mode)
  47. (list
  48. (cons (quote
  49. "\\<\\(?:\\(?:fals\\|tru\\)e\\)\\>")
  50. (quote
  51. (0 font-lock-keyword-face))))))))
  52. (ert-deftest string-comparison-test ()
  53. (should (string-lessp "abc" "acb"))
  54. (should (string-lessp "aBc" "abc"))
  55. (should (string-lessp "abc" "abcd"))
  56. (should (string-lessp "abc" "abcd"))
  57. (should-not (string-lessp "abc" "abc"))
  58. (should-not (string-lessp "" ""))
  59. (should (string-greaterp "acb" "abc"))
  60. (should (string-greaterp "abc" "aBc"))
  61. (should (string-greaterp "abcd" "abc"))
  62. (should (string-greaterp "abcd" "abc"))
  63. (should-not (string-greaterp "abc" "abc"))
  64. (should-not (string-greaterp "" ""))
  65. ;; Symbols are also accepted
  66. (should (string-lessp 'abc 'acb))
  67. (should (string-lessp "abc" 'acb))
  68. (should (string-greaterp 'acb 'abc))
  69. (should (string-greaterp "acb" 'abc)))
  70. (ert-deftest subr-test-when ()
  71. (should (equal (when t 1) 1))
  72. (should (equal (when t 2) 2))
  73. (should (equal (when nil 1) nil))
  74. (should (equal (when nil 2) nil))
  75. (should (equal (when t 'x 1) 1))
  76. (should (equal (when t 'x 2) 2))
  77. (should (equal (when nil 'x 1) nil))
  78. (should (equal (when nil 'x 2) nil))
  79. (let ((x 1))
  80. (should-not (when nil
  81. (setq x (1+ x))
  82. x))
  83. (should (= x 1))
  84. (should (= 2 (when t
  85. (setq x (1+ x))
  86. x)))
  87. (should (= x 2)))
  88. (should (equal (macroexpand-all '(when a b c d))
  89. '(if a (progn b c d)))))
  90. (ert-deftest subr-test-version-parsing ()
  91. (should (equal (version-to-list ".5") '(0 5)))
  92. (should (equal (version-to-list "0.9 alpha1") '(0 9 -3 1)))
  93. (should (equal (version-to-list "0.9 snapshot") '(0 9 -4)))
  94. (should (equal (version-to-list "0.9-alpha1") '(0 9 -3 1)))
  95. (should (equal (version-to-list "0.9-snapshot") '(0 9 -4)))
  96. (should (equal (version-to-list "0.9.snapshot") '(0 9 -4)))
  97. (should (equal (version-to-list "0.9_snapshot") '(0 9 -4)))
  98. (should (equal (version-to-list "0.9alpha1") '(0 9 -3 1)))
  99. (should (equal (version-to-list "0.9snapshot") '(0 9 -4)))
  100. (should (equal (version-to-list "1.0 git") '(1 0 -4)))
  101. (should (equal (version-to-list "1.0 pre2") '(1 0 -1 2)))
  102. (should (equal (version-to-list "1.0-git") '(1 0 -4)))
  103. (should (equal (version-to-list "1.0-pre2") '(1 0 -1 2)))
  104. (should (equal (version-to-list "1.0.1-a") '(1 0 1 1)))
  105. (should (equal (version-to-list "1.0.1-f") '(1 0 1 6)))
  106. (should (equal (version-to-list "1.0.1.a") '(1 0 1 1)))
  107. (should (equal (version-to-list "1.0.1.f") '(1 0 1 6)))
  108. (should (equal (version-to-list "1.0.1_a") '(1 0 1 1)))
  109. (should (equal (version-to-list "1.0.1_f") '(1 0 1 6)))
  110. (should (equal (version-to-list "1.0.1a") '(1 0 1 1)))
  111. (should (equal (version-to-list "1.0.1f") '(1 0 1 6)))
  112. (should (equal (version-to-list "1.0.7.5") '(1 0 7 5)))
  113. (should (equal (version-to-list "1.0.git") '(1 0 -4)))
  114. (should (equal (version-to-list "1.0.pre2") '(1 0 -1 2)))
  115. (should (equal (version-to-list "1.0_git") '(1 0 -4)))
  116. (should (equal (version-to-list "1.0_pre2") '(1 0 -1 2)))
  117. (should (equal (version-to-list "1.0git") '(1 0 -4)))
  118. (should (equal (version-to-list "1.0pre2") '(1 0 -1 2)))
  119. (should (equal (version-to-list "22.8 beta3") '(22 8 -2 3)))
  120. (should (equal (version-to-list "22.8-beta3") '(22 8 -2 3)))
  121. (should (equal (version-to-list "22.8.beta3") '(22 8 -2 3)))
  122. (should (equal (version-to-list "22.8_beta3") '(22 8 -2 3)))
  123. (should (equal (version-to-list "22.8beta3") '(22 8 -2 3)))
  124. (should (equal (version-to-list "6.9.30 Beta") '(6 9 30 -2)))
  125. (should (equal (version-to-list "6.9.30-Beta") '(6 9 30 -2)))
  126. (should (equal (version-to-list "6.9.30.Beta") '(6 9 30 -2)))
  127. (should (equal (version-to-list "6.9.30Beta") '(6 9 30 -2)))
  128. (should (equal (version-to-list "6.9.30_Beta") '(6 9 30 -2)))
  129. (should (equal
  130. (error-message-string (should-error (version-to-list "OTP-18.1.5")))
  131. "Invalid version syntax: `OTP-18.1.5' (must start with a number)"))
  132. (should (equal
  133. (error-message-string (should-error (version-to-list "")))
  134. "Invalid version syntax: `' (must start with a number)"))
  135. (should (equal
  136. (error-message-string (should-error (version-to-list "1.0..7.5")))
  137. "Invalid version syntax: `1.0..7.5'"))
  138. (should (equal
  139. (error-message-string (should-error (version-to-list "1.0prepre2")))
  140. "Invalid version syntax: `1.0prepre2'"))
  141. (should (equal
  142. (error-message-string (should-error (version-to-list "22.8X3")))
  143. "Invalid version syntax: `22.8X3'"))
  144. (should (equal
  145. (error-message-string (should-error (version-to-list "beta22.8alpha3")))
  146. "Invalid version syntax: `beta22.8alpha3' (must start with a number)"))
  147. (should (equal
  148. (error-message-string (should-error (version-to-list "honk")))
  149. "Invalid version syntax: `honk' (must start with a number)"))
  150. (should (equal
  151. (error-message-string (should-error (version-to-list 9)))
  152. "Version must be a string"))
  153. (let ((version-separator "_"))
  154. (should (equal (version-to-list "_5") '(0 5)))
  155. (should (equal (version-to-list "0_9 alpha1") '(0 9 -3 1)))
  156. (should (equal (version-to-list "0_9 snapshot") '(0 9 -4)))
  157. (should (equal (version-to-list "0_9-alpha1") '(0 9 -3 1)))
  158. (should (equal (version-to-list "0_9-snapshot") '(0 9 -4)))
  159. (should (equal (version-to-list "0_9.alpha1") '(0 9 -3 1)))
  160. (should (equal (version-to-list "0_9.snapshot") '(0 9 -4)))
  161. (should (equal (version-to-list "0_9alpha1") '(0 9 -3 1)))
  162. (should (equal (version-to-list "0_9snapshot") '(0 9 -4)))
  163. (should (equal (version-to-list "1_0 git") '(1 0 -4)))
  164. (should (equal (version-to-list "1_0 pre2") '(1 0 -1 2)))
  165. (should (equal (version-to-list "1_0-git") '(1 0 -4)))
  166. (should (equal (version-to-list "1_0.pre2") '(1 0 -1 2)))
  167. (should (equal (version-to-list "1_0_1-a") '(1 0 1 1)))
  168. (should (equal (version-to-list "1_0_1-f") '(1 0 1 6)))
  169. (should (equal (version-to-list "1_0_1.a") '(1 0 1 1)))
  170. (should (equal (version-to-list "1_0_1.f") '(1 0 1 6)))
  171. (should (equal (version-to-list "1_0_1_a") '(1 0 1 1)))
  172. (should (equal (version-to-list "1_0_1_f") '(1 0 1 6)))
  173. (should (equal (version-to-list "1_0_1a") '(1 0 1 1)))
  174. (should (equal (version-to-list "1_0_1f") '(1 0 1 6)))
  175. (should (equal (version-to-list "1_0_7_5") '(1 0 7 5)))
  176. (should (equal (version-to-list "1_0_git") '(1 0 -4)))
  177. (should (equal (version-to-list "1_0pre2") '(1 0 -1 2)))
  178. (should (equal (version-to-list "22_8 beta3") '(22 8 -2 3)))
  179. (should (equal (version-to-list "22_8-beta3") '(22 8 -2 3)))
  180. (should (equal (version-to-list "22_8.beta3") '(22 8 -2 3)))
  181. (should (equal (version-to-list "22_8beta3") '(22 8 -2 3)))
  182. (should (equal (version-to-list "6_9_30 Beta") '(6 9 30 -2)))
  183. (should (equal (version-to-list "6_9_30-Beta") '(6 9 30 -2)))
  184. (should (equal (version-to-list "6_9_30.Beta") '(6 9 30 -2)))
  185. (should (equal (version-to-list "6_9_30Beta") '(6 9 30 -2)))
  186. (should (equal
  187. (error-message-string (should-error (version-to-list "1_0__7_5")))
  188. "Invalid version syntax: `1_0__7_5'"))
  189. (should (equal
  190. (error-message-string (should-error (version-to-list "1_0prepre2")))
  191. "Invalid version syntax: `1_0prepre2'"))
  192. (should (equal
  193. (error-message-string (should-error (version-to-list "22.8X3")))
  194. "Invalid version syntax: `22.8X3'"))
  195. (should (equal
  196. (error-message-string (should-error (version-to-list "beta22_8alpha3")))
  197. "Invalid version syntax: `beta22_8alpha3' (must start with a number)"))))
  198. (provide 'subr-tests)
  199. ;;; subr-tests.el ends here