tests_base.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574
  1. define([
  2. "qunit",
  3. "inputmask.dependencyLib",
  4. "inputmask"
  5. ], function(qunit, $, Inputmask) {
  6. module("Simple masking");
  7. test("inputmask(\"99-99-99\", { clearMaskOnLostFocus: false}", function() {
  8. var $fixture = $("#qunit-fixture");
  9. $fixture.append('<input type="text" id="testmask" />');
  10. var testmask = document.getElementById("testmask");
  11. Inputmask({
  12. mask: "99-99-99",
  13. clearMaskOnLostFocus: false
  14. }).mask(testmask);
  15. equal(testmask.inputmask._valueGet(), "__-__-__", "Result " + testmask.inputmask._valueGet());
  16. $("#testmask").remove();
  17. });
  18. asyncTest("inputmask(\"99-99-99\", { clearMaskOnLostFocus: true}", function() {
  19. var $fixture = $("#qunit-fixture");
  20. $fixture.append('<input type="text" id="testmask" />');
  21. var testmask = document.getElementById("testmask");
  22. Inputmask({
  23. mask: "99-99-99",
  24. clearMaskOnLostFocus: false
  25. }).mask(testmask);
  26. testmask.blur();
  27. setTimeout(function() {
  28. start();
  29. equal(testmask.value, "", "Result " + testmask.value);
  30. $("#testmask").remove();
  31. }, 0);
  32. });
  33. test("inputmask(\"999.999.999\")", function() {
  34. var $fixture = $("#qunit-fixture");
  35. $fixture.append('<input type="text" id="testmask" />');
  36. var testmask = document.getElementById("testmask");
  37. Inputmask("999.999.999").mask(testmask);
  38. testmask.focus();
  39. $("#testmask").Type("123");
  40. equal(testmask.value, "123.___.___", "Result " + testmask.value);
  41. $("#testmask").remove();
  42. });
  43. test("inputmask(\"999.999.999\") + backspace", function() {
  44. var $fixture = $("#qunit-fixture");
  45. $fixture.append('<input type="text" id="testmask" />');
  46. var testmask = document.getElementById("testmask");
  47. Inputmask("999.999.999").mask(testmask);
  48. testmask.focus();
  49. $("#testmask").Type("123");
  50. $("#testmask").SendKey(Inputmask.keyCode.BACKSPACE);
  51. equal(testmask.value, "12_.___.___", "Result " + testmask.value);
  52. $("#testmask").remove();
  53. });
  54. asyncTest("inputmask(\"999.999.999\", { oncomplete: ... })", 1, function() {
  55. var $fixture = $("#qunit-fixture");
  56. $fixture.append('<input type="text" id="testmask" />');
  57. var testmask = document.getElementById("testmask");
  58. Inputmask("999.999.999", {
  59. oncomplete: function() {
  60. equal(testmask.value, "123.456.789", "Result " + testmask.value);
  61. start();
  62. $("#testmask").remove();
  63. }
  64. }).mask(testmask);
  65. testmask.focus();
  66. $("#testmask").Type("123456789");
  67. });
  68. asyncTest("inputmask(\"9-AAA.999\") - change event", 1, function() {
  69. var $fixture = $("#qunit-fixture");
  70. $fixture.append('<input type="text" id="testmask" />');
  71. var testmask = document.getElementById("testmask");
  72. $("#testmask").on("change", function() {
  73. ok(true, "Change triggered");
  74. start();
  75. $("#testmask").remove();
  76. });
  77. Inputmask("9-AAA.999").mask(testmask);
  78. testmask.focus();
  79. setTimeout(function() {
  80. $("#testmask").Type("1abc12");
  81. testmask.blur();
  82. }, 0);
  83. });
  84. asyncTest("inputmask(\"9-AAA.999\", { onincomplete: ... })", 1, function() {
  85. var $fixture = $("#qunit-fixture");
  86. $fixture.append('<input type="text" id="testmask" />');
  87. var testmask = document.getElementById("testmask");
  88. Inputmask("9-AAA.999", {
  89. onincomplete: function() {
  90. equal(testmask.value, "1-ABC.12_", "Result " + testmask.value);
  91. start();
  92. $("#testmask").remove();
  93. }
  94. }).mask(testmask);
  95. testmask.focus();
  96. setTimeout(function() {
  97. $("#testmask").Type("1abc12");
  98. testmask.blur();
  99. }, 0);
  100. });
  101. test("inputmask(\"999.999.999\") - delete 2nd with backspace, continue the mask", function() {
  102. var $fixture = $("#qunit-fixture");
  103. $fixture.append('<input type="text" id="testmask" />');
  104. var testmask = document.getElementById("testmask");
  105. Inputmask("999.999.999").mask(testmask);
  106. testmask.focus();
  107. $("#testmask").Type("123");
  108. $("#testmask").SendKey(Inputmask.keyCode.LEFT);
  109. $("#testmask").SendKey(Inputmask.keyCode.LEFT);
  110. $("#testmask").SendKey(Inputmask.keyCode.BACKSPACE);
  111. $("#testmask").Type("4");
  112. $("#testmask").SendKey(Inputmask.keyCode.RIGHT);
  113. $("#testmask").Type("56");
  114. equal(testmask.value, "143.56_.___", "Result " + testmask.value);
  115. $("#testmask").remove();
  116. });
  117. test("inputmask(\"999.999.999\") - delete 2nd with delete, continue the mask", function() {
  118. var $fixture = $("#qunit-fixture");
  119. $fixture.append('<input type="text" id="testmask" />');
  120. var testmask = document.getElementById("testmask");
  121. Inputmask("999.999.999").mask(testmask);
  122. testmask.focus();
  123. $("#testmask").SendKey(49);
  124. $("#testmask").SendKey(50);
  125. $("#testmask").SendKey(51);
  126. $("#testmask").SendKey(Inputmask.keyCode.LEFT);
  127. $("#testmask").SendKey(Inputmask.keyCode.LEFT);
  128. $("#testmask").SendKey(Inputmask.keyCode.LEFT);
  129. $("#testmask").SendKey(Inputmask.keyCode.DELETE);
  130. $("#testmask").SendKey(52);
  131. $("#testmask").SendKey(Inputmask.keyCode.RIGHT);
  132. $("#testmask").SendKey(53);
  133. $("#testmask").SendKey(54);
  134. equal(testmask.value, "143.56_.___", "Result " + testmask.value);
  135. $("#testmask").remove();
  136. });
  137. test("inputmask(\"999.999.999\") - delete selection start with nomask", function() {
  138. var $fixture = $("#qunit-fixture");
  139. $fixture.append('<input type="text" id="testmask" />');
  140. var testmask = document.getElementById("testmask");
  141. Inputmask("999.999.999").mask(testmask);
  142. testmask.focus();
  143. $("#testmask").Type("123456789");
  144. $.caret(testmask, 3, 7);
  145. $("#testmask").SendKey(Inputmask.keyCode.DELETE);
  146. equal(testmask.value, "123.789.___", "Result " + testmask.value);
  147. $("#testmask").remove();
  148. });
  149. test("inputmask(\"999.999.999\") - backspace selection start with nomask", function() {
  150. var $fixture = $("#qunit-fixture");
  151. $fixture.append('<input type="text" id="testmask" />');
  152. var testmask = document.getElementById("testmask");
  153. Inputmask("999.999.999").mask(testmask);
  154. testmask.focus();
  155. $("#testmask").Type("123456789");
  156. $.caret(testmask, 3, 7);
  157. $("#testmask").SendKey(Inputmask.keyCode.DELETE);
  158. equal(testmask.value, "123.789.___", "Result " + testmask.value);
  159. $("#testmask").remove();
  160. });
  161. test("inputmask(\"999.999.999\") - overtype selection start with nomask", function() {
  162. var $fixture = $("#qunit-fixture");
  163. $fixture.append('<input type="text" id="testmask" />');
  164. var testmask = document.getElementById("testmask");
  165. Inputmask("999.999.999").mask(testmask);
  166. testmask.focus();
  167. $("#testmask").Type("123456789");
  168. $.caret(testmask, 3, 7);
  169. $("#testmask").Type("1");
  170. equal(testmask.value, "123.178.9__", "Result " + testmask.value);
  171. $("#testmask").remove();
  172. });
  173. test("inputmask(\"*****\")", function() {
  174. var $fixture = $("#qunit-fixture");
  175. $fixture.append('<input type="text" id="testmask" />');
  176. var testmask = document.getElementById("testmask");
  177. Inputmask("*****").mask(testmask);
  178. testmask.focus();
  179. $("#testmask").Type("abe");
  180. $("#testmask").SendKey(Inputmask.keyCode.LEFT);
  181. $("#testmask").Type("cd");
  182. equal(testmask.value, "abcde", "Result " + testmask.value);
  183. $("#testmask").remove();
  184. });
  185. test("inputmask(\"d/m/y\")", function() {
  186. var $fixture = $("#qunit-fixture");
  187. $fixture.append('<input type="text" id="testmask" />');
  188. var testmask = document.getElementById("testmask");
  189. Inputmask("d/m/y").mask(testmask);
  190. testmask.focus();
  191. $("#testmask").Type("23031973");
  192. $.caret(testmask, 5);
  193. $("#testmask").SendKey(Inputmask.keyCode.BACKSPACE);
  194. equal(testmask.value, "23/0_/1973", "Result " + testmask.value);
  195. $("#testmask").remove();
  196. });
  197. test("inputmask(\"(999)999-9999\") - ruslanfedoseenko mask", function() {
  198. var $fixture = $("#qunit-fixture");
  199. $fixture.append('<input type="text" id="testmask" />');
  200. var testmask = document.getElementById("testmask");
  201. Inputmask("(999)999-9999").mask(testmask);
  202. testmask.focus();
  203. testmask.value = "9999999999";
  204. $.caret(testmask, 4, 5);
  205. $("#testmask").Type("7");
  206. equal(testmask.value, "(999)999-9999", "Result " + testmask.value);
  207. $("#testmask").remove();
  208. });
  209. test("inputmask(\"(999)999-9999\") - insert false - ruslanfedoseenko mask", function() {
  210. var $fixture = $("#qunit-fixture");
  211. $fixture.append('<input type="text" id="testmask" />');
  212. var testmask = document.getElementById("testmask");
  213. Inputmask("(999)999-9999", {
  214. insertMode: false
  215. }).mask(testmask);
  216. testmask.focus();
  217. testmask.value = "9999999999";
  218. $.caret(testmask, 4, 5);
  219. $("#testmask").Type("7");
  220. equal(testmask.value, "(999)999-9999", "Result " + testmask.value);
  221. $("#testmask").remove();
  222. });
  223. test("inputmask(\"\") - empty mask - andywolk", function() {
  224. var $fixture = $("#qunit-fixture");
  225. $fixture.append('<input type="text" id="testmask" />');
  226. var testmask = document.getElementById("testmask");
  227. Inputmask("").mask(testmask);
  228. testmask.focus();
  229. $("#testmask").val("123");
  230. equal(testmask.value, "123", "Result " + testmask.value);
  231. $("#testmask").remove();
  232. });
  233. test("Intergroup selection - dhilt", function() {
  234. var $fixture = $("#qunit-fixture");
  235. $fixture.append('<input type="text" id="testmask" />');
  236. var testmask = document.getElementById("testmask");
  237. Inputmask("dd/mm/yyyy").mask(testmask);
  238. testmask.focus();
  239. $("#testmask").Type("23314");
  240. $.caret(testmask, 4, 7);
  241. $("#testmask").SendKey("6");
  242. equal(testmask.value, "23/06/y014", "Result " + testmask.value);
  243. $("#testmask").remove();
  244. });
  245. test("Delete selection with non-masks", function() {
  246. var $fixture = $("#qunit-fixture");
  247. $fixture.append('<input type="text" id="testmask" />');
  248. var testmask = document.getElementById("testmask");
  249. Inputmask("(999)999-9999").mask(testmask);
  250. testmask.focus();
  251. $("#testmask").Type("9999999999");
  252. $.caret(testmask, 8, 11);
  253. $("#testmask").SendKey(Inputmask.keyCode.DELETE);
  254. equal(testmask.value, "(999)999-99__", "Result " + testmask.value);
  255. $("#testmask").remove();
  256. });
  257. test("Selection and backspace also deletes previous - kenaku", function() {
  258. var $fixture = $("#qunit-fixture");
  259. $fixture.append('<input type="text" id="testmask" />');
  260. var testmask = document.getElementById("testmask");
  261. Inputmask("999 99 99 999").mask(testmask);
  262. testmask.focus();
  263. $("#testmask").Type("1234567890");
  264. $.caret(testmask, 2, 3);
  265. $("#testmask").SendKey(Inputmask.keyCode.BACKSPACE);
  266. equal(testmask.value, "124 56 78 90_", "Result " + testmask.value);
  267. $("#testmask").remove();
  268. });
  269. module("Non-greedy masks");
  270. test("inputmask(\"*\", { greedy: false, repeat: \"*\" }) - replace cd with 1", function() {
  271. var $fixture = $("#qunit-fixture");
  272. $fixture.append('<input type="text" id="testmask" />');
  273. var testmask = document.getElementById("testmask");
  274. Inputmask("*", {
  275. greedy: false,
  276. repeat: "*"
  277. }).mask(testmask);
  278. testmask.focus();
  279. $("#testmask").Type("abcdef");
  280. $.caret(testmask, 2, 4);
  281. $("#testmask").SendKey("1");
  282. equal(testmask.value, "ab1ef", "Result " + testmask.value);
  283. $("#testmask").remove();
  284. });
  285. test("inputmask(\"*\", { greedy: false, repeat: \"*\" }) - type abcdef", function() {
  286. var $fixture = $("#qunit-fixture");
  287. $fixture.append('<input type="text" id="testmask" />');
  288. var testmask = document.getElementById("testmask");
  289. Inputmask("*", {
  290. greedy: false,
  291. repeat: "*"
  292. }).mask(testmask);
  293. testmask.focus();
  294. $("#testmask").Type("abcdef");
  295. equal(testmask.value, "abcdef", "Result " + testmask.value);
  296. $("#testmask").remove();
  297. });
  298. test("inputmask(\"A.\", { repeat: \"*\" }) - type abc - joostburg", function() {
  299. var $fixture = $("#qunit-fixture");
  300. $fixture.append('<input type="text" id="testmask" />');
  301. var testmask = document.getElementById("testmask");
  302. Inputmask("A.", {
  303. repeat: "*"
  304. }).mask(testmask);
  305. testmask.focus();
  306. $("#testmask").Type("abc");
  307. equal(testmask.value, "A.B.C", "Result " + testmask.value);
  308. $("#testmask").remove();
  309. });
  310. test("{ mask: \"A\", placeholder: \"\", repeat: 16 }) - type testtest - glosswordteam", function() {
  311. var $fixture = $("#qunit-fixture");
  312. $fixture.append('<input type="text" id="testmask" />');
  313. var testmask = document.getElementById("testmask");
  314. Inputmask({
  315. mask: "A",
  316. placeholder: "",
  317. repeat: 16
  318. }).mask(testmask);
  319. testmask.focus();
  320. $("#testmask").Type("testtest");
  321. equal(testmask.value, "TESTTEST", "Result " + testmask.value);
  322. $("#testmask").remove();
  323. });
  324. test("{ mask: \"A\", repeat: 16, greedy: false }) - type testtest - glosswordteam", function() {
  325. var $fixture = $("#qunit-fixture");
  326. $fixture.append('<input type="text" id="testmask" />');
  327. var testmask = document.getElementById("testmask");
  328. Inputmask({
  329. mask: "A",
  330. repeat: 16,
  331. greedy: false
  332. }).mask(testmask);
  333. testmask.focus();
  334. $("#testmask").Type("testtest");
  335. equal(testmask.value, "TESTTEST", "Result " + testmask.value);
  336. $("#testmask").remove();
  337. });
  338. module("greedy masks");
  339. test("inputmask(\"*\", { greedy: true, repeat: 10, clearMaskOnLostFocus: false })", function() {
  340. var $fixture = $("#qunit-fixture");
  341. $fixture.append('<input type="text" id="testmask" />');
  342. var testmask = document.getElementById("testmask");
  343. Inputmask("*", {
  344. greedy: true,
  345. repeat: 10,
  346. clearMaskOnLostFocus: false
  347. }).mask(testmask);
  348. testmask.focus();
  349. equal($("#testmask")[0].inputmask._valueGet(), "__________", "Result " + $("#testmask")[0].inputmask._valueGet());
  350. $("#testmask").remove();
  351. });
  352. test("inputmask(\"*\", { greedy: true, repeat: 10 }) - type 12345678901234567890", function() {
  353. var $fixture = $("#qunit-fixture");
  354. $fixture.append('<input type="text" id="testmask" />');
  355. var testmask = document.getElementById("testmask");
  356. Inputmask("*", {
  357. greedy: true,
  358. repeat: 10
  359. }).mask(testmask);
  360. testmask.focus();
  361. $("#testmask").Type("12345678901234567890");
  362. equal(testmask.value, "1234567890", "Result " + testmask.value);
  363. $("#testmask").remove();
  364. });
  365. test("inputmask(\"9,99\", { greedy: true, repeat: 5 }) - type 12345678901234567890", function() {
  366. var $fixture = $("#qunit-fixture");
  367. $fixture.append('<input type="text" id="testmask" />');
  368. var testmask = document.getElementById("testmask");
  369. Inputmask("9,99", {
  370. greedy: true,
  371. repeat: 5
  372. }).mask(testmask);
  373. testmask.focus();
  374. $("#testmask").Type("12345678901234567890");
  375. equal(testmask.value, "1,234,567,890,123,45", "Result " + testmask.value);
  376. $("#testmask").remove();
  377. });
  378. test("inputmask({ mask: \"9\", repeat: 10, placeholder: \"\", numericInput: true }) - greedy true with empty placeholder - type 12345", function() {
  379. var $fixture = $("#qunit-fixture");
  380. $fixture.append('<input type="text" id="testmask" />');
  381. var testmask = document.getElementById("testmask");
  382. Inputmask({
  383. "mask": "9",
  384. repeat: 10,
  385. placeholder: "",
  386. numericInput: true
  387. }).mask(testmask);
  388. testmask.focus();
  389. $("#testmask").Type("12345");
  390. equal(testmask.value, "12345", "Result " + testmask.value);
  391. $("#testmask").remove();
  392. });
  393. asyncTest("creditcard switch - pchelailya", function() {
  394. var $fixture = $("#qunit-fixture");
  395. $fixture.append('<input type="text" id="testmask" />');
  396. var testmask = document.getElementById("testmask");
  397. Inputmask("9999 9999 9999 9999").mask(testmask);
  398. $("#testmask").on("keyup", function(event) {
  399. var value = this.inputmask.unmaskedvalue();
  400. if (value != null && value.length === 2 && value === "37") {
  401. Inputmask("9999 999999 99999").mask(this);
  402. }
  403. });
  404. testmask.focus();
  405. $("#testmask").Type("37");
  406. setTimeout(function() {
  407. $("#testmask").Type("12");
  408. start();
  409. equal(testmask.value, "3712 ______ _____", "Result " + testmask.value);
  410. $("#testmask").remove();
  411. }, 0);
  412. });
  413. test("maskscache - same mask diff definitions - StonesEditeurs", function() {
  414. var $fixture = $("#qunit-fixture");
  415. $fixture.append('<input type="text" id="testmask" />');
  416. var testmask = document.getElementById("testmask");
  417. Inputmask({
  418. mask: "Z{1,*}",
  419. definitions: {
  420. 'Z': {
  421. validator: function(chrs, buffer, pos, strict, opts) {
  422. return {
  423. pos: pos,
  424. c: 'A'
  425. };
  426. },
  427. }
  428. }
  429. }).mask(testmask);
  430. Inputmask({
  431. mask: "Z{1,*}", // <= Same mask
  432. definitions: {
  433. 'Z': {
  434. validator: function(chrs, buffer, pos, strict, opts) {
  435. return {
  436. pos: pos,
  437. c: 'B'
  438. }; // <= another definition
  439. },
  440. }
  441. }
  442. }).mask(testmask);
  443. $("#testmask").Type("abcdef");
  444. equal(document.getElementById("testmask").inputmask._valueGet(), "BBBBBB", "Result " + document.getElementById("testmask").inputmask._valueGet());
  445. $("#testmask").remove();
  446. });
  447. });