Skip to content

Commit

Permalink
test(definitions): HTTP Bearer
Browse files Browse the repository at this point in the history
  • Loading branch information
Pakisan committed May 21, 2024
1 parent 18478b4 commit 15104d1
Show file tree
Hide file tree
Showing 7 changed files with 99 additions and 0 deletions.
1 change: 1 addition & 0 deletions test/definitions/3.0.0/security/httpBearer/empty.json
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{}
11 changes: 11 additions & 0 deletions test/definitions/3.0.0/security/httpBearer/extended.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
{
"type": "http",
"description": "http",
"scheme": "bearer",
"bearerFormat": "JWT",
"x-number": 0,
"x-string": "",
"x-object": {
"property": {}
}
}
66 changes: 66 additions & 0 deletions test/definitions/3.0.0/security/httpBearer/httpBearer.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
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/BearerHTTPSecurityScheme.json');
const validator = ajv
.addMetaSchema(require('../../../../../definitions/3.0.0/schema.json'))
.addSchema(require('../../../../../definitions/3.0.0/specificationExtension.json'))
.compile(jsonSchema);

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

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

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

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

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

assert(validationResult === true, 'HTTP Bearer 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, 'HTTP Bearer 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, 'HTTP Bearer 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,4 @@
{
"type": "http",
"scheme": "bearer"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
{
"description": "http",
"bearerFormat": "JWT"
}
12 changes: 12 additions & 0 deletions test/definitions/3.0.0/security/httpBearer/wrongly extended.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
{
"type": "http",
"description": "http",
"scheme": "bearer",
"bearerFormat": "JWT",
"x-number": 0,
"x-string": "",
"x-object": {
"property": {}
},
"ext-number": 1
}
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 @@ -10,4 +10,5 @@ describe('Security Schemes', () => {
require('./userPassword/userPassword.js');
require('./x509/x509.js');
require('./httpApiKey/httpApiKey.js');
require('./httpBearer/httpBearer.js');
});

0 comments on commit 15104d1

Please sign in to comment.