tests_base.js 21 KB

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