diff options
| author | Alex Dunn | 2015-12-05 11:32:01 +0200 |
|---|---|---|
| committer | Eli Zaretskii | 2015-12-05 11:32:01 +0200 |
| commit | d676e498255541a486c1d8a4cb30439bfb2ca385 (patch) | |
| tree | 7082cf1d7431466003e9ae0f4de0889b74815ecc /test | |
| parent | b3b68eb655595407f8b03e5500df081324e0cd40 (diff) | |
| download | emacs-d676e498255541a486c1d8a4cb30439bfb2ca385.tar.gz emacs-d676e498255541a486c1d8a4cb30439bfb2ca385.zip | |
Improve parsing of version strings
* lisp/subr.el (version-regexp-alist): Allow "." as priority separator
(version-to-list): More helpful error messages.
(version-to-list): ".5" is valid (update docstring). Make
"22.8X3" invalid, as the doc string says.
* test/automated/subr-tests.el (ert-test-version-parsing): New
tests for version string processing.
Copyright-paperwork-exempt: yes
Diffstat (limited to 'test')
| -rw-r--r-- | test/automated/subr-tests.el | 112 |
1 files changed, 112 insertions, 0 deletions
diff --git a/test/automated/subr-tests.el b/test/automated/subr-tests.el index ee8db593b49..3fcb7d346a3 100644 --- a/test/automated/subr-tests.el +++ b/test/automated/subr-tests.el | |||
| @@ -103,5 +103,117 @@ | |||
| 103 | (should (equal (macroexpand-all '(when a b c d)) | 103 | (should (equal (macroexpand-all '(when a b c d)) |
| 104 | '(if a (progn b c d))))) | 104 | '(if a (progn b c d))))) |
| 105 | 105 | ||
| 106 | (ert-deftest subr-test-version-parsing () | ||
| 107 | (should (equal (version-to-list ".5") '(0 5))) | ||
| 108 | (should (equal (version-to-list "0.9 alpha1") '(0 9 -3 1))) | ||
| 109 | (should (equal (version-to-list "0.9 snapshot") '(0 9 -4))) | ||
| 110 | (should (equal (version-to-list "0.9-alpha1") '(0 9 -3 1))) | ||
| 111 | (should (equal (version-to-list "0.9-snapshot") '(0 9 -4))) | ||
| 112 | (should (equal (version-to-list "0.9.snapshot") '(0 9 -4))) | ||
| 113 | (should (equal (version-to-list "0.9_snapshot") '(0 9 -4))) | ||
| 114 | (should (equal (version-to-list "0.9alpha1") '(0 9 -3 1))) | ||
| 115 | (should (equal (version-to-list "0.9snapshot") '(0 9 -4))) | ||
| 116 | (should (equal (version-to-list "1.0 git") '(1 0 -4))) | ||
| 117 | (should (equal (version-to-list "1.0 pre2") '(1 0 -1 2))) | ||
| 118 | (should (equal (version-to-list "1.0-git") '(1 0 -4))) | ||
| 119 | (should (equal (version-to-list "1.0-pre2") '(1 0 -1 2))) | ||
| 120 | (should (equal (version-to-list "1.0.1-a") '(1 0 1 1))) | ||
| 121 | (should (equal (version-to-list "1.0.1-f") '(1 0 1 6))) | ||
| 122 | (should (equal (version-to-list "1.0.1.a") '(1 0 1 1))) | ||
| 123 | (should (equal (version-to-list "1.0.1.f") '(1 0 1 6))) | ||
| 124 | (should (equal (version-to-list "1.0.1_a") '(1 0 1 1))) | ||
| 125 | (should (equal (version-to-list "1.0.1_f") '(1 0 1 6))) | ||
| 126 | (should (equal (version-to-list "1.0.1a") '(1 0 1 1))) | ||
| 127 | (should (equal (version-to-list "1.0.1f") '(1 0 1 6))) | ||
| 128 | (should (equal (version-to-list "1.0.7.5") '(1 0 7 5))) | ||
| 129 | (should (equal (version-to-list "1.0.git") '(1 0 -4))) | ||
| 130 | (should (equal (version-to-list "1.0.pre2") '(1 0 -1 2))) | ||
| 131 | (should (equal (version-to-list "1.0_git") '(1 0 -4))) | ||
| 132 | (should (equal (version-to-list "1.0_pre2") '(1 0 -1 2))) | ||
| 133 | (should (equal (version-to-list "1.0git") '(1 0 -4))) | ||
| 134 | (should (equal (version-to-list "1.0pre2") '(1 0 -1 2))) | ||
| 135 | (should (equal (version-to-list "22.8 beta3") '(22 8 -2 3))) | ||
| 136 | (should (equal (version-to-list "22.8-beta3") '(22 8 -2 3))) | ||
| 137 | (should (equal (version-to-list "22.8.beta3") '(22 8 -2 3))) | ||
| 138 | (should (equal (version-to-list "22.8_beta3") '(22 8 -2 3))) | ||
| 139 | (should (equal (version-to-list "22.8beta3") '(22 8 -2 3))) | ||
| 140 | (should (equal (version-to-list "6.9.30 Beta") '(6 9 30 -2))) | ||
| 141 | (should (equal (version-to-list "6.9.30-Beta") '(6 9 30 -2))) | ||
| 142 | (should (equal (version-to-list "6.9.30.Beta") '(6 9 30 -2))) | ||
| 143 | (should (equal (version-to-list "6.9.30Beta") '(6 9 30 -2))) | ||
| 144 | (should (equal (version-to-list "6.9.30_Beta") '(6 9 30 -2))) | ||
| 145 | |||
| 146 | (should (equal | ||
| 147 | (error-message-string (should-error (version-to-list "OTP-18.1.5"))) | ||
| 148 | "Invalid version syntax: `OTP-18.1.5' (must start with a number)")) | ||
| 149 | (should (equal | ||
| 150 | (error-message-string (should-error (version-to-list ""))) | ||
| 151 | "Invalid version syntax: `' (must start with a number)")) | ||
| 152 | (should (equal | ||
| 153 | (error-message-string (should-error (version-to-list "1.0..7.5"))) | ||
| 154 | "Invalid version syntax: `1.0..7.5'")) | ||
| 155 | (should (equal | ||
| 156 | (error-message-string (should-error (version-to-list "1.0prepre2"))) | ||
| 157 | "Invalid version syntax: `1.0prepre2'")) | ||
| 158 | (should (equal | ||
| 159 | (error-message-string (should-error (version-to-list "22.8X3"))) | ||
| 160 | "Invalid version syntax: `22.8X3'")) | ||
| 161 | (should (equal | ||
| 162 | (error-message-string (should-error (version-to-list "beta22.8alpha3"))) | ||
| 163 | "Invalid version syntax: `beta22.8alpha3' (must start with a number)")) | ||
| 164 | (should (equal | ||
| 165 | (error-message-string (should-error (version-to-list "honk"))) | ||
| 166 | "Invalid version syntax: `honk' (must start with a number)")) | ||
| 167 | (should (equal | ||
| 168 | (error-message-string (should-error (version-to-list 9))) | ||
| 169 | "Version must be a string")) | ||
| 170 | |||
| 171 | (let ((version-separator "_")) | ||
| 172 | (should (equal (version-to-list "_5") '(0 5))) | ||
| 173 | (should (equal (version-to-list "0_9 alpha1") '(0 9 -3 1))) | ||
| 174 | (should (equal (version-to-list "0_9 snapshot") '(0 9 -4))) | ||
| 175 | (should (equal (version-to-list "0_9-alpha1") '(0 9 -3 1))) | ||
| 176 | (should (equal (version-to-list "0_9-snapshot") '(0 9 -4))) | ||
| 177 | (should (equal (version-to-list "0_9.alpha1") '(0 9 -3 1))) | ||
| 178 | (should (equal (version-to-list "0_9.snapshot") '(0 9 -4))) | ||
| 179 | (should (equal (version-to-list "0_9alpha1") '(0 9 -3 1))) | ||
| 180 | (should (equal (version-to-list "0_9snapshot") '(0 9 -4))) | ||
| 181 | (should (equal (version-to-list "1_0 git") '(1 0 -4))) | ||
| 182 | (should (equal (version-to-list "1_0 pre2") '(1 0 -1 2))) | ||
| 183 | (should (equal (version-to-list "1_0-git") '(1 0 -4))) | ||
| 184 | (should (equal (version-to-list "1_0.pre2") '(1 0 -1 2))) | ||
| 185 | (should (equal (version-to-list "1_0_1-a") '(1 0 1 1))) | ||
| 186 | (should (equal (version-to-list "1_0_1-f") '(1 0 1 6))) | ||
| 187 | (should (equal (version-to-list "1_0_1.a") '(1 0 1 1))) | ||
| 188 | (should (equal (version-to-list "1_0_1.f") '(1 0 1 6))) | ||
| 189 | (should (equal (version-to-list "1_0_1_a") '(1 0 1 1))) | ||
| 190 | (should (equal (version-to-list "1_0_1_f") '(1 0 1 6))) | ||
| 191 | (should (equal (version-to-list "1_0_1a") '(1 0 1 1))) | ||
| 192 | (should (equal (version-to-list "1_0_1f") '(1 0 1 6))) | ||
| 193 | (should (equal (version-to-list "1_0_7_5") '(1 0 7 5))) | ||
| 194 | (should (equal (version-to-list "1_0_git") '(1 0 -4))) | ||
| 195 | (should (equal (version-to-list "1_0pre2") '(1 0 -1 2))) | ||
| 196 | (should (equal (version-to-list "22_8 beta3") '(22 8 -2 3))) | ||
| 197 | (should (equal (version-to-list "22_8-beta3") '(22 8 -2 3))) | ||
| 198 | (should (equal (version-to-list "22_8.beta3") '(22 8 -2 3))) | ||
| 199 | (should (equal (version-to-list "22_8beta3") '(22 8 -2 3))) | ||
| 200 | (should (equal (version-to-list "6_9_30 Beta") '(6 9 30 -2))) | ||
| 201 | (should (equal (version-to-list "6_9_30-Beta") '(6 9 30 -2))) | ||
| 202 | (should (equal (version-to-list "6_9_30.Beta") '(6 9 30 -2))) | ||
| 203 | (should (equal (version-to-list "6_9_30Beta") '(6 9 30 -2))) | ||
| 204 | |||
| 205 | (should (equal | ||
| 206 | (error-message-string (should-error (version-to-list "1_0__7_5"))) | ||
| 207 | "Invalid version syntax: `1_0__7_5'")) | ||
| 208 | (should (equal | ||
| 209 | (error-message-string (should-error (version-to-list "1_0prepre2"))) | ||
| 210 | "Invalid version syntax: `1_0prepre2'")) | ||
| 211 | (should (equal | ||
| 212 | (error-message-string (should-error (version-to-list "22.8X3"))) | ||
| 213 | "Invalid version syntax: `22.8X3'")) | ||
| 214 | (should (equal | ||
| 215 | (error-message-string (should-error (version-to-list "beta22_8alpha3"))) | ||
| 216 | "Invalid version syntax: `beta22_8alpha3' (must start with a number)")))) | ||
| 217 | |||
| 106 | (provide 'subr-tests) | 218 | (provide 'subr-tests) |
| 107 | ;;; subr-tests.el ends here | 219 | ;;; subr-tests.el ends here |