jsdoc/test/specs/documentation/moduleisconstructor.js
Jeff Williams aa0b6c1bfa switch to new-ish ECMAScript syntax
With help from Lebab, plus a lot of manual cleanup. (And more cleanup to come, I'm sure.)
2019-01-15 18:39:10 -08:00

90 lines
3.8 KiB
JavaScript

describe('module that exports a constructor', () => {
describe('pre-ES2015 module', () => {
const docSet = jasmine.getDocSetFromFile('test/fixtures/moduleisconstructor.js');
const modules = docSet.doclets.filter(({kind}) => kind === 'module');
const classes = docSet.doclets.filter(({kind}) => kind === 'class');
const getId = docSet.getByLongname('module:mymodule/config#getId')[0];
const id = docSet.getByLongname('module:mymodule/config#id')[0];
it('should include one doclet whose kind is "module"', () => {
expect(modules.length).toBe(1);
expect(modules[0].kind).toBe('module');
});
it('should include one doclet whose kind is "class"', () => {
expect(classes.length).toBe(1);
expect(classes[0].kind).toBe('class');
});
describe('class doclet', () => {
it('should include a "description" property that contains the constructor description', () => {
expect(classes[0].description).toEqual('Create a new configuration.');
});
it('should include a "classdesc" property', () => {
expect(classes[0].classdesc).toEqual('Describe the class here.');
});
});
describe('module doclet', () => {
it('should include a "description" property that contains the module description', () => {
expect(modules[0].description).toEqual('Describe the module here.');
});
});
describe('instance members', () => {
it('should use the correct longname for instance properties', () => {
expect(id.description).toBe('Document me.');
});
it('should use the correct longname for instance methods', () => {
expect(getId.description).toBe('Get the configuration ID.');
});
});
});
describe('ES2015 module', () => {
const docSet = jasmine.getDocSetFromFile('test/fixtures/moduleisconstructor2.js');
const modules = docSet.doclets.filter(({kind}) => kind === 'module');
const classes = docSet.doclets.filter(({kind, classdesc, description}) => kind === 'class' && classdesc && description);
const getId = docSet.getByLongname('module:mymodule/config#getId')[0];
const id = docSet.getByLongname('module:mymodule/config#id')[0];
it('should include one doclet whose kind is "module"', () => {
expect(modules.length).toBe(1);
expect(modules[0].kind).toBe('module');
});
it('should include one complete class doclet', () => {
expect(classes.length).toBe(1);
expect(classes[0].kind).toBe('class');
});
describe('class doclet', () => {
it('should include a "description" property that contains the constructor description', () => {
expect(classes[0].description).toEqual('Create a new configuration.');
});
it('should include a "classdesc" property', () => {
expect(classes[0].classdesc).toEqual('Describe the class here.');
});
});
describe('module doclet', () => {
it('should include a "description" property that contains the module description', () => {
expect(modules[0].description).toEqual('Describe the module here.');
});
});
describe('instance members', () => {
it('should use the correct longname for instance properties', () => {
expect(id.description).toBe('Document me.');
});
it('should use the correct longname for instance methods', () => {
expect(getId.description).toBe('Get the configuration ID.');
});
});
});
});