diff --git a/src/ng/directive/input.js b/src/ng/directive/input.js index 068079fb1e51..a13a5fc23705 100644 --- a/src/ng/directive/input.js +++ b/src/ng/directive/input.js @@ -2473,8 +2473,11 @@ var maxlengthDirective = function() { maxlength = int(value) || 0; ctrl.$validate(); }); - ctrl.$validators.maxlength = function(value) { - return ctrl.$isEmpty(value) || value.length <= maxlength; + ctrl.$validators.maxlength = function(modelValue, viewValue) { + if (!isString(modelValue)) { + modelValue = viewValue; + } + return ctrl.$isEmpty(modelValue) || modelValue.length <= maxlength; }; } }; @@ -2492,8 +2495,11 @@ var minlengthDirective = function() { minlength = int(value) || 0; ctrl.$validate(); }); - ctrl.$validators.minlength = function(value) { - return ctrl.$isEmpty(value) || value.length >= minlength; + ctrl.$validators.minlength = function(modelValue, viewValue) { + if (!isString(modelValue)) { + modelValue = viewValue; + } + return ctrl.$isEmpty(modelValue) || modelValue.length >= minlength; }; } }; diff --git a/test/ng/directive/inputSpec.js b/test/ng/directive/inputSpec.js index ec09d76e07d8..809590bd95de 100644 --- a/test/ng/directive/inputSpec.js +++ b/test/ng/directive/inputSpec.js @@ -2909,6 +2909,97 @@ describe('input', function() { expect(scope.form.alias.$error.required).toBeTruthy(); }); }); + + describe('minlength', function() { + + it('should invalidate values that are shorter than the given minlength', function() { + compileInput(''); + + changeInputValueTo('12'); + expect(inputElm).toBeInvalid(); + + changeInputValueTo('123'); + expect(inputElm).toBeValid(); + }); + + it('should listen on ng-minlength when minlength is observed', function() { + var value = 0; + compileInput(''); + attrs.$observe('minlength', function(v) { + value = int(attrs.minlength); + }); + + scope.$apply(function() { + scope.min = 5; + }); + + expect(value).toBe(5); + }); + + it('should observe the standard minlength attribute and register it as a validator on the model', function() { + compileInput(''); + scope.$apply(function() { + scope.min = 10; + }); + + changeInputValueTo('12345'); + expect(inputElm).toBeInvalid(); + expect(scope.form.input.$error.minlength).toBe(true); + + scope.$apply(function() { + scope.min = 5; + }); + + expect(inputElm).toBeValid(); + expect(scope.form.input.$error.minlength).not.toBe(true); + }); + }); + + + describe('maxlength', function() { + + it('should invalidate values that are longer than the given maxlength', function() { + compileInput(''); + + changeInputValueTo('12345678'); + expect(inputElm).toBeInvalid(); + + changeInputValueTo('123'); + expect(inputElm).toBeValid(); + }); + + it('should listen on ng-maxlength when maxlength is observed', function() { + var value = 0; + compileInput(''); + attrs.$observe('maxlength', function(v) { + value = int(attrs.maxlength); + }); + + scope.$apply(function() { + scope.max = 10; + }); + + expect(value).toBe(10); + }); + + it('should observe the standard maxlength attribute and register it as a validator on the model', function() { + compileInput(''); + scope.$apply(function() { + scope.max = 1; + }); + + changeInputValueTo('12345'); + expect(inputElm).toBeInvalid(); + expect(scope.form.input.$error.maxlength).toBe(true); + + scope.$apply(function() { + scope.max = 6; + }); + + expect(inputElm).toBeValid(); + expect(scope.form.input.$error.maxlength).not.toBe(true); + }); + }); }); describe('email', function() {