Skip to content

Commit

Permalink
test(definitions): user password
Browse files Browse the repository at this point in the history
  • Loading branch information
Pakisan committed May 21, 2024
1 parent 73dfdfd commit ef8e631
Show file tree
Hide file tree
Showing 7 changed files with 91 additions and 0 deletions.
1 change: 1 addition & 0 deletions test/definitions/3.0.0/security/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,5 @@ describe('Security Schemes', () => {
require('./scramSha256/scramSha256.js');
require('./scramSha512/scramSha512.js');
require('./symmetricEncryption/symmetricEncryption.js');
require('./userPassword/userPassword.js');
});
1 change: 1 addition & 0 deletions test/definitions/3.0.0/security/userPassword/empty.json
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{}
9 changes: 9 additions & 0 deletions test/definitions/3.0.0/security/userPassword/extended.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
{
"type": "userPassword",
"description": "userPassword",
"x-number": 0,
"x-string": "",
"x-object": {
"property": {}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"type": "userPassword"
}
64 changes: 64 additions & 0 deletions test/definitions/3.0.0/security/userPassword/userPassword.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
const Ajv = require('ajv');
const assert = require('assert');
const addFormats = require('ajv-formats');
const fs = require('fs');

const ajv = new Ajv({
jsonPointers: true,
allErrors: true,
schemaId: '$id',
logger: false,
validateFormats: true,
strict: false,
});
addFormats(ajv);

const jsonSchema = require('../../../../../definitions/3.0.0/userPassword.json');
const validator = ajv
.addMetaSchema(require('../../../../../definitions/3.0.0/schema.json'))
.addSchema(require('../../../../../definitions/3.0.0/specificationExtension.json'))
.compile(jsonSchema);

describe('User Password', () => {
it('empty', () => {
const model = JSON.parse(fs.readFileSync(`${__dirname}/empty.json`, 'utf-8'));
const validationResult = validator(model);

assert(validationResult === false, 'User Password with empty body is not valid');
assert(validator.errors[0].message === 'must have required property \'type\'');
assert(validator.errors.length === 1);
});

it('without required properties', () => {
const model = JSON.parse(fs.readFileSync(`${__dirname}/without required properties.json`, 'utf-8'));
const validationResult = validator(model);

assert(validationResult === false, 'User Password without required properties is not valid');
assert(validator.errors[0].message === 'must have required property \'type\'');
assert(validator.errors.length === 1);
});

it('only required properties', () => {
const model = JSON.parse(fs.readFileSync(`${__dirname}/only required properties.json`, 'utf-8'));
const validationResult = validator(model);

assert(validationResult === true, 'User Password is valid with only required properties');
});

it('extended', () => {
const model = JSON.parse(fs.readFileSync(`${__dirname}/extended.json`, 'utf-8'));
const validationResult = validator(model);

assert(validationResult === true, 'User Password can be extended');
});

it('wrongly extended', () => {
const model = JSON.parse(fs.readFileSync(`${__dirname}/wrongly extended.json`, 'utf-8'));
const validationResult = validator(model);

assert(validationResult === false, 'User Password is not valid when was wrongly extended');
assert(validator.errors[0].message === 'must NOT have additional properties');
assert(validator.errors[0].params.additionalProperty === 'ext-number');
assert(validator.errors.length === 1);
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"description": "userPassword"
}
10 changes: 10 additions & 0 deletions test/definitions/3.0.0/security/userPassword/wrongly extended.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"type": "userPassword",
"description": "userPassword",
"x-number": 0,
"x-string": "",
"x-object": {
"property": {}
},
"ext-number": 1
}

0 comments on commit ef8e631

Please sign in to comment.