/* * Copyright (C) 2018-2019 StApps * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the Free * Software Foundation, version 3. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License along with * this program. If not, see . */ import {Logger} from '@openstapps/logger'; import {expect} from 'chai'; import {slow, suite, test, timeout} from 'mocha-typescript'; import {join} from 'path'; import {Converter, getValidatableTypesFromReflection} from '../src/schema'; process.on('unhandledRejection', (err) => { Logger.error('UNHANDLED REJECTION', err.stack); process.exit(1); }); @suite(timeout(20000), slow(10000)) export class SchemaSpec { @test async getSchema() { const converter = new Converter(join(__dirname, '..', 'src', 'resources')); const schema = converter.getSchema('Foo', '0.0.1'); expect(schema).to.be.deep.equal({ $schema: 'http://json-schema.org/draft-06/schema#', additionalProperties: false, definitions: { FooType: { description: 'This is a simple type declaration for\nusage in the Foo interace.', enum: [ 'Foo', ], type: 'string', }, SCFoo: { additionalProperties: false, description: 'This is a simple interface declaration for\ntesting the schema generation and validation.', properties: { lorem: { description: 'Dummy parameter', enum: [ 'ipsum', ], type: 'string', }, type: { $ref: '#/definitions/FooType', description: 'String literal type property', }, }, required: [ 'lorem', 'type', ], type: 'object', }, }, description: 'This is a simple interface declaration for\ntesting the schema generation and validation.', id: 'https://core.stapps.tu-berlin.de/v0.0.1/lib/schema/Foo.json', properties: { lorem: { description: 'Dummy parameter', enum: [ 'ipsum', ], type: 'string', }, type: { $ref: '#/definitions/FooType', description: 'String literal type property', }, }, required: [ 'lorem', 'type', ], type: 'object', }); } @test async getValidatableTypesFromReflection() { const reflection: any = { children: [ { children: [ { comment: { tags: [ { tagName: 'validatable', }, ], }, name: 'foo', }, { name: 'bar', }, ], }, { children: [ { name: 'foobar', }, ], }, ], }; const validatableTypes = getValidatableTypesFromReflection(reflection as any); expect(validatableTypes).to.be.deep.equal(['foo']); } }