spec.js 61 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807
  1. describe('api', function() {
  2. // Override the options
  3. $.extend($.fn.bootstrapValidator.DEFAULT_OPTIONS, {
  4. feedbackIcons: {
  5. valid: 'glyphicon glyphicon-ok',
  6. invalid: 'glyphicon glyphicon-remove',
  7. validating: 'glyphicon glyphicon-refresh'
  8. }
  9. });
  10. beforeEach(function() {
  11. $([
  12. '<div class="container">',
  13. '<form class="form-horizontal" id="apiForm">',
  14. '<div class="form-group">',
  15. '<input type="text" name="username" data-bv-notempty />',
  16. '</div>',
  17. '<div class="form-group">',
  18. '<input type="text" name="email" data-bv-emailaddress />',
  19. '</div>',
  20. '</form>',
  21. '</div>'
  22. ].join('\n')).appendTo('body');
  23. $('#apiForm').bootstrapValidator();
  24. this.bv = $('#apiForm').data('bootstrapValidator');
  25. this.$email = this.bv.getFieldElements('email');
  26. });
  27. afterEach(function() {
  28. $('#apiForm').bootstrapValidator('destroy').parent().remove();
  29. });
  30. it('call revalidateField()', function() {
  31. this.$email.val('email@domain.com');
  32. this.bv.validate();
  33. expect(this.bv.isValidField('email')).toBeTruthy();
  34. this.$email.val('invalid#email.address');
  35. this.bv.revalidateField('email');
  36. expect(this.bv.isValidField(this.$email)).toEqual(false);
  37. });
  38. it('call destroy()', function() {
  39. this.bv.destroy();
  40. expect($('#apiForm').data('bootstrapValidator')).toBeUndefined();
  41. expect($('#apiForm').find('i[data-bv-icon-for]').length).toEqual(0);
  42. expect($('#apiForm').find('.help-block[data-bv-for]').length).toEqual(0);
  43. expect($('#apiForm').find('.has-feedback').length).toEqual(0);
  44. expect($('#apiForm').find('.has-success').length).toEqual(0);
  45. expect($('#apiForm').find('.has-error').length).toEqual(0);
  46. expect($('#apiForm').find('[data-bv-field]').length).toEqual(0);
  47. });
  48. });
  49. function onEmailValid(e, data) {
  50. $('#msg').html(data.field + ' is valid');
  51. };
  52. function onEmailInvalid(e, data) {
  53. $('#msg').html(data.field + ' is invalid');
  54. };
  55. describe('event field attribute callback global', function() {
  56. beforeEach(function() {
  57. var html = [
  58. '<div class="container">',
  59. '<form class="form-horizontal" id="eventForm">',
  60. '<div id="msg"></div>',
  61. '<div class="form-group">',
  62. '<input type="text" name="email" data-bv-emailaddress data-bv-onsuccess="onEmailValid" data-bv-onerror="onEmailInvalid" />',
  63. '</div>',
  64. '</form>',
  65. '</div>'
  66. ].join('\n');
  67. $(html).appendTo('body');
  68. $('#eventForm').bootstrapValidator();
  69. this.bv = $('#eventForm').data('bootstrapValidator');
  70. this.$email = this.bv.getFieldElements('email');
  71. });
  72. afterEach(function() {
  73. $('#eventForm').bootstrapValidator('destroy').parent().remove();
  74. });
  75. it('call data-bv-onsuccess', function() {
  76. this.$email.val('email@domain.com');
  77. this.bv.validate();
  78. expect($('#msg').html()).toEqual('email is valid');
  79. });
  80. it('call data-bv-onerror', function() {
  81. this.$email.val('email@domain');
  82. this.bv.validate();
  83. expect($('#msg').html()).toEqual('email is invalid');
  84. });
  85. });
  86. var My = {
  87. NameSpace: {
  88. onEmailValid: function(e, data) {
  89. $('#msg').html('My.NameSpace.onEmailValid() called, ' + data.field + ' is valid');
  90. },
  91. onEmailInvalid: function(e, data) {
  92. $('#msg').html('My.NameSpace.onEmailInvalid() called, ' + data.field + ' is invalid');
  93. }
  94. }
  95. };
  96. describe('event field attribute callback namespace', function() {
  97. beforeEach(function() {
  98. var html = [
  99. '<div class="container">',
  100. '<form class="form-horizontal" id="eventForm">',
  101. '<div id="msg"></div>',
  102. '<div class="form-group">',
  103. '<input type="text" name="email" data-bv-emailaddress data-bv-onsuccess="My.NameSpace.onEmailValid" data-bv-onerror="My.NameSpace.onEmailInvalid" />',
  104. '</div>',
  105. '</form>',
  106. '</div>'
  107. ].join('\n');
  108. $(html).appendTo('body');
  109. $('#eventForm').bootstrapValidator();
  110. this.bv = $('#eventForm').data('bootstrapValidator');
  111. this.$email = this.bv.getFieldElements('email');
  112. });
  113. afterEach(function() {
  114. $('#eventForm').bootstrapValidator('destroy').parent().remove();
  115. });
  116. it('call data-bv-onsuccess', function() {
  117. this.$email.val('email@domain.com');
  118. this.bv.validate();
  119. expect($('#msg').html()).toEqual('My.NameSpace.onEmailValid() called, email is valid');
  120. });
  121. it('call data-bv-onerror', function() {
  122. this.$email.val('email@domain');
  123. this.bv.validate();
  124. expect($('#msg').html()).toEqual('My.NameSpace.onEmailInvalid() called, email is invalid');
  125. });
  126. });
  127. describe('event field trigger', function() {
  128. beforeEach(function() {
  129. var html = [
  130. '<div class="container">',
  131. '<form class="form-horizontal" id="eventForm">',
  132. '<div id="msg"></div>',
  133. '<div class="form-group">',
  134. '<input type="text" name="email" data-bv-emailaddress />',
  135. '</div>',
  136. '</form>',
  137. '</div>'
  138. ].join('\n');
  139. $(html).appendTo('body');
  140. $('#eventForm')
  141. .bootstrapValidator()
  142. .on('success.field.bv', '[name="email"]', function(e, data) {
  143. $('#msg').html('triggered success.field.bv on ' + data.field);
  144. })
  145. .on('error.field.bv', '[name="email"]', function(e, data) {
  146. $('#msg').html('triggered error.field.bv on ' + data.field);
  147. });
  148. this.bv = $('#eventForm').data('bootstrapValidator');
  149. this.$email = this.bv.getFieldElements('email');
  150. });
  151. afterEach(function() {
  152. $('#eventForm').bootstrapValidator('destroy').parent().remove();
  153. });
  154. it('trigger success.field.bv', function() {
  155. this.$email.val('email@domain.com');
  156. this.bv.validate();
  157. expect($('#msg').html()).toEqual('triggered success.field.bv on email');
  158. });
  159. it('trigger error.field.bv', function() {
  160. this.$email.val('email@domain');
  161. this.bv.validate();
  162. expect($('#msg').html()).toEqual('triggered error.field.bv on email');
  163. });
  164. });
  165. describe('event field programmatically', function() {
  166. beforeEach(function() {
  167. var html = [
  168. '<div class="container">',
  169. '<form class="form-horizontal" id="eventForm">',
  170. '<div id="msg"></div>',
  171. '<div class="form-group">',
  172. '<input type="text" name="email" data-bv-emailaddress />',
  173. '</div>',
  174. '</form>',
  175. '</div>'
  176. ].join('\n');
  177. $(html).appendTo('body');
  178. $('#eventForm').bootstrapValidator({
  179. fields: {
  180. email: {
  181. onSuccess: function(e, data) {
  182. $('#msg').html('onSuccess() called');
  183. },
  184. onError: function(e, data) {
  185. $('#msg').html('onError() called');
  186. },
  187. validator: {
  188. emailAddress: {}
  189. }
  190. }
  191. }
  192. });
  193. this.bv = $('#eventForm').data('bootstrapValidator');
  194. this.$email = this.bv.getFieldElements('email');
  195. });
  196. afterEach(function() {
  197. $('#eventForm').bootstrapValidator('destroy').parent().remove();
  198. });
  199. it('call onSuccess()', function() {
  200. this.$email.val('email@domain.com');
  201. this.bv.validate();
  202. expect($('#msg').html()).toEqual('onSuccess() called');
  203. });
  204. it('call onError()', function() {
  205. this.$email.val('email@domain');
  206. this.bv.validate();
  207. expect($('#msg').html()).toEqual('onError() called');
  208. });
  209. });
  210. describe('excluded', function() {
  211. beforeEach(function() {
  212. $([
  213. '<div class="container">',
  214. '<form class="form-horizontal" id="excludedForm" data-bv-excluded="[name=\'email\']">',
  215. '<div class="form-group">',
  216. '<input type="text" name="username" required />',
  217. '</div>',
  218. '<div class="form-group">',
  219. '<input type="text" name="email" required data-bv-emailaddress />',
  220. '</div>',
  221. '</form>',
  222. '</div>'
  223. ].join('')).appendTo('body');
  224. $('#excludedForm').bootstrapValidator();
  225. this.bv = $('#excludedForm').data('bootstrapValidator');
  226. this.$username = this.bv.getFieldElements('username');
  227. this.$email = this.bv.getFieldElements('email');
  228. });
  229. afterEach(function() {
  230. $('#excludedForm').bootstrapValidator('destroy').parent().remove();
  231. });
  232. it('excluded form declarative', function() {
  233. this.bv.validate();
  234. expect(this.bv.isValid()).toEqual(false);
  235. this.bv.resetForm();
  236. this.$username.val('your_user_name');
  237. this.$email.val('');
  238. this.bv.validate();
  239. expect(this.bv.isValid()).toBeTruthy();
  240. });
  241. it('excluded form programmatically', function() {
  242. this.bv.destroy();
  243. $('#excludedForm').removeAttr('data-bv-excluded');
  244. $('#excludedForm').bootstrapValidator({
  245. excluded: '[name="username"]'
  246. });
  247. this.bv = $('#excludedForm').data('bootstrapValidator');
  248. this.$username = this.bv.getFieldElements('username');
  249. this.$email = this.bv.getFieldElements('email');
  250. this.$username.val('');
  251. this.$email.val('invalid#email.com');
  252. this.bv.validate();
  253. expect(this.bv.isValid()).toEqual(false);
  254. this.bv.resetForm();
  255. this.$email.val('valid@email.com');
  256. this.bv.validate();
  257. expect(this.bv.isValid()).toBeTruthy();
  258. });
  259. it('excluded field declarative', function() {
  260. this.bv.destroy();
  261. $('#excludedForm').removeAttr('data-bv-excluded');
  262. $('#excludedForm').find('[name="username"]').attr('data-bv-excluded', 'true');
  263. $('#excludedForm').find('[name="email"]').attr('data-bv-excluded', 'false');
  264. this.bv = $('#excludedForm').bootstrapValidator().data('bootstrapValidator');
  265. this.$username = this.bv.getFieldElements('username');
  266. this.$email = this.bv.getFieldElements('email');
  267. this.$username.val('');
  268. this.$email.val('');
  269. this.bv.validate();
  270. expect(this.bv.isValid()).toEqual(false);
  271. this.bv.resetForm();
  272. this.$email.val('invalid#email.com');
  273. this.bv.validate();
  274. expect(this.bv.isValid()).toEqual(false);
  275. this.bv.resetForm();
  276. this.$email.val('valid@email.com');
  277. this.bv.validate();
  278. expect(this.bv.isValid()).toBeTruthy();
  279. });
  280. it('excluded field programmatically true/false', function() {
  281. this.bv.destroy();
  282. $('#excludedForm').removeAttr('data-bv-excluded');
  283. $('#excludedForm').bootstrapValidator({
  284. fields: {
  285. username: {
  286. excluded: true
  287. },
  288. email: {
  289. excluded: false
  290. }
  291. }
  292. });
  293. this.bv = $('#excludedForm').bootstrapValidator().data('bootstrapValidator');
  294. this.$username = this.bv.getFieldElements('username');
  295. this.$email = this.bv.getFieldElements('email');
  296. this.$username.val('');
  297. this.$email.val('');
  298. this.bv.validate();
  299. expect(this.bv.isValid()).toEqual(false);
  300. this.bv.resetForm();
  301. this.$email.val('invalid#email.com');
  302. this.bv.validate();
  303. expect(this.bv.isValid()).toEqual(false);
  304. this.bv.resetForm();
  305. this.$email.val('valid@email.com');
  306. this.bv.validate();
  307. expect(this.bv.isValid()).toBeTruthy();
  308. });
  309. it('excluded field programmatically "true"/"false"', function() {
  310. this.bv.destroy();
  311. $('#excludedForm').removeAttr('data-bv-excluded');
  312. $('#excludedForm').bootstrapValidator({
  313. fields: {
  314. username: {
  315. excluded: 'false'
  316. },
  317. email: {
  318. excluded: 'true'
  319. }
  320. }
  321. });
  322. this.bv = $('#excludedForm').bootstrapValidator().data('bootstrapValidator');
  323. this.$username = this.bv.getFieldElements('username');
  324. this.$email = this.bv.getFieldElements('email');
  325. this.$username.val('');
  326. this.$email.val('valid@email.com');
  327. this.bv.validate();
  328. expect(this.bv.isValid()).toEqual(false);
  329. this.bv.resetForm();
  330. this.$username.val('your_user_name');
  331. this.$email.val('invalid#email.com');
  332. this.bv.validate();
  333. expect(this.bv.isValid()).toBeTruthy();
  334. });
  335. });
  336. describe('i18n', function() {
  337. beforeEach(function() {
  338. $([
  339. '<form id="i18nForm" class="form-horizontal">',
  340. '<div class="form-group">',
  341. '<label class="col-lg-3 control-label">Full name</label>',
  342. '<div class="col-lg-5">',
  343. '<input type="text" class="form-control" name="fullName" />',
  344. '</div>',
  345. '</div>',
  346. '<div class="form-group">',
  347. '<label class="col-lg-3 control-label">Username</label>',
  348. '<div class="col-lg-5">',
  349. '<input type="text" class="form-control" name="username" />',
  350. '</div>',
  351. '</div>',
  352. '<div class="form-group">',
  353. '<label class="col-lg-3 control-label">Email address</label>',
  354. '<div class="col-lg-5">',
  355. '<input type="text" class="form-control" name="email" />',
  356. '</div>',
  357. '</div>',
  358. '<div class="form-group">',
  359. '<label class="col-lg-3 control-label">Password</label>',
  360. '<div class="col-lg-5">',
  361. '<input type="password" class="form-control" name="password" />',
  362. '</div>',
  363. '</div>',
  364. '<div class="form-group">',
  365. '<label class="col-lg-3 control-label">Retype password</label>',
  366. '<div class="col-lg-5">',
  367. '<input type="password" class="form-control" name="confirmPassword" />',
  368. '</div>',
  369. '</div>',
  370. '<div class="form-group">',
  371. '<label class="col-lg-3 control-label">Gender</label>',
  372. '<div class="col-lg-5">',
  373. '<div class="radio">',
  374. '<label><input type="radio" name="gender" value="male" /> Male</label>',
  375. '</div>',
  376. '<div class="radio">',
  377. '<label><input type="radio" name="gender" value="female" /> Female</label>',
  378. '</div>',
  379. '<div class="radio">',
  380. '<label><input type="radio" name="gender" value="other" /> Other</label>',
  381. '</div>',
  382. '</div>',
  383. '</div>',
  384. '<div class="form-group">',
  385. '<label class="col-lg-3 control-label">Age</label>',
  386. '<div class="col-lg-3">',
  387. '<input type="text" class="form-control" name="age" />',
  388. '</div>',
  389. '</div>',
  390. '<div class="form-group">',
  391. '<label class="col-lg-3 control-label">Website</label>',
  392. '<div class="col-lg-5">',
  393. '<input type="text" class="form-control" name="website" />',
  394. '</div>',
  395. '</div>',
  396. '<div class="form-group">',
  397. '<label class="col-lg-3 control-label">Phone number</label>',
  398. '<div class="col-lg-5">',
  399. '<input type="text" class="form-control" name="phoneNumber" />',
  400. '</div>',
  401. '</div>',
  402. '<div class="form-group">',
  403. '<label class="col-lg-3 control-label">Languages</label>',
  404. '<div class="col-lg-5">',
  405. '<div class="checkbox">',
  406. '<label><input type="checkbox" name="languages[]" value="english" /> English</label>',
  407. '</div>',
  408. '<div class="checkbox">',
  409. '<label><input type="checkbox" name="languages[]" value="french" /> French</label>',
  410. '</div>',
  411. '<div class="checkbox">',
  412. '<label><input type="checkbox" name="languages[]" value="german" /> German</label>',
  413. '</div>',
  414. '<div class="checkbox">',
  415. '<label><input type="checkbox" name="languages[]" value="russian" /> Russian</label>',
  416. '</div>',
  417. '<div class="checkbox">',
  418. '<label><input type="checkbox" name="languages[]" value="other" /> Other</label>',
  419. '</div>',
  420. '</div>',
  421. '</div>',
  422. '<div class="form-group">',
  423. '<label class="col-lg-3 control-label">Programming Languages</label>',
  424. '<div class="col-lg-5">',
  425. '<div class="checkbox">',
  426. '<label><input type="checkbox" name="programs[]" value="net" /> .Net</label>',
  427. '</div>',
  428. '<div class="checkbox">',
  429. '<label><input type="checkbox" name="programs[]" value="java" /> Java</label>',
  430. '</div>',
  431. '<div class="checkbox">',
  432. '<label><input type="checkbox" name="programs[]" value="c" /> C/C++</label>',
  433. '</div>',
  434. '<div class="checkbox">',
  435. '<label><input type="checkbox" name="programs[]" value="php" /> PHP</label>',
  436. '</div>',
  437. '<div class="checkbox">',
  438. '<label><input type="checkbox" name="programs[]" value="perl" /> Perl</label>',
  439. '</div>',
  440. '<div class="checkbox">',
  441. '<label><input type="checkbox" name="programs[]" value="ruby" /> Ruby</label>',
  442. '</div>',
  443. '<div class="checkbox">',
  444. '<label><input type="checkbox" name="programs[]" value="python" /> Python</label>',
  445. '</div>',
  446. '<div class="checkbox">',
  447. '<label><input type="checkbox" name="programs[]" value="javascript" /> Javascript</label>',
  448. '</div>',
  449. '</div>',
  450. '</div>',
  451. '</form>'
  452. ].join('')).appendTo('body');
  453. $('#i18nForm').bootstrapValidator({
  454. feedbackIcons: {
  455. valid: 'glyphicon glyphicon-ok',
  456. invalid: 'glyphicon glyphicon-remove',
  457. validating: 'glyphicon glyphicon-refresh'
  458. },
  459. fields: {
  460. fullName: {
  461. validators: {
  462. notEmpty: {},
  463. stringCase: {
  464. 'case': 'upper'
  465. }
  466. }
  467. },
  468. username: {
  469. validators: {
  470. notEmpty: {},
  471. stringLength: {
  472. min: 6,
  473. max: 20
  474. },
  475. regexp: {
  476. regexp: /^[a-zA-Z0-9_\.]+$/
  477. },
  478. different: {
  479. field: 'password'
  480. }
  481. }
  482. },
  483. email: {
  484. validators: {
  485. emailAddress: {}
  486. }
  487. },
  488. password: {
  489. validators: {
  490. notEmpty: {},
  491. identical: {
  492. field: 'confirmPassword'
  493. },
  494. different: {
  495. field: 'username'
  496. }
  497. }
  498. },
  499. confirmPassword: {
  500. validators: {
  501. notEmpty: {},
  502. identical: {
  503. field: 'password'
  504. },
  505. different: {
  506. field: 'username'
  507. }
  508. }
  509. },
  510. age: {
  511. validators: {
  512. notEmpty: {},
  513. digits: {},
  514. greaterThan: {
  515. value: 18
  516. },
  517. lessThan: {
  518. value: 100
  519. }
  520. }
  521. },
  522. website: {
  523. validators: {
  524. notEmpty: {},
  525. uri: {}
  526. }
  527. },
  528. phoneNumber: {
  529. validators: {
  530. notEmpty: {},
  531. digits: {},
  532. phone: {
  533. country: 'US'
  534. }
  535. }
  536. },
  537. gender: {
  538. validators: {
  539. notEmpty: {}
  540. }
  541. },
  542. 'languages[]': {
  543. validators: {
  544. notEmpty: {}
  545. }
  546. },
  547. 'programs[]': {
  548. validators: {
  549. choice: {
  550. min: 2,
  551. max: 4
  552. }
  553. }
  554. }
  555. }
  556. });
  557. this.bv = $('#i18nForm').data('bootstrapValidator');
  558. this.$fullName = this.bv.getFieldElements('fullName');
  559. this.$email = this.bv.getFieldElements('email');
  560. this.$userName = this.bv.getFieldElements('username');
  561. this.$password = this.bv.getFieldElements('password');
  562. this.$confirm = this.bv.getFieldElements('confirmPassword');
  563. this.$age = this.bv.getFieldElements('age');
  564. this.$website = this.bv.getFieldElements('website');
  565. this.$phone = this.bv.getFieldElements('phoneNumber');
  566. this.$program = this.bv.getFieldElements('programs[]');
  567. });
  568. afterEach(function() {
  569. $('#i18nForm').bootstrapValidator('destroy').remove();
  570. });
  571. it('default message', function() {
  572. this.bv.validate();
  573. expect(this.bv.getMessages(this.$fullName, 'notEmpty')[0]).toEqual($.fn.bootstrapValidator.i18n.notEmpty['default']);
  574. this.$fullName.val('lowerName');
  575. this.bv.revalidateField('fullName');
  576. expect(this.bv.getMessages('fullName', 'stringCase')[0]).toEqual($.fn.bootstrapValidator.i18n.stringCase.upper);
  577. this.bv.resetForm();
  578. this.$userName.val('123');
  579. this.bv.validate();
  580. expect(this.bv.getMessages('username', 'stringLength')[0]).toEqual($.fn.bootstrapValidator.i18n.stringLength.getMessage({ min: 6, max: 20 }));
  581. this.bv.resetForm();
  582. this.$userName.val('contain@#$');
  583. this.bv.validate();
  584. expect(this.bv.getMessages(this.$userName, 'regexp')[0]).toEqual($.fn.bootstrapValidator.i18n.regexp['default']);
  585. this.bv.resetForm();
  586. this.$userName.val('validUserName');
  587. this.$password.val('validUserName');
  588. this.bv.validate();
  589. expect(this.bv.getMessages('username', 'different')[0]).toEqual($.fn.bootstrapValidator.i18n.different['default']);
  590. this.bv.resetForm();
  591. this.$email.val('invalid#email@address');
  592. this.bv.validate();
  593. expect(this.bv.getMessages(this.$email, 'emailAddress')[0]).toEqual($.fn.bootstrapValidator.i18n.emailAddress['default']);
  594. this.bv.resetForm();
  595. this.$password.val('@S3cur3P@@w0rd');
  596. this.$confirm.val('notMatch');
  597. this.bv.validate();
  598. expect(this.bv.getMessages('password', 'identical')[0]).toEqual($.fn.bootstrapValidator.i18n.identical['default']);
  599. this.bv.resetForm();
  600. this.$age.val('notDigit');
  601. this.bv.validate();
  602. expect(this.bv.getMessages('age', 'digits')[0]).toEqual($.fn.bootstrapValidator.i18n.digits['default']);
  603. this.bv.resetForm();
  604. this.$age.val(10);
  605. this.bv.validate();
  606. expect(this.bv.getMessages(this.$age, 'greaterThan')[0]).toEqual($.fn.bootstrapValidator.i18n.greaterThan.getMessage({ value: 18 }));
  607. this.bv.resetForm();
  608. this.$age.val(120);
  609. this.bv.validate();
  610. expect(this.bv.getMessages('age', 'lessThan')[0]).toEqual($.fn.bootstrapValidator.i18n.lessThan.getMessage({ value: 100 }));
  611. this.bv.resetForm();
  612. this.$website.val('http://invalidWebsite');
  613. this.bv.validate();
  614. expect(this.bv.getMessages('website', 'uri')[0]).toEqual($.fn.bootstrapValidator.i18n.uri['default']);
  615. this.bv.resetForm();
  616. this.$phone.val('123456');
  617. this.bv.validate();
  618. expect(this.bv.getMessages('phoneNumber', 'phone')[0]).toEqual($.fn.bootstrapValidator.i18n.phone.getMessage({ country: 'US' }));
  619. this.bv.resetForm();
  620. this.$program.eq(0).prop('checked', 'checked');
  621. this.bv.validate();
  622. expect(this.bv.getMessages(this.$program, 'choice')[0]).toEqual($.fn.bootstrapValidator.i18n.choice.getMessage({ min: 2, max: 4 }));
  623. this.bv.resetForm();
  624. this.$program.prop('checked', 'checked');
  625. this.bv.validate();
  626. expect(this.bv.getMessages('programs[]', 'choice')[0]).toEqual($.fn.bootstrapValidator.i18n.choice.getMessage({ min: 2, max: 4 }));
  627. });
  628. });
  629. describe('message', function() {
  630. beforeEach(function() {
  631. var html = [
  632. '<div class="container">',
  633. '<form class="form-horizontal" id="messageForm">',
  634. '<div class="form-group">',
  635. '<input type="password" class="form-control" name="password" placeholder="Enter secure password" />',
  636. '</div>',
  637. '</form>',
  638. '</div>'
  639. ].join('\n');
  640. $(html).appendTo('body');
  641. $('#messageForm').bootstrapValidator({
  642. fields: {
  643. password: {
  644. validators: {
  645. notEmpty: {
  646. message: 'The password is required'
  647. },
  648. callback: {
  649. callback: function(value, validator) {
  650. // Check the password strength
  651. if (value.length < 6) {
  652. return {
  653. valid: false,
  654. message: 'The password must be more than 6 characters'
  655. }
  656. }
  657. if (value === value.toLowerCase()) {
  658. return {
  659. valid: false,
  660. message: 'The password must contain at least one upper case character'
  661. }
  662. }
  663. if (value === value.toUpperCase()) {
  664. return {
  665. valid: false,
  666. message: 'The password must contain at least one lower case character'
  667. }
  668. }
  669. if (value.search(/[0-9]/) < 0) {
  670. return {
  671. valid: false,
  672. message: 'The password must contain at least one digit'
  673. }
  674. }
  675. return true;
  676. }
  677. }
  678. }
  679. }
  680. }
  681. });
  682. this.bv = $('#messageForm').data('bootstrapValidator');
  683. this.$password = this.bv.getFieldElements('password');
  684. });
  685. afterEach(function() {
  686. $('#messageForm').bootstrapValidator('destroy').parent().remove();
  687. });
  688. it('update message from callback', function() {
  689. this.bv.resetForm();
  690. this.$password.val('123');
  691. this.bv.validate();
  692. expect(this.bv.getMessages('password', 'callback')[0]).toEqual('The password must be more than 6 characters');
  693. this.bv.resetForm();
  694. this.$password.val('no_upper_case!@#');
  695. this.bv.validate();
  696. expect(this.bv.getMessages('password', 'callback')[0]).toEqual('The password must contain at least one upper case character');
  697. this.bv.resetForm();
  698. this.$password.val('NO_LOWER_CASE123');
  699. this.bv.validate();
  700. expect(this.bv.getMessages('password', 'callback')[0]).toEqual('The password must contain at least one lower case character');
  701. this.bv.resetForm();
  702. this.$password.val('NoDigits!@#');
  703. this.bv.validate();
  704. expect(this.bv.getMessages('password', 'callback')[0]).toEqual('The password must contain at least one digit');
  705. });
  706. it('call updateMessage()', function() {
  707. this.bv.updateStatus('password', this.bv.STATUS_INVALID, 'callback');
  708. this.bv.updateMessage('password', 'callback', 'The password is weak');
  709. expect(this.bv.getMessages('password', 'callback')[0]).toEqual('The password is weak');
  710. this.bv.updateMessage(this.$password, 'callback', 'The password is not strong');
  711. expect(this.bv.getMessages(this.$password, 'callback')[0]).toEqual('The password is not strong');
  712. });
  713. });
  714. function validateCaptcha(value, validator, $field) {
  715. var items = $('#captchaOperation').html().split(' '), sum = parseInt(items[0]) + parseInt(items[2]);
  716. return value === sum + '';
  717. };
  718. describe('callback', function() {
  719. beforeEach(function() {
  720. $(['<div class="container">',
  721. '<form class="form-horizontal" id="callbackForm">',
  722. '<div class="form-group">',
  723. '<label class="col-md-3 control-label" id="captchaOperation"></label>',
  724. '<div class="col-md-2">',
  725. '<input type="text" class="form-control" name="captcha" />',
  726. '</div>',
  727. '</div>',
  728. '<div class="form-group">',
  729. '<div class="col-md-2 col-md-offset-3">',
  730. '<input type="text" class="form-control" name="declarativeCaptcha" data-bv-callback data-bv-callback-callback="validateCaptcha" />',
  731. '</div>',
  732. '</div>',
  733. '</form>',
  734. '</div>'
  735. ].join('\n')).appendTo('body');
  736. $('#callbackForm').bootstrapValidator({
  737. fields: {
  738. captcha: {
  739. validators: {
  740. callback: {
  741. message: 'Wrong answer',
  742. callback: function(value, validator, $field) {
  743. return validateCaptcha(value, validator, $field);
  744. }
  745. }
  746. }
  747. }
  748. }
  749. });
  750. this.bv = $('#callbackForm').data('bootstrapValidator');
  751. this.$captcha = this.bv.getFieldElements('captcha');
  752. this.$declarativeCaptcha = this.bv.getFieldElements('declarativeCaptcha');
  753. });
  754. afterEach(function() {
  755. $('#callbackForm').bootstrapValidator('destroy').parent().remove();
  756. });
  757. it('execute the callback', function() {
  758. $('#captchaOperation').html('1 + 2');
  759. this.$captcha.val('3');
  760. this.bv.validate();
  761. expect(this.bv.isValidField('captcha')).toBeTruthy();
  762. this.bv.resetForm();
  763. this.$captcha.val('5');
  764. this.bv.validate();
  765. expect(this.bv.isValidField('captcha')).toEqual(false);
  766. });
  767. it('callback declarative', function() {
  768. $('#captchaOperation').html('10 + 20');
  769. this.$declarativeCaptcha.val('40');
  770. this.bv.validate();
  771. expect(this.bv.isValidField('declarativeCaptcha')).toEqual(false);
  772. this.bv.resetForm();
  773. this.$declarativeCaptcha.val('30');
  774. this.bv.validate();
  775. expect(this.bv.isValidField('declarativeCaptcha')).toBeTruthy();
  776. });
  777. });
  778. describe('creditCard', function() {
  779. // Get the fake credit card number at http://www.getcreditcardnumbers.com/
  780. beforeEach(function() {
  781. var html = [
  782. '<div class="container">',
  783. '<form class="form-horizontal" id="ccForm">',
  784. '<div class="form-group">',
  785. '<input type="text" name="cc" data-bv-creditcard />',
  786. '</div>',
  787. '</form>',
  788. '</div>'
  789. ].join('\n');
  790. $(html).appendTo('body');
  791. $('#ccForm').bootstrapValidator();
  792. this.bv = $('#ccForm').data('bootstrapValidator');
  793. this.$creditCard = this.bv.getFieldElements('cc');
  794. });
  795. afterEach(function() {
  796. $('#ccForm').bootstrapValidator('destroy').parent().remove();
  797. });
  798. it('accept spaces', function() {
  799. this.$creditCard.val('5267 9789 9451 9654');
  800. this.bv.validate();
  801. expect(this.bv.isValidField('cc')).toBeTruthy();
  802. });
  803. it('accept dashes', function() {
  804. this.$creditCard.val('6011-2649-6840-4521');
  805. this.bv.validate();
  806. expect(this.bv.isValidField('cc')).toBeTruthy();
  807. });
  808. it('invalid format', function() {
  809. this.$creditCard.val('4539.1870.2954.3862');
  810. this.bv.validate();
  811. expect(this.bv.isValidField('cc')).toEqual(false);
  812. });
  813. it('American Express', function() {
  814. this.$creditCard.val('340653705597107');
  815. this.bv.validate();
  816. expect(this.bv.isValidField('cc')).toBeTruthy();
  817. });
  818. it('American Express invalid length', function() {
  819. this.$creditCard.val('3744148309166730');
  820. this.bv.validate();
  821. expect(this.bv.isValidField('cc')).toEqual(false);
  822. });
  823. it('American Express invalid prefix', function() {
  824. this.$creditCard.val('356120148436654');
  825. this.bv.validate();
  826. expect(this.bv.isValidField('cc')).toEqual(false);
  827. });
  828. it('Diners Club', function() {
  829. this.$creditCard.val('30130708434187');
  830. this.bv.validate();
  831. expect(this.bv.isValidField('cc')).toBeTruthy();
  832. });
  833. it('Diners Club (US)', function() {
  834. this.$creditCard.val('5517479515603901');
  835. this.bv.validate();
  836. expect(this.bv.isValidField('cc')).toBeTruthy();
  837. });
  838. it('Discover', function() {
  839. this.$creditCard.val('6011734674929094');
  840. this.bv.validate();
  841. expect(this.bv.isValidField('cc')).toBeTruthy();
  842. });
  843. it('JCB', function() {
  844. this.$creditCard.val('3566002020360505');
  845. this.bv.validate();
  846. expect(this.bv.isValidField('cc')).toBeTruthy();
  847. });
  848. it('Laser', function() {
  849. this.$creditCard.val('6304 9000 1774 0292 441');
  850. this.bv.validate();
  851. expect(this.bv.isValidField('cc')).toBeTruthy();
  852. });
  853. it('Maestro', function() {
  854. this.$creditCard.val('6762835098779303');
  855. this.bv.validate();
  856. expect(this.bv.isValidField('cc')).toBeTruthy();
  857. });
  858. it('Mastercard', function() {
  859. this.$creditCard.val('5303765013600904');
  860. this.bv.validate();
  861. expect(this.bv.isValidField('cc')).toBeTruthy();
  862. });
  863. it('Solo', function() {
  864. this.$creditCard.val('6334580500000000');
  865. this.bv.validate();
  866. expect(this.bv.isValidField('cc')).toBeTruthy();
  867. });
  868. it('Visa', function() {
  869. this.$creditCard.val('4929248980295542');
  870. this.bv.validate();
  871. expect(this.bv.isValidField('cc')).toBeTruthy();
  872. });
  873. it('Visa invalid check digit', function() {
  874. this.$creditCard.val('4532599916257826');
  875. this.bv.validate();
  876. expect(this.bv.isValidField('cc')).toEqual(false);
  877. });
  878. });
  879. describe('ean', function() {
  880. beforeEach(function() {
  881. var html = [
  882. '<div class="container">',
  883. '<form class="form-horizontal" id="eanForm">',
  884. '<div class="form-group">',
  885. '<input type="text" name="ean" data-bv-ean />',
  886. '</div>',
  887. '</form>',
  888. '</div>'
  889. ].join('\n');
  890. $(html).appendTo('body');
  891. $('#eanForm').bootstrapValidator();
  892. this.bv = $('#eanForm').data('bootstrapValidator');
  893. this.$ean = this.bv.getFieldElements('ean');
  894. });
  895. afterEach(function() {
  896. $('#eanForm').bootstrapValidator('destroy').parent().remove();
  897. });
  898. it('valid', function() {
  899. var samples = ['73513537', '9780471117094', '4006381333931'];
  900. for (var i in samples) {
  901. this.$ean.val(samples[i]);
  902. this.bv.validate();
  903. expect(this.bv.isValidField('ean')).toBeTruthy();
  904. }
  905. });
  906. it('contains only digits', function() {
  907. this.$ean.val('123abcDEF!@#');
  908. this.bv.validate();
  909. expect(this.bv.isValidField('ean')).toEqual(false);
  910. });
  911. it('invalid length', function() {
  912. this.$ean.val('1234567');
  913. this.bv.validate();
  914. expect(this.bv.isValidField('ean')).toEqual(false);
  915. });
  916. it('invalid check digit', function() {
  917. this.$ean.val('73513536');
  918. this.bv.validate();
  919. expect(this.bv.isValidField('ean')).toEqual(false);
  920. });
  921. });
  922. describe('iban', function() {
  923. beforeEach(function() {
  924. var html = [
  925. '<div class="container">',
  926. '<form class="form-horizontal" id="ibanForm">',
  927. '<div class="form-group">',
  928. '<input type="text" name="iban" data-bv-iban />',
  929. '</div>',
  930. '</form>',
  931. '</div>'
  932. ].join('\n');
  933. $(html).appendTo('body');
  934. $('#ibanForm').bootstrapValidator();
  935. this.bv = $('#ibanForm').data('bootstrapValidator');
  936. this.$iban = this.bv.getFieldElements('iban');
  937. });
  938. afterEach(function() {
  939. $('#ibanForm').bootstrapValidator('destroy').parent().remove();
  940. });
  941. it('not supported country', function() {
  942. this.$iban.val('US123456789');
  943. this.bv.validate();
  944. expect(this.bv.isValidField('iban')).toEqual(false);
  945. });
  946. it('Albania', function() {
  947. this.$iban.val('AL47212110090000000235698741');
  948. this.bv.validate();
  949. expect(this.bv.isValidField('iban')).toBeTruthy();
  950. });
  951. it('Algeria', function() {
  952. this.$iban.val('DZ4000400174401001050486');
  953. this.bv.validate();
  954. expect(this.bv.isValidField('iban')).toBeTruthy();
  955. });
  956. it('Andorra', function() {
  957. this.$iban.val('AD1200012030200359100100');
  958. this.bv.validate();
  959. expect(this.bv.isValidField('iban')).toBeTruthy();
  960. });
  961. it('Angola', function() {
  962. this.$iban.val('AO06000600000100037131174');
  963. this.bv.validate();
  964. expect(this.bv.isValidField('iban')).toBeTruthy();
  965. });
  966. it('Austria', function() {
  967. this.$iban.val('AT611904300234573201');
  968. this.bv.validate();
  969. expect(this.bv.isValidField('iban')).toBeTruthy();
  970. });
  971. it('Azerbaijan', function() {
  972. this.$iban.val('AZ21NABZ00000000137010001944');
  973. this.bv.validate();
  974. expect(this.bv.isValidField('iban')).toBeTruthy();
  975. });
  976. it('Bahrain', function() {
  977. this.$iban.val('BH29BMAG1299123456BH00');
  978. this.bv.validate();
  979. expect(this.bv.isValidField('iban')).toBeTruthy();
  980. });
  981. it('Belgium', function() {
  982. this.$iban.val('BE68539007547034');
  983. this.bv.validate();
  984. expect(this.bv.isValidField('iban')).toBeTruthy();
  985. });
  986. it('Benin', function() {
  987. this.$iban.val('BJ11B00610100400271101192591');
  988. this.bv.validate();
  989. expect(this.bv.isValidField('iban')).toBeTruthy();
  990. });
  991. it('Brazil', function() {
  992. this.$iban.val('BR9700360305000010009795493P1');
  993. this.bv.validate();
  994. expect(this.bv.isValidField('iban')).toBeTruthy();
  995. });
  996. it('Bulgaria', function() {
  997. this.$iban.val('BG80BNBG96611020345678');
  998. this.bv.validate();
  999. expect(this.bv.isValidField('iban')).toBeTruthy();
  1000. });
  1001. it('Burkina Faso', function() {
  1002. this.$iban.val('BF1030134020015400945000643');
  1003. this.bv.validate();
  1004. expect(this.bv.isValidField('iban')).toBeTruthy();
  1005. });
  1006. it('Burundi', function() {
  1007. this.$iban.val('BI43201011067444');
  1008. this.bv.validate();
  1009. expect(this.bv.isValidField('iban')).toBeTruthy();
  1010. });
  1011. it('Cameroon', function() {
  1012. this.$iban.val('CM2110003001000500000605306');
  1013. this.bv.validate();
  1014. expect(this.bv.isValidField('iban')).toBeTruthy();
  1015. });
  1016. it('Cape Verde', function() {
  1017. this.$iban.val('CV64000300004547069110176');
  1018. this.bv.validate();
  1019. expect(this.bv.isValidField('iban')).toBeTruthy();
  1020. });
  1021. it('Costa Rica', function() {
  1022. this.$iban.val('CR0515202001026284066');
  1023. this.bv.validate();
  1024. expect(this.bv.isValidField('iban')).toBeTruthy();
  1025. });
  1026. it('Croatia', function() {
  1027. this.$iban.val('HR1210010051863000160');
  1028. this.bv.validate();
  1029. expect(this.bv.isValidField('iban')).toBeTruthy();
  1030. });
  1031. it('Cyprus', function() {
  1032. this.$iban.val('CY17002001280000001200527600');
  1033. this.bv.validate();
  1034. expect(this.bv.isValidField('iban')).toBeTruthy();
  1035. });
  1036. it('Czech Republic', function() {
  1037. this.$iban.val('CZ6508000000192000145399');
  1038. this.bv.validate();
  1039. expect(this.bv.isValidField('iban')).toBeTruthy();
  1040. });
  1041. it('Denmark', function() {
  1042. this.$iban.val('DK5000400440116243');
  1043. this.bv.validate();
  1044. expect(this.bv.isValidField('iban')).toBeTruthy();
  1045. });
  1046. it('Dominican Republic', function() {
  1047. this.$iban.val('DO28BAGR00000001212453611324');
  1048. this.bv.validate();
  1049. expect(this.bv.isValidField('iban')).toBeTruthy();
  1050. });
  1051. it('Estonia', function() {
  1052. this.$iban.val('EE382200221020145685');
  1053. this.bv.validate();
  1054. expect(this.bv.isValidField('iban')).toBeTruthy();
  1055. });
  1056. it('Faroe Islands', function() {
  1057. this.$iban.val('FO1464600009692713');
  1058. this.bv.validate();
  1059. expect(this.bv.isValidField('iban')).toBeTruthy();
  1060. });
  1061. it('Finland', function() {
  1062. this.$iban.val('FI2112345600000785');
  1063. this.bv.validate();
  1064. expect(this.bv.isValidField('iban')).toBeTruthy();
  1065. });
  1066. it('France', function() {
  1067. this.$iban.val('FR1420041010050500013M02606');
  1068. this.bv.validate();
  1069. expect(this.bv.isValidField('iban')).toBeTruthy();
  1070. });
  1071. it('Guatemala', function() {
  1072. this.$iban.val('GT82TRAJ01020000001210029690');
  1073. this.bv.validate();
  1074. expect(this.bv.isValidField('iban')).toBeTruthy();
  1075. });
  1076. it('Georgia', function() {
  1077. this.$iban.val('GE29NB0000000101904917');
  1078. this.bv.validate();
  1079. expect(this.bv.isValidField('iban')).toBeTruthy();
  1080. });
  1081. it('Germany', function() {
  1082. this.$iban.val('DE89370400440532013000');
  1083. this.bv.validate();
  1084. expect(this.bv.isValidField('iban')).toBeTruthy();
  1085. });
  1086. it('Gibraltar', function() {
  1087. this.$iban.val('GI75NWBK000000007099453');
  1088. this.bv.validate();
  1089. expect(this.bv.isValidField('iban')).toBeTruthy();
  1090. });
  1091. it('Greece', function() {
  1092. this.$iban.val('GR1601101250000000012300695');
  1093. this.bv.validate();
  1094. expect(this.bv.isValidField('iban')).toBeTruthy();
  1095. });
  1096. it('Greenland', function() {
  1097. this.$iban.val('GL8964710001000206');
  1098. this.bv.validate();
  1099. expect(this.bv.isValidField('iban')).toBeTruthy();
  1100. });
  1101. it('Hungary', function() {
  1102. this.$iban.val('HU42117730161111101800000000');
  1103. this.bv.validate();
  1104. expect(this.bv.isValidField('iban')).toBeTruthy();
  1105. });
  1106. it('Iceland', function() {
  1107. this.$iban.val('IS140159260076545510730339');
  1108. this.bv.validate();
  1109. expect(this.bv.isValidField('iban')).toBeTruthy();
  1110. });
  1111. it('Iran', function() {
  1112. this.$iban.val('IR580540105180021273113007');
  1113. this.bv.validate();
  1114. expect(this.bv.isValidField('iban')).toBeTruthy();
  1115. });
  1116. it('Ireland', function() {
  1117. this.$iban.val('IE29AIBK93115212345678');
  1118. this.bv.validate();
  1119. expect(this.bv.isValidField('iban')).toBeTruthy();
  1120. });
  1121. it('Israel', function() {
  1122. this.$iban.val('IL620108000000099999999');
  1123. this.bv.validate();
  1124. expect(this.bv.isValidField('iban')).toBeTruthy();
  1125. });
  1126. it('Italy', function() {
  1127. this.$iban.val('IT60X0542811101000000123456');
  1128. this.bv.validate();
  1129. expect(this.bv.isValidField('iban')).toBeTruthy();
  1130. });
  1131. it('Ivory Coast', function() {
  1132. this.$iban.val('CI05A00060174100178530011852');
  1133. this.bv.validate();
  1134. expect(this.bv.isValidField('iban')).toBeTruthy();
  1135. });
  1136. it('Jordan', function() {
  1137. this.$iban.val('JO94CBJO0010000000000131000302');
  1138. this.bv.validate();
  1139. expect(this.bv.isValidField('iban')).toBeTruthy();
  1140. });
  1141. it('Kazakhstan', function() {
  1142. this.$iban.val('KZ176010251000042993');
  1143. this.bv.validate();
  1144. expect(this.bv.isValidField('iban')).toBeTruthy();
  1145. });
  1146. it('Kuwait', function() {
  1147. this.$iban.val('KW74NBOK0000000000001000372151');
  1148. this.bv.validate();
  1149. expect(this.bv.isValidField('iban')).toBeTruthy();
  1150. });
  1151. it('Latvia', function() {
  1152. this.$iban.val('LV80BANK0000435195001');
  1153. this.bv.validate();
  1154. expect(this.bv.isValidField('iban')).toBeTruthy();
  1155. });
  1156. it('Lebanon', function() {
  1157. this.$iban.val('LB30099900000001001925579115');
  1158. this.bv.validate();
  1159. expect(this.bv.isValidField('iban')).toBeTruthy();
  1160. });
  1161. it('Liechtenstein', function() {
  1162. this.$iban.val('LI21088100002324013AA');
  1163. this.bv.validate();
  1164. expect(this.bv.isValidField('iban')).toBeTruthy();
  1165. });
  1166. it('Lithuania', function() {
  1167. this.$iban.val('LT121000011101001000');
  1168. this.bv.validate();
  1169. expect(this.bv.isValidField('iban')).toBeTruthy();
  1170. });
  1171. it('Luxembourg', function() {
  1172. this.$iban.val('LU280019400644750000');
  1173. this.bv.validate();
  1174. expect(this.bv.isValidField('iban')).toBeTruthy();
  1175. });
  1176. it('Macedonia', function() {
  1177. this.$iban.val('MK07300000000042425');
  1178. this.bv.validate();
  1179. expect(this.bv.isValidField('iban')).toBeTruthy();
  1180. });
  1181. it('Madagascar', function() {
  1182. this.$iban.val('MG4600005030010101914016056');
  1183. this.bv.validate();
  1184. expect(this.bv.isValidField('iban')).toBeTruthy();
  1185. });
  1186. it('Malta', function() {
  1187. this.$iban.val('MT84MALT011000012345MTLCAST001S');
  1188. this.bv.validate();
  1189. expect(this.bv.isValidField('iban')).toBeTruthy();
  1190. });
  1191. it('Mauritania', function() {
  1192. this.$iban.val('MR1300012000010000002037372');
  1193. this.bv.validate();
  1194. expect(this.bv.isValidField('iban')).toBeTruthy();
  1195. });
  1196. it('Mauritius', function() {
  1197. this.$iban.val('MU17BOMM0101101030300200000MUR');
  1198. this.bv.validate();
  1199. expect(this.bv.isValidField('iban')).toBeTruthy();
  1200. });
  1201. it('Mali', function() {
  1202. this.$iban.val('ML03D00890170001002120000447');
  1203. this.bv.validate();
  1204. expect(this.bv.isValidField('iban')).toBeTruthy();
  1205. });
  1206. it('Moldova', function() {
  1207. this.$iban.val('MD24AG000225100013104168');
  1208. this.bv.validate();
  1209. expect(this.bv.isValidField('iban')).toBeTruthy();
  1210. });
  1211. it('Monaco', function() {
  1212. this.$iban.val('MC5813488000010051108001292');
  1213. this.bv.validate();
  1214. expect(this.bv.isValidField('iban')).toBeTruthy();
  1215. });
  1216. it('Montenegro', function() {
  1217. this.$iban.val('ME25505000012345678951');
  1218. this.bv.validate();
  1219. expect(this.bv.isValidField('iban')).toBeTruthy();
  1220. });
  1221. it('Mozambique', function() {
  1222. this.$iban.val('MZ59000100000011834194157');
  1223. this.bv.validate();
  1224. expect(this.bv.isValidField('iban')).toBeTruthy();
  1225. });
  1226. it('Netherlands', function() {
  1227. this.$iban.val('NL91ABNA0417164300');
  1228. this.bv.validate();
  1229. expect(this.bv.isValidField('iban')).toBeTruthy();
  1230. });
  1231. it('Norway', function() {
  1232. this.$iban.val('NO9386011117947');
  1233. this.bv.validate();
  1234. expect(this.bv.isValidField('iban')).toBeTruthy();
  1235. });
  1236. it('Pakistan', function() {
  1237. this.$iban.val('PK24SCBL0000001171495101');
  1238. this.bv.validate();
  1239. expect(this.bv.isValidField('iban')).toBeTruthy();
  1240. });
  1241. it('Palestine', function() {
  1242. this.$iban.val('PS92PALS000000000400123456702');
  1243. this.bv.validate();
  1244. expect(this.bv.isValidField('iban')).toBeTruthy();
  1245. });
  1246. it('Poland', function() {
  1247. this.$iban.val('PL27114020040000300201355387');
  1248. this.bv.validate();
  1249. expect(this.bv.isValidField('iban')).toBeTruthy();
  1250. });
  1251. it('Portugal', function() {
  1252. this.$iban.val('PT50000201231234567890154');
  1253. this.bv.validate();
  1254. expect(this.bv.isValidField('iban')).toBeTruthy();
  1255. });
  1256. it('Qatar', function() {
  1257. this.$iban.val('QA58DOHB00001234567890ABCDEFG');
  1258. this.bv.validate();
  1259. expect(this.bv.isValidField('iban')).toBeTruthy();
  1260. });
  1261. it('Romania', function() {
  1262. this.$iban.val('RO49AAAA1B31007593840000');
  1263. this.bv.validate();
  1264. expect(this.bv.isValidField('iban')).toBeTruthy();
  1265. });
  1266. it('San Marino', function() {
  1267. this.$iban.val('SM86U0322509800000000270100');
  1268. this.bv.validate();
  1269. expect(this.bv.isValidField('iban')).toBeTruthy();
  1270. });
  1271. it('Saudi Arabia', function() {
  1272. this.$iban.val('SA0380000000608010167519');
  1273. this.bv.validate();
  1274. expect(this.bv.isValidField('iban')).toBeTruthy();
  1275. });
  1276. it('Senegal', function() {
  1277. this.$iban.val('SN12K00100152000025690007542');
  1278. this.bv.validate();
  1279. expect(this.bv.isValidField('iban')).toBeTruthy();
  1280. });
  1281. it('Serbia', function() {
  1282. this.$iban.val('RS35260005601001611379');
  1283. this.bv.validate();
  1284. expect(this.bv.isValidField('iban')).toBeTruthy();
  1285. });
  1286. it('Slovakia', function() {
  1287. this.$iban.val('SK3112000000198742637541');
  1288. this.bv.validate();
  1289. expect(this.bv.isValidField('iban')).toBeTruthy();
  1290. });
  1291. it('Slovenia', function() {
  1292. this.$iban.val('SI56191000000123438');
  1293. this.bv.validate();
  1294. expect(this.bv.isValidField('iban')).toBeTruthy();
  1295. });
  1296. it('Spain', function() {
  1297. this.$iban.val('ES9121000418450200051332');
  1298. this.bv.validate();
  1299. expect(this.bv.isValidField('iban')).toBeTruthy();
  1300. });
  1301. it('Sweden', function() {
  1302. this.$iban.val('SE3550000000054910000003');
  1303. this.bv.validate();
  1304. expect(this.bv.isValidField('iban')).toBeTruthy();
  1305. });
  1306. it('Switzerland', function() {
  1307. this.$iban.val('CH9300762011623852957');
  1308. this.bv.validate();
  1309. expect(this.bv.isValidField('iban')).toBeTruthy();
  1310. });
  1311. it('Tunisia', function() {
  1312. this.$iban.val('TN5914207207100707129648');
  1313. this.bv.validate();
  1314. expect(this.bv.isValidField('iban')).toBeTruthy();
  1315. });
  1316. it('Turkey', function() {
  1317. this.$iban.val('TR330006100519786457841326');
  1318. this.bv.validate();
  1319. expect(this.bv.isValidField('iban')).toBeTruthy();
  1320. });
  1321. it('United Arab Emirates', function() {
  1322. this.$iban.val('AE260211000000230064016');
  1323. this.bv.validate();
  1324. expect(this.bv.isValidField('iban')).toBeTruthy();
  1325. });
  1326. it('United Kingdom', function() {
  1327. this.$iban.val('GB29NWBK60161331926819');
  1328. this.bv.validate();
  1329. expect(this.bv.isValidField('iban')).toBeTruthy();
  1330. });
  1331. it('Virgin Islands, British', function() {
  1332. this.$iban.val('VG96VPVG0000012345678901');
  1333. this.bv.validate();
  1334. expect(this.bv.isValidField('iban')).toBeTruthy();
  1335. });
  1336. it('invalid checksum', function() {
  1337. this.$iban.val('TR330006100519786457841325');
  1338. this.bv.validate();
  1339. expect(this.bv.isValidField('iban')).toEqual(false);
  1340. });
  1341. });
  1342. describe('isbn', function() {
  1343. beforeEach(function() {
  1344. var html = [
  1345. '<div class="container">',
  1346. '<form class="form-horizontal" id="isbnForm">',
  1347. '<div class="form-group">',
  1348. '<input type="text" name="isbn" data-bv-isbn />',
  1349. '</div>',
  1350. '</form>',
  1351. '</div>'
  1352. ].join('\n');
  1353. $(html).appendTo('body');
  1354. $('#isbnForm').bootstrapValidator();
  1355. this.bv = $('#isbnForm').data('bootstrapValidator');
  1356. this.$isbn = this.bv.getFieldElements('isbn');
  1357. });
  1358. afterEach(function() {
  1359. $('#isbnForm').bootstrapValidator('destroy').parent().remove();
  1360. });
  1361. it('isbn10 hyphen', function() {
  1362. var samples = ['99921-58-10-7', '9971-5-0210-0', '960-425-059-0', '80-902734-1-6'];
  1363. for (var i in samples) {
  1364. this.$isbn.val(samples[i]);
  1365. this.bv.validate();
  1366. expect(this.bv.isValidField('isbn')).toBeTruthy();
  1367. }
  1368. });
  1369. it('isbn10 space', function() {
  1370. var samples = ['85 359 0277 5', '1 84356 028 3', '0 684 84328 5', '0 85131 041 9', '0 943396 04 2'];
  1371. for (var i in samples) {
  1372. this.$isbn.val(samples[i]);
  1373. this.bv.validate();
  1374. expect(this.bv.isValidField('isbn')).toBeTruthy();
  1375. }
  1376. });
  1377. it('isbn10 hyphen with X', function() {
  1378. var samples = ['0-8044-2957-X', '0-9752298-0-X'];
  1379. for (var i in samples) {
  1380. this.$isbn.val(samples[i]);
  1381. this.bv.validate();
  1382. expect(this.bv.isValidField('isbn')).toBeTruthy();
  1383. }
  1384. });
  1385. it('isbn10 invalid check digit', function() {
  1386. this.$isbn.val('99921-58-10-6');
  1387. this.bv.validate();
  1388. expect(this.bv.isValidField('isbn')).toEqual(false);
  1389. });
  1390. it('isbn13', function() {
  1391. this.$isbn.val('978-0-306-40615-7');
  1392. this.bv.validate();
  1393. expect(this.bv.isValidField('isbn')).toBeTruthy();
  1394. });
  1395. it('isbn13 invalid check digit', function() {
  1396. this.$isbn.val('978-0-306-40615-6');
  1397. this.bv.validate();
  1398. expect(this.bv.isValidField('isbn')).toEqual(false);
  1399. });
  1400. });
  1401. describe('isin', function() {
  1402. beforeEach(function() {
  1403. var html = [
  1404. '<div class="container">',
  1405. '<form class="form-horizontal" id="isinForm">',
  1406. '<div class="form-group">',
  1407. '<input type="text" name="isin" data-bv-isin />',
  1408. '</div>',
  1409. '</form>',
  1410. '</div>'
  1411. ].join('\n');
  1412. $(html).appendTo('body');
  1413. $('#isinForm').bootstrapValidator();
  1414. this.bv = $('#isinForm').data('bootstrapValidator');
  1415. this.$isin = this.bv.getFieldElements('isin');
  1416. });
  1417. afterEach(function() {
  1418. $('#isinForm').bootstrapValidator('destroy').parent().remove();
  1419. });
  1420. it('valid', function() {
  1421. var samples = ['US0378331005', 'AU0000XVGZA3', 'GB0002634946'];
  1422. for (var i in samples) {
  1423. this.$isin.val(samples[i]);
  1424. this.bv.validate();
  1425. expect(this.bv.isValidField('isin')).toBeTruthy();
  1426. }
  1427. });
  1428. it('invalid country code', function() {
  1429. this.$isin.val('AA0000XVGZA3');
  1430. this.bv.validate();
  1431. expect(this.bv.isValidField('isin')).toEqual(false);
  1432. });
  1433. it('contains only digits and alphabet', function() {
  1434. this.$isin.val('US12345ABC@#$');
  1435. this.bv.validate();
  1436. expect(this.bv.isValidField('isin')).toEqual(false);
  1437. });
  1438. it('invalid length', function() {
  1439. this.$isin.val('US1234567');
  1440. this.bv.validate();
  1441. expect(this.bv.isValidField('isin')).toEqual(false);
  1442. });
  1443. it('invalid check digit', function() {
  1444. this.$isin.val('US0378331004');
  1445. this.bv.validate();
  1446. expect(this.bv.isValidField('isin')).toEqual(false);
  1447. });
  1448. });
  1449. describe('ismn', function() {
  1450. beforeEach(function() {
  1451. var html = [
  1452. '<div class="container">',
  1453. '<form class="form-horizontal" id="ismnForm">',
  1454. '<div class="form-group">',
  1455. '<input type="text" name="ismn" data-bv-ismn />',
  1456. '</div>',
  1457. '</form>',
  1458. '</div>'
  1459. ].join('\n');
  1460. $(html).appendTo('body');
  1461. $('#ismnForm').bootstrapValidator();
  1462. this.bv = $('#ismnForm').data('bootstrapValidator');
  1463. this.$ismn = this.bv.getFieldElements('ismn');
  1464. });
  1465. afterEach(function() {
  1466. $('#ismnForm').bootstrapValidator('destroy').parent().remove();
  1467. });
  1468. it('valid start with M', function() {
  1469. this.$ismn.val('M230671187');
  1470. this.bv.validate();
  1471. expect(this.bv.isValidField('ismn')).toBeTruthy();
  1472. });
  1473. it('valid start with 979', function() {
  1474. this.$ismn.val('9790060115615');
  1475. this.bv.validate();
  1476. expect(this.bv.isValidField('ismn')).toBeTruthy();
  1477. });
  1478. it('valid contains spaces', function() {
  1479. this.$ismn.val('979 0 3452 4680 5');
  1480. this.bv.validate();
  1481. expect(this.bv.isValidField('ismn')).toBeTruthy();
  1482. });
  1483. it('valid contains dashes', function() {
  1484. this.$ismn.val('979-0-0601-1561-5');
  1485. this.bv.validate();
  1486. expect(this.bv.isValidField('ismn')).toBeTruthy();
  1487. });
  1488. it('invalid format', function() {
  1489. this.$ismn.val('N123456789');
  1490. this.bv.validate();
  1491. expect(this.bv.isValidField('ismn')).toEqual(false);
  1492. });
  1493. it('invalid check digit', function() {
  1494. this.$ismn.val('9790060115614');
  1495. this.bv.validate();
  1496. expect(this.bv.isValidField('ismn')).toEqual(false);
  1497. });
  1498. });
  1499. describe('issn', function() {
  1500. beforeEach(function() {
  1501. var html = [
  1502. '<div class="container">',
  1503. '<form class="form-horizontal" id="issnForm">',
  1504. '<div class="form-group">',
  1505. '<input type="text" name="issn" data-bv-issn />',
  1506. '</div>',
  1507. '</form>',
  1508. '</div>'
  1509. ].join('\n');
  1510. $(html).appendTo('body');
  1511. $('#issnForm').bootstrapValidator();
  1512. this.bv = $('#issnForm').data('bootstrapValidator');
  1513. this.$issn = this.bv.getFieldElements('issn');
  1514. });
  1515. afterEach(function() {
  1516. $('#issnForm').bootstrapValidator('destroy').parent().remove();
  1517. });
  1518. it('valid', function() {
  1519. var samples = ['0378-5955', '0024-9319', '0032-1478'];
  1520. for (var i in samples) {
  1521. this.$issn.val(samples[i]);
  1522. this.bv.validate();
  1523. expect(this.bv.isValidField('issn')).toBeTruthy();
  1524. }
  1525. });
  1526. it('not contains hyphen', function() {
  1527. this.$issn.val('03785955');
  1528. this.bv.validate();
  1529. expect(this.bv.isValidField('issn')).toEqual(false);
  1530. });
  1531. it('contains only digits, X', function() {
  1532. this.$issn.val('1234-566A');
  1533. this.bv.validate();
  1534. expect(this.bv.isValidField('issn')).toEqual(false);
  1535. });
  1536. it('invalid check sum', function() {
  1537. this.$issn.val('0032-147X');
  1538. this.bv.validate();
  1539. expect(this.bv.isValidField('issn')).toEqual(false);
  1540. });
  1541. });