2018-06-22 11:58:29 -04:00
|
|
|
const testPackage = require('../../helpers/test-package');
|
|
|
|
const processorFactory = require('./processPackages');
|
|
|
|
const Dgeni = require('dgeni');
|
|
|
|
|
|
|
|
describe('processPackages processor', () => {
|
|
|
|
|
|
|
|
it('should be available on the injector', () => {
|
|
|
|
const dgeni = new Dgeni([testPackage('angular-api-package')]);
|
|
|
|
const injector = dgeni.configureInjector();
|
|
|
|
const processor = injector.get('processPackages');
|
|
|
|
expect(processor.$process).toBeDefined();
|
2019-04-02 17:24:29 -04:00
|
|
|
expect(processor.$runAfter).toEqual(['processAliasDocs', 'collectPackageContentDocsProcessor']);
|
|
|
|
expect(processor.$runBefore).toEqual(['rendering-docs', 'checkContentRules']);
|
2018-06-22 11:58:29 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should change `module` docs to `package` docs', () => {
|
2019-04-02 17:24:29 -04:00
|
|
|
const processor = processorFactory({ packageContentFiles: {} });
|
2018-06-22 11:58:29 -04:00
|
|
|
const docs = [
|
|
|
|
{ fileInfo: { filePath: 'some/a' }, docType: 'module', id: 'a' },
|
|
|
|
{ fileInfo: { filePath: 'some/b' }, docType: 'module', id: 'b' },
|
|
|
|
{ docType: 'other', id: 'c' },
|
|
|
|
];
|
2019-04-02 17:24:29 -04:00
|
|
|
processor.$process(docs);
|
|
|
|
expect(docs).toEqual([
|
2018-06-22 11:58:29 -04:00
|
|
|
jasmine.objectContaining({ docType: 'package', id: 'a' }),
|
|
|
|
jasmine.objectContaining({ docType: 'package', id: 'b' }),
|
|
|
|
jasmine.objectContaining({ docType: 'other', id: 'c' }),
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should attach the relevant package contents to the package doc', () => {
|
|
|
|
const docs = [
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-1/index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-1',
|
|
|
|
someProp: 'foo',
|
|
|
|
},
|
|
|
|
{
|
2019-04-02 17:24:29 -04:00
|
|
|
fileInfo: { filePath: 'some/package-2/index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-2',
|
|
|
|
},
|
|
|
|
];
|
|
|
|
const packageContentFiles = {
|
|
|
|
'some/package-1': {
|
2018-06-22 11:58:29 -04:00
|
|
|
fileInfo: { filePath: 'some/package-1/PACKAGE.md' },
|
|
|
|
docType: 'package-content',
|
|
|
|
id: 'package-1/PACKAGE.md',
|
|
|
|
shortDescription: 'some short description',
|
|
|
|
description: 'some description',
|
|
|
|
see: [ 'a', 'b' ],
|
2019-04-02 17:24:29 -04:00
|
|
|
}
|
|
|
|
};
|
|
|
|
const processor = processorFactory({ packageContentFiles });
|
|
|
|
processor.$process(docs);
|
2018-06-22 11:58:29 -04:00
|
|
|
|
|
|
|
const package1 = jasmine.objectContaining({
|
|
|
|
fileInfo: { filePath: 'some/package-1/PACKAGE.md' },
|
|
|
|
docType: 'package',
|
|
|
|
name: '@angular/package-1',
|
|
|
|
id: 'package-1',
|
|
|
|
someProp: 'foo',
|
|
|
|
shortDescription: 'some short description',
|
|
|
|
description: 'some description',
|
|
|
|
see: [ 'a', 'b' ],
|
|
|
|
isPrimaryPackage: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
const package2 = jasmine.objectContaining({
|
|
|
|
fileInfo: { filePath: 'some/package-2/index' },
|
|
|
|
docType: 'package',
|
|
|
|
name: '@angular/package-2',
|
|
|
|
id: 'package-2',
|
|
|
|
isPrimaryPackage: true,
|
|
|
|
});
|
|
|
|
|
2019-04-02 17:24:29 -04:00
|
|
|
expect(docs).toEqual([package1, package2]);
|
2018-06-22 11:58:29 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should compute primary and second package info', () => {
|
|
|
|
const docs = [
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-1/index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-1',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-1/sub-1index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-1/sub-1',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-1/sub-2index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-1/sub-2',
|
|
|
|
},
|
|
|
|
];
|
2019-04-02 17:24:29 -04:00
|
|
|
const processor = processorFactory({ packageContentFiles: {} });
|
|
|
|
processor.$process(docs);
|
2018-06-22 11:58:29 -04:00
|
|
|
|
2019-04-02 17:24:29 -04:00
|
|
|
expect(docs[0].isPrimaryPackage).toBe(true);
|
|
|
|
expect(docs[1].isPrimaryPackage).toBe(false);
|
|
|
|
expect(docs[2].isPrimaryPackage).toBe(false);
|
2018-06-22 11:58:29 -04:00
|
|
|
|
2019-04-02 17:24:29 -04:00
|
|
|
expect(docs[0].packageInfo.primary).toBe(docs[0]);
|
|
|
|
expect(docs[1].packageInfo.primary).toBe(docs[0]);
|
|
|
|
expect(docs[2].packageInfo.primary).toBe(docs[0]);
|
2018-06-22 11:58:29 -04:00
|
|
|
|
2019-04-02 17:24:29 -04:00
|
|
|
expect(docs[0].packageInfo.secondary).toEqual([docs[1], docs[2]]);
|
|
|
|
expect(docs[1].packageInfo.secondary).toEqual([docs[1], docs[2]]);
|
|
|
|
expect(docs[2].packageInfo.secondary).toEqual([docs[1], docs[2]]);
|
2018-06-22 11:58:29 -04:00
|
|
|
});
|
|
|
|
|
2018-09-21 04:08:58 -04:00
|
|
|
it('should partition the exports of packages into groups, sorted by id', () => {
|
2018-06-22 11:58:29 -04:00
|
|
|
const docs = [
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/x' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'x',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'function', id: 'function-1' },
|
|
|
|
{ docType: 'directive', id: 'directive-2' },
|
|
|
|
{ docType: 'decorator', id: 'decorator-1' },
|
|
|
|
{ docType: 'class', id: 'class-1' },
|
2018-09-21 04:08:58 -04:00
|
|
|
{ docType: 'directive', id: 'directive-1' },
|
2018-06-22 11:58:29 -04:00
|
|
|
{ docType: 'type-alias', id: 'type-alias-1' },
|
|
|
|
{ docType: 'class', id: 'class-2' },
|
|
|
|
{ docType: 'pipe', id: 'pipe-1' },
|
|
|
|
{ docType: 'const', id: 'const-1' },
|
2018-09-21 04:08:58 -04:00
|
|
|
{ docType: 'interface', id: 'interface-2' },
|
2018-06-22 11:58:29 -04:00
|
|
|
{ docType: 'const', id: 'const-2' },
|
|
|
|
{ docType: 'enum', id: 'enum-1' },
|
|
|
|
{ docType: 'interface', id: 'interface-1' },
|
|
|
|
]
|
|
|
|
},
|
|
|
|
];
|
2019-04-02 17:24:29 -04:00
|
|
|
const processor = processorFactory({ packageContentFiles: {} });
|
|
|
|
processor.$process(docs);
|
2018-06-22 11:58:29 -04:00
|
|
|
|
2019-04-02 17:24:29 -04:00
|
|
|
expect(docs[0].decorators).toEqual([
|
2018-06-22 11:58:29 -04:00
|
|
|
{ docType: 'decorator', id: 'decorator-1' },
|
|
|
|
]);
|
2019-04-02 17:24:29 -04:00
|
|
|
expect(docs[0].functions).toEqual([
|
2018-06-22 11:58:29 -04:00
|
|
|
{ docType: 'function', id: 'function-1' },
|
|
|
|
]);
|
2019-04-02 17:24:29 -04:00
|
|
|
expect(docs[0].structures).toEqual([
|
2018-06-22 11:58:29 -04:00
|
|
|
{ docType: 'enum', id: 'enum-1' },
|
|
|
|
{ docType: 'interface', id: 'interface-1' },
|
|
|
|
{ docType: 'interface', id: 'interface-2' },
|
|
|
|
]);
|
2019-04-02 17:24:29 -04:00
|
|
|
expect(docs[0].directives).toEqual([
|
2018-06-22 11:58:29 -04:00
|
|
|
{ docType: 'directive', id: 'directive-1' },
|
|
|
|
{ docType: 'directive', id: 'directive-2' },
|
|
|
|
]);
|
2019-04-02 17:24:29 -04:00
|
|
|
expect(docs[0].pipes).toEqual([
|
2018-06-22 11:58:29 -04:00
|
|
|
{ docType: 'pipe', id: 'pipe-1' },
|
|
|
|
]);
|
2019-04-02 17:24:29 -04:00
|
|
|
expect(docs[0].types).toEqual([
|
2018-06-22 11:58:29 -04:00
|
|
|
{ docType: 'const', id: 'const-1' },
|
|
|
|
{ docType: 'const', id: 'const-2' },
|
2018-09-21 04:08:58 -04:00
|
|
|
{ docType: 'type-alias', id: 'type-alias-1' },
|
2018-06-22 11:58:29 -04:00
|
|
|
]);
|
|
|
|
});
|
2018-09-17 12:37:18 -04:00
|
|
|
|
2021-02-06 08:59:12 -05:00
|
|
|
it('should compute whether the entry point has public exports', () => {
|
|
|
|
const docs = [
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-1/index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-1',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'class', id: 'class-1' },
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-1/sub-1index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-1/sub-1',
|
|
|
|
exports: [],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-2/index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-2',
|
|
|
|
exports: [],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-1/sub-1index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-1/sub-1',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'const', id: 'const-2' },
|
|
|
|
{ docType: 'enum', id: 'enum-3' },
|
|
|
|
],
|
|
|
|
},
|
|
|
|
];
|
|
|
|
const processor = processorFactory({ packageContentFiles: {} });
|
|
|
|
processor.$process(docs);
|
|
|
|
|
|
|
|
expect(docs[0].hasPublicExports).toBeTrue();
|
|
|
|
expect(docs[1].hasPublicExports).toBeFalse();
|
|
|
|
expect(docs[2].hasPublicExports).toBeFalse();
|
|
|
|
expect(docs[3].hasPublicExports).toBeTrue();
|
|
|
|
});
|
|
|
|
|
2018-09-17 12:37:18 -04:00
|
|
|
it('should compute the deprecated status of each entry point', () => {
|
|
|
|
const docs = [
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-1/index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-1',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'class', id: 'class-1', deprecated: true },
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-1/sub-1index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-1/sub-1',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'class', id: 'class-2', deprecated: true },
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-2/index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-2',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'class', id: 'class-3' },
|
|
|
|
{ docType: 'class', id: 'class-4', deprecated: true },
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-3/index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-3',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'class', id: 'class-5' },
|
|
|
|
{ docType: 'class', id: 'class-6' },
|
|
|
|
]
|
|
|
|
},
|
2021-02-06 08:59:12 -05:00
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-4/index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-4',
|
|
|
|
exports: []
|
|
|
|
},
|
2018-09-17 12:37:18 -04:00
|
|
|
];
|
2019-04-02 17:24:29 -04:00
|
|
|
const processor = processorFactory({ packageContentFiles: {} });
|
|
|
|
processor.$process(docs);
|
2018-09-17 12:37:18 -04:00
|
|
|
|
2019-04-02 17:24:29 -04:00
|
|
|
expect(docs[0].deprecated).toBeTruthy();
|
|
|
|
expect(docs[1].deprecated).toBeTruthy();
|
|
|
|
expect(docs[2].deprecated).toBeUndefined();
|
|
|
|
expect(docs[3].deprecated).toBeUndefined();
|
2021-02-06 08:59:12 -05:00
|
|
|
expect(docs[4].deprecated).toBeUndefined();
|
2018-09-17 12:37:18 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should compute the deprecated status of packages', () => {
|
|
|
|
const docs = [
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-1/index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-1',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'class', id: 'class-1', deprecated: true },
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-1/sub-1index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-1/sub-1',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'class', id: 'class-2', deprecated: true },
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-2/index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-2',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'class', id: 'class-3', deprecated: true },
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-2/sub-1index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-2/sub-1',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'class', id: 'class-4', deprecated: false },
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-3/index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-3',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'class', id: 'class-5', deprecated: false },
|
|
|
|
]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fileInfo: { filePath: 'some/package-3/sub-1index' },
|
|
|
|
docType: 'module',
|
|
|
|
id: 'package-3/sub-1',
|
|
|
|
exports: [
|
|
|
|
{ docType: 'class', id: 'class-6', deprecated: true },
|
|
|
|
]
|
|
|
|
},
|
|
|
|
];
|
2019-04-02 17:24:29 -04:00
|
|
|
const processor = processorFactory({ packageContentFiles: {} });
|
|
|
|
processor.$process(docs);
|
|
|
|
expect(docs[0].packageDeprecated).toBe(true);
|
|
|
|
expect(docs[1].packageDeprecated).toBeUndefined();
|
|
|
|
expect(docs[2].packageDeprecated).toBe(false);
|
|
|
|
expect(docs[3].packageDeprecated).toBeUndefined();
|
|
|
|
expect(docs[4].packageDeprecated).toBe(false);
|
2018-09-17 12:37:18 -04:00
|
|
|
});
|
2018-06-22 11:58:29 -04:00
|
|
|
});
|