tests_regex.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480
  1. import { keys } from "../lib/keycode";
  2. export default function (qunit, Inputmask) {
  3. var $ = Inputmask.dependencyLib;
  4. qunit.module("Regex masks");
  5. qunit.test('inputmask({ regex: "[0-9]*"});', function (assert) {
  6. var $fixture = $("#qunit-fixture");
  7. $fixture.append('<input type="text" id="testmask" />');
  8. var testmask = document.getElementById("testmask");
  9. Inputmask({
  10. regex: "[0-9]*"
  11. }).mask(testmask);
  12. testmask.focus();
  13. $("#testmask").Type("123abc45");
  14. assert.equal(testmask.value, "12345", "Result " + testmask.value);
  15. });
  16. qunit.test('inputmask({ regex: "[0-9]*"}); ~ isComplete', function (assert) {
  17. var $fixture = $("#qunit-fixture"),
  18. done = assert.async();
  19. $fixture.append('<input type="text" id="testmask" />');
  20. var testmask = document.getElementById("testmask");
  21. Inputmask({
  22. regex: "[0-9]*",
  23. oncomplete: function () {
  24. assert.equal(testmask.value, "1", "Result " + testmask.value);
  25. done();
  26. }
  27. }).mask(testmask);
  28. testmask.focus();
  29. $("#testmask").SendKey("1");
  30. });
  31. qunit.test(
  32. 'inputmask({ regex: "[A-Za-z\u0410-\u044F\u0401\u04510-9]*"});',
  33. function (assert) {
  34. var $fixture = $("#qunit-fixture");
  35. $fixture.append('<input type="text" id="testmask" />');
  36. var testmask = document.getElementById("testmask");
  37. Inputmask({
  38. regex: "[A-Za-z\u0410-\u044F\u0401\u04510-9]*"
  39. }).mask(testmask);
  40. testmask.focus();
  41. $("#testmask").Type("123abc45");
  42. assert.equal(testmask.value, "123abc45", "Result " + testmask.value);
  43. }
  44. );
  45. qunit.test(
  46. 'inputmask({ regex: "[A-Za-z\u0410-\u044F\u0401\u0451]+[A-Za-z\u0410-\u044F\u0401\u04510-9]*"});',
  47. function (assert) {
  48. var $fixture = $("#qunit-fixture");
  49. $fixture.append('<input type="text" id="testmask" />');
  50. var testmask = document.getElementById("testmask");
  51. Inputmask({
  52. regex:
  53. "[A-Za-z\u0410-\u044F\u0401\u0451]+[A-Za-z\u0410-\u044F\u0401\u04510-9]*"
  54. }).mask(testmask);
  55. testmask.focus();
  56. $("#testmask").Type("123abc45");
  57. assert.equal(testmask.value, "abc45", "Result " + testmask.value);
  58. }
  59. );
  60. qunit.test(
  61. 'inputmask({ regex: "[A-Za-z\u0410-\u044F\u0401\u0451]{1}[A-Za-z\u0410-\u044F\u0401\u04510-9]*"});',
  62. function (assert) {
  63. var $fixture = $("#qunit-fixture");
  64. $fixture.append('<input type="text" id="testmask" />');
  65. var testmask = document.getElementById("testmask");
  66. Inputmask({
  67. regex:
  68. "[A-Za-z\u0410-\u044F\u0401\u0451]{1}[A-Za-z\u0410-\u044F\u0401\u04510-9]*"
  69. }).mask(testmask);
  70. testmask.focus();
  71. $("#testmask").Type("123abc45");
  72. assert.equal(testmask.value, "abc45", "Result " + testmask.value);
  73. }
  74. );
  75. qunit.test(
  76. 'inputmask({ regex: "[-]?(([1-8][0-9])|[1-9]0?)"});',
  77. function (assert) {
  78. var $fixture = $("#qunit-fixture");
  79. $fixture.append('<input type="text" id="testmask" />');
  80. var testmask = document.getElementById("testmask");
  81. Inputmask({
  82. regex: "[-]?(([1-8][0-9])|[1-9]0?)"
  83. }).mask(testmask);
  84. testmask.focus();
  85. $("#testmask").Type("90");
  86. assert.equal(testmask.value, "90", "Result " + testmask.value);
  87. }
  88. );
  89. qunit.test(
  90. 'inputmask({ regex: "[-]?(([1-8][0-9])|[1-9]0?)"});',
  91. function (assert) {
  92. var $fixture = $("#qunit-fixture");
  93. $fixture.append('<input type="text" id="testmask" />');
  94. var testmask = document.getElementById("testmask");
  95. Inputmask({
  96. regex: "[-]?(([1-8][0-9])|[1-9]0?)"
  97. }).mask(testmask);
  98. testmask.focus();
  99. $("#testmask").Type("0");
  100. assert.equal(testmask.value, "", "Result " + testmask.value);
  101. }
  102. );
  103. qunit.test(
  104. 'inputmask({ regex: "[-]?(([1-8][0-9])|[1-9]0?)"});',
  105. function (assert) {
  106. var $fixture = $("#qunit-fixture");
  107. $fixture.append('<input type="text" id="testmask" />');
  108. var testmask = document.getElementById("testmask");
  109. Inputmask({
  110. regex: "[-]?(([1-8][0-9])|[1-9]0?)"
  111. }).mask(testmask);
  112. testmask.focus();
  113. $("#testmask").Type("-78");
  114. assert.equal(testmask.value, "-78", "Result " + testmask.value);
  115. }
  116. );
  117. qunit.test(
  118. "inputmask({ regex: \"[a-za-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+(?:\\.[a-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-zA-Z0-9](?:[a-zA-Z0-9-]*[a-zA-Z0-9])?\\.)+[a-zA-Z0-9](?:[a-zA-Z0-9-]*)?\" - simple regex email",
  119. function (assert) {
  120. var $fixture = $("#qunit-fixture");
  121. $fixture.append('<input type="text" id="testmask" />');
  122. var testmask = document.getElementById("testmask");
  123. Inputmask({
  124. regex:
  125. "[a-za-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+(?:\\.[a-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-zA-Z0-9](?:[a-zA-Z0-9-]*)?\\.)+[a-zA-Z0-9](?:[a-zA-Z0-9-]*[a-zA-Z0-9])?"
  126. }).mask(testmask);
  127. testmask.focus();
  128. $("#testmask").Type("some.body@mail.com");
  129. assert.equal(
  130. testmask.value,
  131. "some.body@mail.com",
  132. "Result " + testmask.value
  133. );
  134. }
  135. );
  136. qunit.test(
  137. "inputmask({ regex: \"[a-za-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+(?:\\.[a-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-zA-Z0-9](?:[a-zA-Z0-9-]*)?\\.)+[a-zA-Z0-9](?:[a-zA-Z0-9-]*[a-zA-Z0-9])?\" - complexer regex email",
  138. function (assert) {
  139. var $fixture = $("#qunit-fixture");
  140. $fixture.append('<input type="text" id="testmask" />');
  141. var testmask = document.getElementById("testmask");
  142. Inputmask({
  143. regex:
  144. "[a-za-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+(?:\\.[a-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-zA-Z0-9](?:[a-zA-Z0-9-]*)?\\.)+[a-zA-Z0-9](?:[a-zA-Z0-9-]*[a-zA-Z0-9])?"
  145. }).mask(testmask);
  146. testmask.focus();
  147. $("#testmask").Type("denise.van.de.cruys@mail.com");
  148. assert.equal(
  149. testmask.value,
  150. "denise.van.de.cruys@mail.com",
  151. "Result " + testmask.value
  152. );
  153. }
  154. );
  155. qunit.test(
  156. 'inputmask({ regex: "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))" - mrpanacs regex 1-123-4562',
  157. function (assert) {
  158. var $fixture = $("#qunit-fixture");
  159. $fixture.append('<input type="text" id="testmask" />');
  160. var testmask = document.getElementById("testmask");
  161. Inputmask({
  162. regex:
  163. "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))"
  164. }).mask(testmask);
  165. testmask.focus();
  166. $("#testmask").Type("1-123-4562");
  167. assert.equal(testmask.value, "1-123-4562", "Result " + testmask.value);
  168. }
  169. );
  170. qunit.test(
  171. 'inputmask({ regex: "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))" - mrpanacs regex 20-222-2222',
  172. function (assert) {
  173. var $fixture = $("#qunit-fixture");
  174. $fixture.append('<input type="text" id="testmask" />');
  175. var testmask = document.getElementById("testmask");
  176. Inputmask({
  177. regex:
  178. "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))"
  179. }).mask(testmask);
  180. testmask.focus();
  181. $("#testmask").Type("20-222-2222");
  182. assert.equal(testmask.value, "20-222-2222", "Result " + testmask.value);
  183. }
  184. );
  185. qunit.test(
  186. 'inputmask({ regex: "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))" - mrpanacs regex 22-222-234',
  187. function (assert) {
  188. var $fixture = $("#qunit-fixture");
  189. $fixture.append('<input type="text" id="testmask" />');
  190. var testmask = document.getElementById("testmask");
  191. Inputmask({
  192. regex:
  193. "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))"
  194. }).mask(testmask);
  195. testmask.focus();
  196. $("#testmask").Type("22-222-234");
  197. assert.equal(testmask.value, "22-222-234", "Result " + testmask.value);
  198. }
  199. );
  200. qunit.test(
  201. 'inputmask({ regex: "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))" - mrpanacs regex 70-12-34',
  202. function (assert) {
  203. var $fixture = $("#qunit-fixture");
  204. $fixture.append('<input type="text" id="testmask" />');
  205. var testmask = document.getElementById("testmask");
  206. Inputmask({
  207. regex:
  208. "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))"
  209. }).mask(testmask);
  210. testmask.focus();
  211. $("#testmask").Type("70-12-34");
  212. assert.equal(testmask.value, "70-123-4__", "Result " + testmask.value);
  213. }
  214. );
  215. qunit.test(
  216. 'inputmask({ regex: "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))" - mrpanacs regex 70-12-34567',
  217. function (assert) {
  218. var $fixture = $("#qunit-fixture");
  219. $fixture.append('<input type="text" id="testmask" />');
  220. var testmask = document.getElementById("testmask");
  221. Inputmask({
  222. regex:
  223. "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))"
  224. }).mask(testmask);
  225. testmask.focus();
  226. $("#testmask").Type("70-12-34567");
  227. assert.equal(testmask.value, "70-123-4567", "Result " + testmask.value);
  228. }
  229. );
  230. qunit.test(
  231. 'inputmask({ regex: "([0-9]|[1][0-9]|[2][0-3]?)(\\.(5|25|75))?" - arame regex 12',
  232. function (assert) {
  233. var $fixture = $("#qunit-fixture");
  234. $fixture.append('<input type="text" id="testmask" />');
  235. var testmask = document.getElementById("testmask");
  236. Inputmask({
  237. regex: "([0-9]|[1][0-9]|[2][0-3]?)(\\.(5|25|75))?"
  238. }).mask(testmask);
  239. testmask.focus();
  240. $("#testmask").Type("12");
  241. assert.equal(testmask.value, "12", "Result " + testmask.value);
  242. }
  243. );
  244. qunit.test(
  245. 'inputmask({ regex: "([0-9]|[1][0-9]|[2][0-3]?)(\\.(5|25|75))?" } - arame regex 12.5',
  246. function (assert) {
  247. var $fixture = $("#qunit-fixture");
  248. $fixture.append('<input type="text" id="testmask" />');
  249. var testmask = document.getElementById("testmask");
  250. Inputmask({
  251. regex: "([0-9]|[1][0-9]|[2][0-3]?)(\\.(5|25|75))?"
  252. }).mask(testmask);
  253. testmask.focus();
  254. $("#testmask").Type("12.5");
  255. assert.equal(testmask.value, "12.5", "Result " + testmask.value);
  256. }
  257. );
  258. qunit.test(
  259. 'inputmask({ regex: "([0-9]|[1][0-9]|[2][0-3]?)(\\.(5|25|75))?" } - arame regex 12.75',
  260. function (assert) {
  261. var $fixture = $("#qunit-fixture");
  262. $fixture.append('<input type="text" id="testmask" />');
  263. var testmask = document.getElementById("testmask");
  264. Inputmask({
  265. regex: "([0-9]|[1][0-9]|[2][0-3]?)(\\.(5|25|75))?"
  266. }).mask(testmask);
  267. testmask.focus();
  268. $("#testmask").Type("12.75");
  269. assert.equal(testmask.value, "12.75", "Result " + testmask.value);
  270. }
  271. );
  272. qunit.test(
  273. 'inputmask({ regex: "(abc)+(def)" }); - Flyarbonkers regex abcdef',
  274. function (assert) {
  275. var $fixture = $("#qunit-fixture");
  276. $fixture.append('<input type="text" id="testmask" />');
  277. var testmask = document.getElementById("testmask");
  278. Inputmask({
  279. regex: "(abc)+(def)",
  280. jitMasking: true
  281. }).mask(testmask);
  282. testmask.focus();
  283. $("#testmask").Type("abcdef");
  284. assert.equal(testmask.value, "abcdef", "Result " + testmask.value);
  285. }
  286. );
  287. qunit.test(
  288. 'inputmask({ regex: "(abc)+(def)" }); - Flyarbonkers regex 123a4b5c6d7e8f',
  289. function (assert) {
  290. var $fixture = $("#qunit-fixture");
  291. $fixture.append('<input type="text" id="testmask" />');
  292. var testmask = document.getElementById("testmask");
  293. Inputmask({
  294. regex: "(abc)+(def)",
  295. jitMasking: true
  296. }).mask(testmask);
  297. testmask.focus();
  298. $("#testmask").Type("123a4b5c6d7e8f");
  299. assert.equal(testmask.value, "abcdef", "Result " + testmask.value);
  300. }
  301. );
  302. qunit.test(
  303. 'inputmask({ regex: "(abc)+(def)" }); - Flyarbonkers regex abcabcdef',
  304. function (assert) {
  305. var $fixture = $("#qunit-fixture");
  306. $fixture.append('<input type="text" id="testmask" />');
  307. var testmask = document.getElementById("testmask");
  308. Inputmask({
  309. regex: "(abc)+(def)",
  310. jitMasking: true
  311. }).mask(testmask);
  312. testmask.focus();
  313. $("#testmask").Type("abcabcdef");
  314. assert.equal(testmask.value, "abcabcdef", "Result " + testmask.value);
  315. }
  316. );
  317. qunit.test(
  318. 'inputmask({ regex: "(abc){2,4}(def)" }); - Flyarbonkers regex abcafebcaefbfcabcdef',
  319. function (assert) {
  320. var $fixture = $("#qunit-fixture");
  321. $fixture.append('<input type="text" id="testmask" />');
  322. var testmask = document.getElementById("testmask");
  323. Inputmask({
  324. regex: "(abc){2,4}(def)",
  325. jitMasking: true
  326. }).mask(testmask);
  327. testmask.focus();
  328. $("#testmask").Type("abcafebcaefbfcabcdef");
  329. assert.equal(
  330. testmask.value,
  331. "abcabcabcabcdef",
  332. "Result " + testmask.value
  333. );
  334. }
  335. );
  336. qunit.test(
  337. 'inputmask({regex: "[а-яА-Я\\s]*"}) - type space - SilentImp',
  338. function (assert) {
  339. var $fixture = $("#qunit-fixture");
  340. $fixture.append('<input type="text" id="testmask" />');
  341. var testmask = document.getElementById("testmask");
  342. Inputmask({
  343. regex: "[а-яА-Я\\s]*"
  344. }).mask(testmask);
  345. testmask.focus();
  346. $("#testmask").SendKey(keys.Space);
  347. assert.equal(testmask.value, " ", "Result " + testmask.value);
  348. }
  349. );
  350. qunit.test(
  351. 'inputmask({regex: "\\+7 \\(\\d{3}\\) \\d{3} \\d{4}"}) - hxss',
  352. function (assert) {
  353. var done = assert.async(),
  354. $fixture = $("#qunit-fixture");
  355. $fixture.append('<input type="text" id="testmask" />');
  356. var testmask = document.getElementById("testmask");
  357. Inputmask({
  358. regex: "\\+7 \\(\\d{3}\\) \\d{3} \\d{4}"
  359. }).mask(testmask);
  360. testmask.focus();
  361. setTimeout(function () {
  362. assert.equal(
  363. testmask.inputmask.__valueGet.call(testmask),
  364. "+7 (___) ___ ____",
  365. "Result " + testmask.inputmask.__valueGet.call(testmask)
  366. );
  367. done();
  368. }, 0);
  369. }
  370. );
  371. qunit.test("[0-9]{2}|[0-9]{3} - type 123", function (assert) {
  372. var $fixture = $("#qunit-fixture");
  373. $fixture.append('<input type="text" id="testmask" />');
  374. var testmask = document.getElementById("testmask");
  375. Inputmask({
  376. regex: "[0-9]{2}|[0-9]{3}"
  377. }).mask(testmask);
  378. testmask.focus();
  379. $("#testmask").Type("123");
  380. assert.equal(
  381. testmask.inputmask.__valueGet.call(testmask),
  382. "123",
  383. "Result " + testmask.inputmask.__valueGet.call(testmask)
  384. );
  385. });
  386. qunit.test(
  387. "[+-]?[0-9]+\\.?([0-9]+)?(px|em|rem|ex|%|in|cm|mm|pt|pc) - type maimairel",
  388. function (assert) {
  389. var $fixture = $("#qunit-fixture");
  390. $fixture.append('<input type="text" id="testmask" />');
  391. var testmask = document.getElementById("testmask");
  392. Inputmask({
  393. regex: "[+-]?[0-9]+\\.?([0-9]+)?(px|em|rem|ex|%|in|cm|mm|pt|pc)"
  394. }).mask(testmask);
  395. testmask.focus();
  396. $("#testmask").Type("10px");
  397. assert.equal(
  398. testmask.inputmask.__valueGet.call(testmask),
  399. "10px",
  400. "Result " + testmask.inputmask.__valueGet.call(testmask)
  401. );
  402. }
  403. );
  404. }