tests_base.js 18 KB

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