mirror of
https://github.com/balena-io/balena-cli.git
synced 2025-01-31 00:24:15 +00:00
Merge pull request #1736 from balena-io/validation-test-coverage
Add test coverage for validation module
This commit is contained in:
commit
66b9f5a337
@ -17,38 +17,207 @@
|
||||
|
||||
import { expect } from 'chai';
|
||||
import { ExpectedError } from '../../build/errors';
|
||||
import { parseAsInteger } from '../../build/utils/validation';
|
||||
import * as v from '../../build/utils/validation';
|
||||
|
||||
describe('parseAsInteger() function', function() {
|
||||
describe('validateEmail() function', () => {
|
||||
it('should reject invalid email addresses with a message', () => {
|
||||
const errorMessage = 'Email is not valid';
|
||||
expect(v.validateEmail('test.com')).to.equal(errorMessage);
|
||||
expect(v.validateEmail('@test.com')).to.equal(errorMessage);
|
||||
expect(v.validateEmail('test@')).to.equal(errorMessage);
|
||||
expect(v.validateEmail('test@@test.com')).to.equal(errorMessage);
|
||||
expect(v.validateEmail('1234')).to.equal(errorMessage);
|
||||
expect(v.validateEmail('')).to.equal(errorMessage);
|
||||
|
||||
// Note, currently does not validate domains well, and allows these invalid patterns:
|
||||
// - test@test
|
||||
// - test@test..com
|
||||
});
|
||||
|
||||
it('should return true for valid emails', () => {
|
||||
expect(v.validateEmail('test@test.com')).to.equal(true);
|
||||
expect(v.validateEmail('t.e.s.t@test.com')).to.equal(true);
|
||||
expect(v.validateEmail('test+test@test.com')).to.equal(true);
|
||||
expect(v.validateEmail('test@test.io')).to.equal(true);
|
||||
});
|
||||
});
|
||||
|
||||
describe('validatePassword() function', () => {
|
||||
it('should reject passwords shorter than 8 characters, with a message', () => {
|
||||
const errorMessage = 'Password should be 8 characters long';
|
||||
expect(v.validatePassword('abc')).to.equal(errorMessage);
|
||||
expect(v.validatePassword('')).to.equal(errorMessage);
|
||||
});
|
||||
|
||||
it('should return true for passwords of 8 characters or more', () => {
|
||||
expect(v.validatePassword('abcdefgh')).to.equal(true);
|
||||
expect(v.validatePassword('abcdefghi')).to.equal(true);
|
||||
});
|
||||
});
|
||||
|
||||
describe('validateApplicationName() function', () => {
|
||||
it('should reject applications names shorter than 4 characters, with a message', () => {
|
||||
const errorMessage = 'The application name should be at least 4 characters';
|
||||
expect(v.validateApplicationName('abc')).to.equal(errorMessage);
|
||||
expect(v.validateApplicationName('')).to.equal(errorMessage);
|
||||
});
|
||||
|
||||
it('should return false for application names with characters other than `a-z,A-Z,0-9,_-`', () => {
|
||||
expect(v.validateApplicationName('abcd.')).to.equal(false);
|
||||
expect(v.validateApplicationName('abcd$')).to.equal(false);
|
||||
expect(v.validateApplicationName('ab cd')).to.equal(false);
|
||||
expect(v.validateApplicationName('(abcd)')).to.equal(false);
|
||||
});
|
||||
|
||||
it('should return true for valid application names', () => {
|
||||
expect(v.validateApplicationName('Test-Application1')).to.equal(true);
|
||||
expect(v.validateApplicationName('test_application2')).to.equal(true);
|
||||
});
|
||||
});
|
||||
|
||||
describe('validateIPAddress() function', () => {
|
||||
it('should return false for invalid IP addresses', () => {
|
||||
expect(v.validateIPAddress('')).to.equal(false);
|
||||
expect(v.validateIPAddress('abc')).to.equal(false);
|
||||
expect(v.validateIPAddress('127')).to.equal(false);
|
||||
expect(v.validateIPAddress('127.0')).to.equal(false);
|
||||
expect(v.validateIPAddress('127.0.0')).to.equal(false);
|
||||
expect(v.validateIPAddress('127..0.0.1')).to.equal(false);
|
||||
|
||||
// Note,
|
||||
// - incorrectly allows leading zeros, e.g. 127.0.000.001
|
||||
// - Allows IP and port, e.g. 127.0.0.1:80
|
||||
});
|
||||
|
||||
it('should return true for valid IP addresses', () => {
|
||||
expect(v.validateIPAddress('127.0.0.1')).to.equal(true);
|
||||
expect(v.validateIPAddress('192.168.0.1')).to.equal(true);
|
||||
expect(v.validateIPAddress('1.1.1.1')).to.equal(true);
|
||||
|
||||
// Note, does not support IPv6 addresses.
|
||||
});
|
||||
});
|
||||
|
||||
describe('validateDotLocalUrl() function', () => {
|
||||
it('should return false for invalid dot local URLs', () => {
|
||||
expect(v.validateDotLocalUrl('')).to.equal(false);
|
||||
expect(v.validateDotLocalUrl('abc')).to.equal(false);
|
||||
expect(v.validateDotLocalUrl('abc123local')).to.equal(false);
|
||||
expect(v.validateDotLocalUrl('abc123.loca')).to.equal(false);
|
||||
});
|
||||
|
||||
it('should return true for valid dot local URLs', () => {
|
||||
expect(v.validateDotLocalUrl('820b04a.local')).to.equal(true);
|
||||
expect(v.validateDotLocalUrl('aaaaaaa.local')).to.equal(true);
|
||||
expect(v.validateDotLocalUrl('1234567.local')).to.equal(true);
|
||||
});
|
||||
});
|
||||
|
||||
describe('validateLongUuid() function', () => {
|
||||
it('should return false for strings with length other than 32 or 64', () => {
|
||||
expect(v.validateLongUuid('')).to.equal(false);
|
||||
expect(v.validateLongUuid('abc')).to.equal(false);
|
||||
expect(v.validateLongUuid('a'.repeat(31))).to.equal(false);
|
||||
expect(v.validateLongUuid('a'.repeat(33))).to.equal(false);
|
||||
expect(v.validateLongUuid('a'.repeat(63))).to.equal(false);
|
||||
expect(v.validateLongUuid('a'.repeat(65))).to.equal(false);
|
||||
});
|
||||
|
||||
it('should return false for strings with characters other than a-z,0-9', () => {
|
||||
expect(v.validateLongUuid('a'.repeat(31) + 'A')).to.equal(false);
|
||||
expect(v.validateLongUuid('a'.repeat(31) + '.')).to.equal(false);
|
||||
expect(v.validateLongUuid('a'.repeat(31) + '-')).to.equal(false);
|
||||
expect(v.validateLongUuid('a'.repeat(31) + '_')).to.equal(false);
|
||||
});
|
||||
|
||||
it('should return true for valid long UUIDs', () => {
|
||||
expect(v.validateLongUuid('8ab84942d20b4753e08243a9e3a177e2')).to.equal(
|
||||
true,
|
||||
);
|
||||
expect(
|
||||
v.validateLongUuid('8ab84942d20b4753e08243a9e3a177e2'.repeat(2)),
|
||||
).to.equal(true);
|
||||
});
|
||||
});
|
||||
|
||||
describe('validateShortUuid() function', () => {
|
||||
it('should return false for strings with length other than 7', () => {
|
||||
expect(v.validateShortUuid('')).to.equal(false);
|
||||
expect(v.validateShortUuid('abc')).to.equal(false);
|
||||
expect(v.validateShortUuid('a'.repeat(6))).to.equal(false);
|
||||
expect(v.validateShortUuid('a'.repeat(8))).to.equal(false);
|
||||
});
|
||||
|
||||
it('should return false for strings with characters other than a-z,0-9', () => {
|
||||
expect(v.validateShortUuid('a'.repeat(31) + 'A')).to.equal(false);
|
||||
expect(v.validateShortUuid('a'.repeat(31) + '.')).to.equal(false);
|
||||
expect(v.validateShortUuid('a'.repeat(31) + '-')).to.equal(false);
|
||||
expect(v.validateShortUuid('a'.repeat(31) + '_')).to.equal(false);
|
||||
});
|
||||
|
||||
it('should return true for valid short UUIDs', () => {
|
||||
expect(v.validateShortUuid('8ab8494')).to.equal(true);
|
||||
});
|
||||
});
|
||||
|
||||
describe('validateUuid() function', () => {
|
||||
it('should return false for strings with length other than 7, 32 or 64', () => {
|
||||
expect(v.validateUuid('')).to.equal(false);
|
||||
expect(v.validateUuid('abc')).to.equal(false);
|
||||
expect(v.validateUuid('a'.repeat(6))).to.equal(false);
|
||||
expect(v.validateUuid('a'.repeat(8))).to.equal(false);
|
||||
expect(v.validateUuid('a'.repeat(31))).to.equal(false);
|
||||
expect(v.validateUuid('a'.repeat(33))).to.equal(false);
|
||||
expect(v.validateUuid('a'.repeat(63))).to.equal(false);
|
||||
expect(v.validateUuid('a'.repeat(65))).to.equal(false);
|
||||
});
|
||||
|
||||
it('should return false for strings with characters other than a-z,0-9', () => {
|
||||
expect(v.validateUuid('a'.repeat(31) + 'A')).to.equal(false);
|
||||
expect(v.validateUuid('a'.repeat(31) + '.')).to.equal(false);
|
||||
expect(v.validateUuid('a'.repeat(31) + '-')).to.equal(false);
|
||||
expect(v.validateUuid('a'.repeat(31) + '_')).to.equal(false);
|
||||
});
|
||||
|
||||
it('should return true for valid UUIDs', () => {
|
||||
expect(v.validateUuid('8ab8494')).to.equal(true);
|
||||
expect(v.validateUuid('8ab84942d20b4753e08243a9e3a177e2')).to.equal(true);
|
||||
expect(
|
||||
v.validateUuid('8ab84942d20b4753e08243a9e3a177e2'.repeat(2)),
|
||||
).to.equal(true);
|
||||
});
|
||||
});
|
||||
|
||||
describe('parseAsInteger() function', () => {
|
||||
it('should reject non-numeric characters', () => {
|
||||
expect(() => parseAsInteger('abc')).to.throw(ExpectedError);
|
||||
expect(() => parseAsInteger('1a')).to.throw(ExpectedError);
|
||||
expect(() => parseAsInteger('a1')).to.throw(ExpectedError);
|
||||
expect(() => parseAsInteger('a')).to.throw(ExpectedError);
|
||||
expect(() => parseAsInteger('1.0')).to.throw(ExpectedError);
|
||||
expect(() => v.parseAsInteger('abc')).to.throw(ExpectedError);
|
||||
expect(() => v.parseAsInteger('1a')).to.throw(ExpectedError);
|
||||
expect(() => v.parseAsInteger('a1')).to.throw(ExpectedError);
|
||||
expect(() => v.parseAsInteger('a')).to.throw(ExpectedError);
|
||||
expect(() => v.parseAsInteger('1.0')).to.throw(ExpectedError);
|
||||
});
|
||||
|
||||
it('should reject leading zeros', () => {
|
||||
expect(() => parseAsInteger('01')).to.throw(ExpectedError);
|
||||
expect(() => parseAsInteger('001')).to.throw(ExpectedError);
|
||||
expect(() => v.parseAsInteger('01')).to.throw(ExpectedError);
|
||||
expect(() => v.parseAsInteger('001')).to.throw(ExpectedError);
|
||||
});
|
||||
|
||||
it('should throw with specific message when param name passed', () => {
|
||||
expect(() => parseAsInteger('abc')).to.throw(
|
||||
expect(() => v.parseAsInteger('abc')).to.throw(
|
||||
'The parameter must be an integer.',
|
||||
);
|
||||
});
|
||||
|
||||
it('should throw with general message when no param name passed', () => {
|
||||
expect(() => parseAsInteger('abc', 'foo')).to.throw(
|
||||
expect(() => v.parseAsInteger('abc', 'foo')).to.throw(
|
||||
"The parameter 'foo' must be an integer.",
|
||||
);
|
||||
});
|
||||
|
||||
it('should parse integers to number type', () => {
|
||||
expect(parseAsInteger('100')).to.equal(100);
|
||||
expect(parseAsInteger('100')).to.be.a('number');
|
||||
expect(parseAsInteger('0')).to.equal(0);
|
||||
expect(parseAsInteger('0')).to.be.a('number');
|
||||
expect(v.parseAsInteger('100')).to.equal(100);
|
||||
expect(v.parseAsInteger('100')).to.be.a('number');
|
||||
expect(v.parseAsInteger('0')).to.equal(0);
|
||||
expect(v.parseAsInteger('0')).to.be.a('number');
|
||||
});
|
||||
});
|
||||
|
Loading…
x
Reference in New Issue
Block a user