tests_base.js 17 KB

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