tests_regex.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379
  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"), done = assert.async();
  18. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  19. var testmask = document.getElementById("testmask");
  20. Inputmask({
  21. regex: "[0-9]*",
  22. oncomplete: function () {
  23. assert.equal(testmask.value, "1", "Result " + testmask.value);
  24. done();
  25. }
  26. }).mask(testmask);
  27. testmask.focus();
  28. $("#testmask").SendKey("1");
  29. });
  30. qunit.test("inputmask({ regex: \"[A-Za-z\u0410-\u044F\u0401\u04510-9]*\"});", function (assert) {
  31. var $fixture = $("#qunit-fixture");
  32. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  33. var testmask = document.getElementById("testmask");
  34. Inputmask({
  35. regex: "[A-Za-z\u0410-\u044F\u0401\u04510-9]*"
  36. }).mask(testmask);
  37. testmask.focus();
  38. $("#testmask").Type("123abc45");
  39. assert.equal(testmask.value, "123abc45", "Result " + testmask.value);
  40. });
  41. qunit.test("inputmask({ regex: \"[A-Za-z\u0410-\u044F\u0401\u0451]+[A-Za-z\u0410-\u044F\u0401\u04510-9]*\"});", function (assert) {
  42. var $fixture = $("#qunit-fixture");
  43. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  44. var testmask = document.getElementById("testmask");
  45. Inputmask({
  46. regex: "[A-Za-z\u0410-\u044F\u0401\u0451]+[A-Za-z\u0410-\u044F\u0401\u04510-9]*"
  47. }).mask(testmask);
  48. testmask.focus();
  49. $("#testmask").Type("123abc45");
  50. assert.equal(testmask.value, "abc45", "Result " + testmask.value);
  51. });
  52. qunit.test("inputmask({ regex: \"[A-Za-z\u0410-\u044F\u0401\u0451]{1}[A-Za-z\u0410-\u044F\u0401\u04510-9]*\"});", function (assert) {
  53. var $fixture = $("#qunit-fixture");
  54. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  55. var testmask = document.getElementById("testmask");
  56. Inputmask({
  57. regex: "[A-Za-z\u0410-\u044F\u0401\u0451]{1}[A-Za-z\u0410-\u044F\u0401\u04510-9]*"
  58. }).mask(testmask);
  59. testmask.focus();
  60. $("#testmask").Type("123abc45");
  61. assert.equal(testmask.value, "abc45", "Result " + testmask.value);
  62. });
  63. qunit.test("inputmask({ regex: \"[-]?(([1-8][0-9])|[1-9]0?)\"});", function (assert) {
  64. var $fixture = $("#qunit-fixture");
  65. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  66. var testmask = document.getElementById("testmask");
  67. Inputmask({
  68. regex: "[-]?(([1-8][0-9])|[1-9]0?)"
  69. }).mask(testmask);
  70. testmask.focus();
  71. $("#testmask").Type("90");
  72. assert.equal(testmask.value, "90", "Result " + testmask.value);
  73. });
  74. qunit.test("inputmask({ regex: \"[-]?(([1-8][0-9])|[1-9]0?)\"});", function (assert) {
  75. var $fixture = $("#qunit-fixture");
  76. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  77. var testmask = document.getElementById("testmask");
  78. Inputmask({
  79. regex: "[-]?(([1-8][0-9])|[1-9]0?)"
  80. }).mask(testmask);
  81. testmask.focus();
  82. $("#testmask").Type("0");
  83. assert.equal(testmask.value, "", "Result " + testmask.value);
  84. });
  85. qunit.test("inputmask({ regex: \"[-]?(([1-8][0-9])|[1-9]0?)\"});", function (assert) {
  86. var $fixture = $("#qunit-fixture");
  87. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  88. var testmask = document.getElementById("testmask");
  89. Inputmask({
  90. regex: "[-]?(([1-8][0-9])|[1-9]0?)"
  91. }).mask(testmask);
  92. testmask.focus();
  93. $("#testmask").Type("-78");
  94. assert.equal(testmask.value, "-78", "Result " + testmask.value);
  95. });
  96. qunit.test("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", function (assert) {
  97. var $fixture = $("#qunit-fixture");
  98. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  99. var testmask = document.getElementById("testmask");
  100. Inputmask({
  101. 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])?"
  102. }).mask(testmask);
  103. testmask.focus();
  104. $("#testmask").Type("some.body@mail.com");
  105. assert.equal(testmask.value, "some.body@mail.com", "Result " + testmask.value);
  106. });
  107. qunit.test("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", function (assert) {
  108. var $fixture = $("#qunit-fixture");
  109. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  110. var testmask = document.getElementById("testmask");
  111. Inputmask({
  112. 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])?"
  113. }).mask(testmask);
  114. testmask.focus();
  115. $("#testmask").Type("denise.van.de.cruys@mail.com");
  116. assert.equal(testmask.value, "denise.van.de.cruys@mail.com", "Result " + testmask.value);
  117. });
  118. qunit.test("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", function (assert) {
  119. var $fixture = $("#qunit-fixture");
  120. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  121. var testmask = document.getElementById("testmask");
  122. Inputmask({
  123. regex: "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))"
  124. }).mask(testmask);
  125. testmask.focus();
  126. $("#testmask").Type("1-123-4562");
  127. assert.equal(testmask.value, "1-123-4562", "Result " + testmask.value);
  128. });
  129. qunit.test("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", function (assert) {
  130. var $fixture = $("#qunit-fixture");
  131. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  132. var testmask = document.getElementById("testmask");
  133. Inputmask({
  134. regex: "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))"
  135. }).mask(testmask);
  136. testmask.focus();
  137. $("#testmask").Type("20-222-2222");
  138. assert.equal(testmask.value, "20-222-2222", "Result " + testmask.value);
  139. });
  140. qunit.test("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", function (assert) {
  141. var $fixture = $("#qunit-fixture");
  142. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  143. var testmask = document.getElementById("testmask");
  144. Inputmask({
  145. regex: "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))"
  146. }).mask(testmask);
  147. testmask.focus();
  148. $("#testmask").Type("22-222-234");
  149. assert.equal(testmask.value, "22-222-234", "Result " + testmask.value);
  150. });
  151. qunit.test("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", function (assert) {
  152. var $fixture = $("#qunit-fixture");
  153. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  154. var testmask = document.getElementById("testmask");
  155. Inputmask({
  156. regex: "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))"
  157. }).mask(testmask);
  158. testmask.focus();
  159. $("#testmask").Type("70-12-34");
  160. assert.equal(testmask.value, "70-123-4__", "Result " + testmask.value);
  161. });
  162. qunit.test("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", function (assert) {
  163. var $fixture = $("#qunit-fixture");
  164. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  165. var testmask = document.getElementById("testmask");
  166. Inputmask({
  167. regex: "(([2-9][0-9])-([0-9]{3}-[0-9]{3}))|((1|30|20|70)-([0-9]{3}-[0-9]{4}))"
  168. }).mask(testmask);
  169. testmask.focus();
  170. $("#testmask").Type("70-12-34567");
  171. assert.equal(testmask.value, "70-123-4567", "Result " + testmask.value);
  172. });
  173. qunit.test("inputmask({ regex: \"([0-9]|[1][0-9]|[2][0-3]?)(\\.(5|25|75))?\" - arame regex 12", function (assert) {
  174. var $fixture = $("#qunit-fixture");
  175. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  176. var testmask = document.getElementById("testmask");
  177. Inputmask({
  178. regex: "([0-9]|[1][0-9]|[2][0-3]?)(\\.(5|25|75))?"
  179. }).mask(testmask);
  180. testmask.focus();
  181. $("#testmask").Type("12");
  182. assert.equal(testmask.value, "12", "Result " + testmask.value);
  183. });
  184. qunit.test("inputmask({ regex: \"([0-9]|[1][0-9]|[2][0-3]?)(\\.(5|25|75))?\" } - arame regex 12.5", function (assert) {
  185. var $fixture = $("#qunit-fixture");
  186. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  187. var testmask = document.getElementById("testmask");
  188. Inputmask({
  189. regex: "([0-9]|[1][0-9]|[2][0-3]?)(\\.(5|25|75))?"
  190. }).mask(testmask);
  191. testmask.focus();
  192. $("#testmask").Type("12.5");
  193. assert.equal(testmask.value, "12.5", "Result " + testmask.value);
  194. });
  195. qunit.test("inputmask({ regex: \"([0-9]|[1][0-9]|[2][0-3]?)(\\.(5|25|75))?\" } - arame regex 12.75", function (assert) {
  196. var $fixture = $("#qunit-fixture");
  197. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  198. var testmask = document.getElementById("testmask");
  199. Inputmask({
  200. regex: "([0-9]|[1][0-9]|[2][0-3]?)(\\.(5|25|75))?"
  201. }).mask(testmask);
  202. testmask.focus();
  203. $("#testmask").Type("12.75");
  204. assert.equal(testmask.value, "12.75", "Result " + testmask.value);
  205. });
  206. qunit.test("inputmask({ regex: \"(abc)+(def)\" }); - Flyarbonkers regex abcdef", function (assert) {
  207. var $fixture = $("#qunit-fixture");
  208. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  209. var testmask = document.getElementById("testmask");
  210. Inputmask({
  211. regex: "(abc)+(def)",
  212. jitMasking: true
  213. }).mask(testmask);
  214. testmask.focus();
  215. $("#testmask").Type("abcdef");
  216. assert.equal(testmask.value, "abcdef", "Result " + testmask.value);
  217. });
  218. qunit.test("inputmask({ regex: \"(abc)+(def)\" }); - Flyarbonkers regex 123a4b5c6d7e8f", function (assert) {
  219. var $fixture = $("#qunit-fixture");
  220. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  221. var testmask = document.getElementById("testmask");
  222. Inputmask({
  223. regex: "(abc)+(def)",
  224. jitMasking: true
  225. }).mask(testmask);
  226. testmask.focus();
  227. $("#testmask").Type("123a4b5c6d7e8f");
  228. assert.equal(testmask.value, "abcdef", "Result " + testmask.value);
  229. });
  230. qunit.test("inputmask({ regex: \"(abc)+(def)\" }); - Flyarbonkers regex abcabcdef", function (assert) {
  231. var $fixture = $("#qunit-fixture");
  232. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  233. var testmask = document.getElementById("testmask");
  234. Inputmask({
  235. regex: "(abc)+(def)",
  236. jitMasking: true
  237. }).mask(testmask);
  238. testmask.focus();
  239. $("#testmask").Type("abcabcdef");
  240. assert.equal(testmask.value, "abcabcdef", "Result " + testmask.value);
  241. });
  242. qunit.test("inputmask({ regex: \"(abc){2,4}(def)\" }); - Flyarbonkers regex abcafebcaefbfcabcdef", function (assert) {
  243. var $fixture = $("#qunit-fixture");
  244. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  245. var testmask = document.getElementById("testmask");
  246. Inputmask({
  247. regex: "(abc){2,4}(def)",
  248. jitMasking: true
  249. }).mask(testmask);
  250. testmask.focus();
  251. $("#testmask").Type("abcafebcaefbfcabcdef");
  252. assert.equal(testmask.value, "abcabcabcabcdef", "Result " + testmask.value);
  253. });
  254. qunit.test("inputmask({regex: \"[а-яА-Я\\s]*\"}) - type space - SilentImp", function (assert) {
  255. var $fixture = $("#qunit-fixture");
  256. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  257. var testmask = document.getElementById("testmask");
  258. Inputmask({
  259. regex: "[а-яА-Я\\s]*"
  260. }).mask(testmask);
  261. testmask.focus();
  262. $("#testmask").SendKey(keys.Space);
  263. assert.equal(testmask.value, " ", "Result " + testmask.value);
  264. });
  265. qunit.test("inputmask({regex: \"\\+7 \\(\\d{3}\\) \\d{3} \\d{4}\"}) - hxss", function (assert) {
  266. var done = assert.async(),
  267. $fixture = $("#qunit-fixture");
  268. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  269. var testmask = document.getElementById("testmask");
  270. Inputmask({
  271. regex: "\\+7 \\(\\d{3}\\) \\d{3} \\d{4}"
  272. }).mask(testmask);
  273. testmask.focus();
  274. setTimeout(function () {
  275. assert.equal(testmask.inputmask.__valueGet.call(testmask), "+7 (___) ___ ____", "Result " + testmask.inputmask.__valueGet.call(testmask));
  276. done();
  277. }, 0);
  278. });
  279. qunit.test("[0-9]{2}|[0-9]{3} - type 123", function (assert) {
  280. var $fixture = $("#qunit-fixture");
  281. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  282. var testmask = document.getElementById("testmask");
  283. Inputmask({
  284. regex: "[0-9]{2}|[0-9]{3}"
  285. }).mask(testmask);
  286. testmask.focus();
  287. $("#testmask").Type("123");
  288. assert.equal(testmask.inputmask.__valueGet.call(testmask), "123", "Result " + testmask.inputmask.__valueGet.call(testmask));
  289. });
  290. qunit.test("[+-]?[0-9]+\\.?([0-9]+)?(px|em|rem|ex|%|in|cm|mm|pt|pc) - type maimairel", function (assert) {
  291. var $fixture = $("#qunit-fixture");
  292. $fixture.append("<input type=\"text\" id=\"testmask\" />");
  293. var testmask = document.getElementById("testmask");
  294. Inputmask({
  295. regex: "[+-]?[0-9]+\\.?([0-9]+)?(px|em|rem|ex|%|in|cm|mm|pt|pc)"
  296. }).mask(testmask);
  297. testmask.focus();
  298. $("#testmask").Type("10px");
  299. assert.equal(testmask.inputmask.__valueGet.call(testmask), "10px", "Result " + testmask.inputmask.__valueGet.call(testmask));
  300. });
  301. };