refactor(compiler): bump metadata version to 4 (#19338)
Also adds auto upgrade from lower version based
on the .d.ts file (e.g. from version 3 to 4).
This is needed as we are now also capturing type aliases
in metadata files (and we rely on this),
see 6e3498ca8e
.
This commit is contained in:
parent
86ffacf7ce
commit
a75040d0a1
|
@ -15,6 +15,7 @@ export {getClassMembersFromDeclaration, getPipesTable, getSymbolQuery} from './s
|
||||||
export {Extractor} from './src/extractor';
|
export {Extractor} from './src/extractor';
|
||||||
export {VERSION} from './src/version';
|
export {VERSION} from './src/version';
|
||||||
|
|
||||||
|
export * from './src/metadata';
|
||||||
export * from './src/transformers/api';
|
export * from './src/transformers/api';
|
||||||
export * from './src/transformers/entry_points';
|
export * from './src/transformers/entry_points';
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@ import * as fs from 'fs';
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as ts from 'typescript';
|
import * as ts from 'typescript';
|
||||||
|
|
||||||
import {CollectorOptions, MetadataCollector, ModuleMetadata} from './metadata/index';
|
import {CollectorOptions, METADATA_VERSION, MetadataCollector, ModuleMetadata} from './metadata/index';
|
||||||
import {CompilerOptions} from './transformers/api';
|
import {CompilerOptions} from './transformers/api';
|
||||||
|
|
||||||
const EXT = /(\.ts|\.d\.ts|\.js|\.jsx|\.tsx)$/;
|
const EXT = /(\.ts|\.d\.ts|\.js|\.jsx|\.tsx)$/;
|
||||||
|
@ -76,9 +76,9 @@ export abstract class BaseAotCompilerHost<C extends BaseAotCompilerHostContext>
|
||||||
let metadatas = this.readMetadata(filePath);
|
let metadatas = this.readMetadata(filePath);
|
||||||
if (!metadatas) {
|
if (!metadatas) {
|
||||||
// If there is a .d.ts file but no metadata file we need to produce a
|
// If there is a .d.ts file but no metadata file we need to produce a
|
||||||
// v3 metadata from the .d.ts file as v3 includes the exports we need
|
// metadata from the .d.ts file as metadata files capture reexports
|
||||||
// to resolve symbols.
|
// (starting with v3).
|
||||||
metadatas = [this.upgradeVersion1Metadata(
|
metadatas = [this.upgradeMetadataWithDtsData(
|
||||||
{'__symbolic': 'module', 'version': 1, 'metadata': {}}, filePath)];
|
{'__symbolic': 'module', 'version': 1, 'metadata': {}}, filePath)];
|
||||||
}
|
}
|
||||||
return metadatas;
|
return metadatas;
|
||||||
|
@ -104,10 +104,11 @@ export abstract class BaseAotCompilerHost<C extends BaseAotCompilerHostContext>
|
||||||
const metadatas: ModuleMetadata[] = metadataOrMetadatas ?
|
const metadatas: ModuleMetadata[] = metadataOrMetadatas ?
|
||||||
(Array.isArray(metadataOrMetadatas) ? metadataOrMetadatas : [metadataOrMetadatas]) :
|
(Array.isArray(metadataOrMetadatas) ? metadataOrMetadatas : [metadataOrMetadatas]) :
|
||||||
[];
|
[];
|
||||||
const v1Metadata = metadatas.find(m => m.version === 1);
|
if (metadatas.length) {
|
||||||
let v3Metadata = metadatas.find(m => m.version === 3);
|
let maxMetadata = metadatas.reduce((p, c) => p.version > c.version ? p : c);
|
||||||
if (!v3Metadata && v1Metadata) {
|
if (maxMetadata.version < METADATA_VERSION) {
|
||||||
metadatas.push(this.upgradeVersion1Metadata(v1Metadata, dtsFilePath));
|
metadatas.push(this.upgradeMetadataWithDtsData(maxMetadata, dtsFilePath));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
this.resolverCache.set(dtsFilePath, metadatas);
|
this.resolverCache.set(dtsFilePath, metadatas);
|
||||||
return metadatas;
|
return metadatas;
|
||||||
|
@ -117,30 +118,44 @@ export abstract class BaseAotCompilerHost<C extends BaseAotCompilerHostContext>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private upgradeVersion1Metadata(v1Metadata: ModuleMetadata, dtsFilePath: string): ModuleMetadata {
|
private upgradeMetadataWithDtsData(oldMetadata: ModuleMetadata, dtsFilePath: string):
|
||||||
// patch up v1 to v3 by merging the metadata with metadata collected from the d.ts file
|
ModuleMetadata {
|
||||||
// as the only difference between the versions is whether all exports are contained in
|
// patch v1 to v3 by adding exports and the `extends` clause.
|
||||||
// the metadata and the `extends` clause.
|
// patch v3 to v4 by adding `interface` symbols for TypeAlias
|
||||||
let v3Metadata: ModuleMetadata = {'__symbolic': 'module', 'version': 3, 'metadata': {}};
|
let newMetadata: ModuleMetadata = {
|
||||||
if (v1Metadata.exports) {
|
'__symbolic': 'module',
|
||||||
v3Metadata.exports = v1Metadata.exports;
|
'version': METADATA_VERSION,
|
||||||
|
'metadata': {...oldMetadata.metadata},
|
||||||
|
};
|
||||||
|
if (oldMetadata.exports) {
|
||||||
|
newMetadata.exports = oldMetadata.exports;
|
||||||
|
}
|
||||||
|
if (oldMetadata.importAs) {
|
||||||
|
newMetadata.importAs = oldMetadata.importAs;
|
||||||
|
}
|
||||||
|
if (oldMetadata.origins) {
|
||||||
|
newMetadata.origins = oldMetadata.origins;
|
||||||
|
}
|
||||||
|
const dtsMetadata = this.getMetadataForSourceFile(dtsFilePath);
|
||||||
|
if (dtsMetadata) {
|
||||||
|
for (let prop in dtsMetadata.metadata) {
|
||||||
|
if (!newMetadata.metadata[prop]) {
|
||||||
|
newMetadata.metadata[prop] = dtsMetadata.metadata[prop];
|
||||||
}
|
}
|
||||||
for (let prop in v1Metadata.metadata) {
|
|
||||||
v3Metadata.metadata[prop] = v1Metadata.metadata[prop];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const exports = this.getMetadataForSourceFile(dtsFilePath);
|
// Only copy exports from exports from metadata prior to version 3.
|
||||||
if (exports) {
|
// Starting with version 3 the collector began collecting exports and
|
||||||
for (let prop in exports.metadata) {
|
// this should be redundant. Also, with bundler will rewrite the exports
|
||||||
if (!v3Metadata.metadata[prop]) {
|
// which will hoist the exports from modules referenced indirectly causing
|
||||||
v3Metadata.metadata[prop] = exports.metadata[prop];
|
// the imports to be different than the .d.ts files and using the .d.ts file
|
||||||
|
// exports would cause the StaticSymbolResolver to redirect symbols to the
|
||||||
|
// incorrect location.
|
||||||
|
if ((!oldMetadata.version || oldMetadata.version < 3) && dtsMetadata.exports) {
|
||||||
|
newMetadata.exports = dtsMetadata.exports;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (exports.exports) {
|
return newMetadata;
|
||||||
v3Metadata.exports = exports.exports;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return v3Metadata;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
loadResource(filePath: string): Promise<string>|string {
|
loadResource(filePath: string): Promise<string>|string {
|
||||||
|
|
|
@ -9,7 +9,7 @@ import * as path from 'path';
|
||||||
import * as ts from 'typescript';
|
import * as ts from 'typescript';
|
||||||
|
|
||||||
import {MetadataCollector} from '../metadata/collector';
|
import {MetadataCollector} from '../metadata/collector';
|
||||||
import {ClassMetadata, ConstructorMetadata, FunctionMetadata, MemberMetadata, MetadataEntry, MetadataError, MetadataImportedSymbolReferenceExpression, MetadataMap, MetadataObject, MetadataSymbolicExpression, MetadataSymbolicReferenceExpression, MetadataValue, MethodMetadata, ModuleExportMetadata, ModuleMetadata, VERSION, isClassMetadata, isConstructorMetadata, isFunctionMetadata, isInterfaceMetadata, isMetadataError, isMetadataGlobalReferenceExpression, isMetadataImportedSymbolReferenceExpression, isMetadataModuleReferenceExpression, isMetadataSymbolicExpression, isMethodMetadata} from '../metadata/schema';
|
import {ClassMetadata, ConstructorMetadata, FunctionMetadata, METADATA_VERSION, MemberMetadata, MetadataEntry, MetadataError, MetadataImportedSymbolReferenceExpression, MetadataMap, MetadataObject, MetadataSymbolicExpression, MetadataSymbolicReferenceExpression, MetadataValue, MethodMetadata, ModuleExportMetadata, ModuleMetadata, isClassMetadata, isConstructorMetadata, isFunctionMetadata, isInterfaceMetadata, isMetadataError, isMetadataGlobalReferenceExpression, isMetadataImportedSymbolReferenceExpression, isMetadataModuleReferenceExpression, isMetadataSymbolicExpression, isMethodMetadata} from '../metadata/schema';
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -114,7 +114,7 @@ export class MetadataBundler {
|
||||||
return {
|
return {
|
||||||
metadata: {
|
metadata: {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: VERSION,
|
version: METADATA_VERSION,
|
||||||
exports: exports.length ? exports : undefined, metadata, origins,
|
exports: exports.length ? exports : undefined, metadata, origins,
|
||||||
importAs: this.importAs !
|
importAs: this.importAs !
|
||||||
},
|
},
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
import * as ts from 'typescript';
|
import * as ts from 'typescript';
|
||||||
|
|
||||||
import {Evaluator, errorSymbol} from './evaluator';
|
import {Evaluator, errorSymbol} from './evaluator';
|
||||||
import {ClassMetadata, ConstructorMetadata, FunctionMetadata, InterfaceMetadata, MemberMetadata, MetadataEntry, MetadataError, MetadataMap, MetadataSymbolicBinaryExpression, MetadataSymbolicCallExpression, MetadataSymbolicExpression, MetadataSymbolicIfExpression, MetadataSymbolicIndexExpression, MetadataSymbolicPrefixExpression, MetadataSymbolicReferenceExpression, MetadataSymbolicSelectExpression, MetadataSymbolicSpreadExpression, MetadataValue, MethodMetadata, ModuleExportMetadata, ModuleMetadata, VERSION, isClassMetadata, isConstructorMetadata, isFunctionMetadata, isMetadataError, isMetadataGlobalReferenceExpression, isMetadataSymbolicExpression, isMetadataSymbolicReferenceExpression, isMetadataSymbolicSelectExpression, isMethodMetadata} from './schema';
|
import {ClassMetadata, ConstructorMetadata, FunctionMetadata, InterfaceMetadata, METADATA_VERSION, MemberMetadata, MetadataEntry, MetadataError, MetadataMap, MetadataSymbolicBinaryExpression, MetadataSymbolicCallExpression, MetadataSymbolicExpression, MetadataSymbolicIfExpression, MetadataSymbolicIndexExpression, MetadataSymbolicPrefixExpression, MetadataSymbolicReferenceExpression, MetadataSymbolicSelectExpression, MetadataSymbolicSpreadExpression, MetadataValue, MethodMetadata, ModuleExportMetadata, ModuleMetadata, isClassMetadata, isConstructorMetadata, isFunctionMetadata, isMetadataError, isMetadataGlobalReferenceExpression, isMetadataSymbolicExpression, isMetadataSymbolicReferenceExpression, isMetadataSymbolicSelectExpression, isMethodMetadata} from './schema';
|
||||||
import {Symbols} from './symbols';
|
import {Symbols} from './symbols';
|
||||||
|
|
||||||
const isStatic = (node: ts.Node) => ts.getCombinedModifierFlags(node) & ts.ModifierFlags.Static;
|
const isStatic = (node: ts.Node) => ts.getCombinedModifierFlags(node) & ts.ModifierFlags.Static;
|
||||||
|
@ -549,7 +549,7 @@ export class MetadataCollector {
|
||||||
}
|
}
|
||||||
const result: ModuleMetadata = {
|
const result: ModuleMetadata = {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: this.options.version || VERSION, metadata
|
version: this.options.version || METADATA_VERSION, metadata
|
||||||
};
|
};
|
||||||
if (exports) result.exports = exports;
|
if (exports) result.exports = exports;
|
||||||
return result;
|
return result;
|
||||||
|
|
|
@ -8,14 +8,15 @@
|
||||||
|
|
||||||
// Metadata Schema
|
// Metadata Schema
|
||||||
|
|
||||||
// If you make a backwards incompatible change to the schema, increment the VERSION number.
|
// If you make a backwards incompatible change to the schema, increment the METADTA_VERSION number.
|
||||||
|
|
||||||
// If you make a backwards compatible change to the metadata (such as adding an option field) then
|
// If you make a backwards compatible change to the metadata (such as adding an option field) then
|
||||||
// leave VERSION the same. If possible, as many versions of the metadata that can represent the
|
// leave METADATA_VERSION the same. If possible, supply as many versions of the metadata that can
|
||||||
// semantics of the file in an array. For example, when generating a version 2 file, if version 1
|
// represent the semantics of the file in an array. For example, when generating a version 2 file,
|
||||||
// can accurately represent the metadata, generate both version 1 and version 2 in an array.
|
// if version 1 can accurately represent the metadata, generate both version 1 and version 2 in
|
||||||
|
// an array.
|
||||||
|
|
||||||
export const VERSION = 3;
|
export const METADATA_VERSION = 4;
|
||||||
|
|
||||||
export type MetadataEntry = ClassMetadata | InterfaceMetadata | FunctionMetadata | MetadataValue;
|
export type MetadataEntry = ClassMetadata | InterfaceMetadata | FunctionMetadata | MetadataValue;
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
* found in the LICENSE file at https://angular.io/license
|
* found in the LICENSE file at https://angular.io/license
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import {ModuleMetadata} from '@angular/compiler-cli/src/metadata/index';
|
import {METADATA_VERSION, ModuleMetadata} from '@angular/compiler-cli';
|
||||||
import * as ts from 'typescript';
|
import * as ts from 'typescript';
|
||||||
|
|
||||||
import {CompilerHost} from '../src/compiler_host';
|
import {CompilerHost} from '../src/compiler_host';
|
||||||
|
@ -163,7 +163,7 @@ describe('CompilerHost', () => {
|
||||||
|
|
||||||
it('should be able to read a metadata file', () => {
|
it('should be able to read a metadata file', () => {
|
||||||
expect(hostNestedGenDir.getMetadataFor('node_modules/@angular/core.d.ts')).toEqual([
|
expect(hostNestedGenDir.getMetadataFor('node_modules/@angular/core.d.ts')).toEqual([
|
||||||
{__symbolic: 'module', version: 3, metadata: {foo: {__symbolic: 'class'}}}
|
{__symbolic: 'module', version: METADATA_VERSION, metadata: {foo: {__symbolic: 'class'}}}
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -181,13 +181,14 @@ describe('CompilerHost', () => {
|
||||||
expect(hostNestedGenDir.getMetadataFor('node_modules/@angular/missing.d.ts')).toBeUndefined();
|
expect(hostNestedGenDir.getMetadataFor('node_modules/@angular/missing.d.ts')).toBeUndefined();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should add missing v3 metadata from v1 metadata and .d.ts files', () => {
|
it(`should add missing v${METADATA_VERSION} metadata from v1 metadata and .d.ts files`, () => {
|
||||||
expect(hostNestedGenDir.getMetadataFor('metadata_versions/v1.d.ts')).toEqual([
|
expect(hostNestedGenDir.getMetadataFor('metadata_versions/v1.d.ts')).toEqual([
|
||||||
{__symbolic: 'module', version: 1, metadata: {foo: {__symbolic: 'class'}}}, {
|
{__symbolic: 'module', version: 1, metadata: {foo: {__symbolic: 'class'}}}, {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
foo: {__symbolic: 'class'},
|
foo: {__symbolic: 'class'},
|
||||||
|
aType: {__symbolic: 'interface'},
|
||||||
Bar: {__symbolic: 'class', members: {ngOnInit: [{__symbolic: 'method'}]}},
|
Bar: {__symbolic: 'class', members: {ngOnInit: [{__symbolic: 'method'}]}},
|
||||||
BarChild: {__symbolic: 'class', extends: {__symbolic: 'reference', name: 'Bar'}},
|
BarChild: {__symbolic: 'class', extends: {__symbolic: 'reference', name: 'Bar'}},
|
||||||
ReExport: {__symbolic: 'reference', module: './lib/utils2', name: 'ReExport'},
|
ReExport: {__symbolic: 'reference', module: './lib/utils2', name: 'ReExport'},
|
||||||
|
@ -197,9 +198,29 @@ describe('CompilerHost', () => {
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should upgrade a missing metadata file into v3', () => {
|
it(`should upgrade a missing metadata file into v${METADATA_VERSION}`, () => {
|
||||||
expect(hostNestedGenDir.getMetadataFor('metadata_versions/v1_empty.d.ts')).toEqual([
|
expect(hostNestedGenDir.getMetadataFor('metadata_versions/v1_empty.d.ts')).toEqual([{
|
||||||
{__symbolic: 'module', version: 3, metadata: {}, exports: [{from: './lib/utils'}]}
|
__symbolic: 'module',
|
||||||
|
version: METADATA_VERSION,
|
||||||
|
metadata: {},
|
||||||
|
exports: [{from: './lib/utils'}]
|
||||||
|
}]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it(`should upgrade v3 metadata into v${METADATA_VERSION}`, () => {
|
||||||
|
expect(hostNestedGenDir.getMetadataFor('metadata_versions/v3.d.ts')).toEqual([
|
||||||
|
{__symbolic: 'module', version: 3, metadata: {foo: {__symbolic: 'class'}}}, {
|
||||||
|
__symbolic: 'module',
|
||||||
|
version: METADATA_VERSION,
|
||||||
|
metadata: {
|
||||||
|
foo: {__symbolic: 'class'},
|
||||||
|
aType: {__symbolic: 'interface'},
|
||||||
|
Bar: {__symbolic: 'class', members: {ngOnInit: [{__symbolic: 'method'}]}},
|
||||||
|
BarChild: {__symbolic: 'class', extends: {__symbolic: 'reference', name: 'Bar'}},
|
||||||
|
ReExport: {__symbolic: 'reference', module: './lib/utils2', name: 'ReExport'},
|
||||||
|
}
|
||||||
|
// Note: exports is missing because it was elided in the original.
|
||||||
|
}
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -207,7 +228,7 @@ describe('CompilerHost', () => {
|
||||||
const dummyModule = 'export let foo: any[];';
|
const dummyModule = 'export let foo: any[];';
|
||||||
const dummyMetadata: ModuleMetadata = {
|
const dummyMetadata: ModuleMetadata = {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata:
|
metadata:
|
||||||
{foo: {__symbolic: 'error', message: 'Variable not initialized', line: 0, character: 11}}
|
{foo: {__symbolic: 'error', message: 'Variable not initialized', line: 0, character: 11}}
|
||||||
};
|
};
|
||||||
|
@ -230,7 +251,7 @@ const FILES: Entry = {
|
||||||
'@angular': {
|
'@angular': {
|
||||||
'core.d.ts': dummyModule,
|
'core.d.ts': dummyModule,
|
||||||
'core.metadata.json':
|
'core.metadata.json':
|
||||||
`{"__symbolic":"module", "version": 3, "metadata": {"foo": {"__symbolic": "class"}}}`,
|
`{"__symbolic":"module", "version": ${METADATA_VERSION}, "metadata": {"foo": {"__symbolic": "class"}}}`,
|
||||||
'router': {'index.d.ts': dummyModule, 'src': {'providers.d.ts': dummyModule}},
|
'router': {'index.d.ts': dummyModule, 'src': {'providers.d.ts': dummyModule}},
|
||||||
'unused.d.ts': dummyModule,
|
'unused.d.ts': dummyModule,
|
||||||
'empty.d.ts': 'export declare var a: string;',
|
'empty.d.ts': 'export declare var a: string;',
|
||||||
|
@ -244,6 +265,8 @@ const FILES: Entry = {
|
||||||
|
|
||||||
export {Export} from './lib/utils2';
|
export {Export} from './lib/utils2';
|
||||||
|
|
||||||
|
export type aType = number;
|
||||||
|
|
||||||
export declare class Bar {
|
export declare class Bar {
|
||||||
ngOnInit() {}
|
ngOnInit() {}
|
||||||
}
|
}
|
||||||
|
@ -253,7 +276,22 @@ const FILES: Entry = {
|
||||||
`{"__symbolic":"module", "version": 1, "metadata": {"foo": {"__symbolic": "class"}}}`,
|
`{"__symbolic":"module", "version": 1, "metadata": {"foo": {"__symbolic": "class"}}}`,
|
||||||
'v1_empty.d.ts': `
|
'v1_empty.d.ts': `
|
||||||
export * from './lib/utils';
|
export * from './lib/utils';
|
||||||
`
|
`,
|
||||||
|
'v3.d.ts': `
|
||||||
|
import {ReExport} from './lib/utils2';
|
||||||
|
export {ReExport};
|
||||||
|
|
||||||
|
export {Export} from './lib/utils2';
|
||||||
|
|
||||||
|
export type aType = number;
|
||||||
|
|
||||||
|
export declare class Bar {
|
||||||
|
ngOnInit() {}
|
||||||
|
}
|
||||||
|
export declare class BarChild extends Bar {}
|
||||||
|
`,
|
||||||
|
'v3.metadata.json':
|
||||||
|
`{"__symbolic":"module", "version": 3, "metadata": {"foo": {"__symbolic": "class"}}}`,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
import * as ts from 'typescript';
|
import * as ts from 'typescript';
|
||||||
|
|
||||||
import {MetadataCollector} from '../../src/metadata/collector';
|
import {MetadataCollector} from '../../src/metadata/collector';
|
||||||
import {ClassMetadata, ConstructorMetadata, MetadataEntry, ModuleMetadata, isClassMetadata, isMetadataGlobalReferenceExpression} from '../../src/metadata/schema';
|
import {ClassMetadata, ConstructorMetadata, METADATA_VERSION, MetadataEntry, ModuleMetadata, isClassMetadata, isMetadataGlobalReferenceExpression} from '../../src/metadata/schema';
|
||||||
|
|
||||||
import {Directory, Host, expectValidSources} from './typescript.mocks';
|
import {Directory, Host, expectValidSources} from './typescript.mocks';
|
||||||
|
|
||||||
|
@ -73,7 +73,7 @@ describe('Collector', () => {
|
||||||
const metadata = collector.getMetadata(sourceFile);
|
const metadata = collector.getMetadata(sourceFile);
|
||||||
expect(metadata).toEqual({
|
expect(metadata).toEqual({
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
DeclaredClass: {__symbolic: 'class'},
|
DeclaredClass: {__symbolic: 'class'},
|
||||||
declaredFn: {__symbolic: 'function'},
|
declaredFn: {__symbolic: 'function'},
|
||||||
|
@ -84,15 +84,21 @@ describe('Collector', () => {
|
||||||
it('should return an interface reference for types', () => {
|
it('should return an interface reference for types', () => {
|
||||||
const sourceFile = program.getSourceFile('/exported-type.ts');
|
const sourceFile = program.getSourceFile('/exported-type.ts');
|
||||||
const metadata = collector.getMetadata(sourceFile);
|
const metadata = collector.getMetadata(sourceFile);
|
||||||
expect(metadata).toEqual(
|
expect(metadata).toEqual({
|
||||||
{__symbolic: 'module', version: 3, metadata: {SomeType: {__symbolic: 'interface'}}});
|
__symbolic: 'module',
|
||||||
|
version: METADATA_VERSION,
|
||||||
|
metadata: {SomeType: {__symbolic: 'interface'}}
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should return an interface reference for interfaces', () => {
|
it('should return an interface reference for interfaces', () => {
|
||||||
const sourceFile = program.getSourceFile('app/hero.ts');
|
const sourceFile = program.getSourceFile('app/hero.ts');
|
||||||
const metadata = collector.getMetadata(sourceFile);
|
const metadata = collector.getMetadata(sourceFile);
|
||||||
expect(metadata).toEqual(
|
expect(metadata).toEqual({
|
||||||
{__symbolic: 'module', version: 3, metadata: {Hero: {__symbolic: 'interface'}}});
|
__symbolic: 'module',
|
||||||
|
version: METADATA_VERSION,
|
||||||
|
metadata: {Hero: {__symbolic: 'interface'}}
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should be able to collect a simple component\'s metadata', () => {
|
it('should be able to collect a simple component\'s metadata', () => {
|
||||||
|
@ -100,7 +106,7 @@ describe('Collector', () => {
|
||||||
const metadata = collector.getMetadata(sourceFile);
|
const metadata = collector.getMetadata(sourceFile);
|
||||||
expect(metadata).toEqual({
|
expect(metadata).toEqual({
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
HeroDetailComponent: {
|
HeroDetailComponent: {
|
||||||
__symbolic: 'class',
|
__symbolic: 'class',
|
||||||
|
@ -141,7 +147,7 @@ describe('Collector', () => {
|
||||||
const metadata = collector.getMetadata(sourceFile);
|
const metadata = collector.getMetadata(sourceFile);
|
||||||
expect(metadata).toEqual({
|
expect(metadata).toEqual({
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
AppComponent: {
|
AppComponent: {
|
||||||
__symbolic: 'class',
|
__symbolic: 'class',
|
||||||
|
@ -195,7 +201,7 @@ describe('Collector', () => {
|
||||||
const metadata = collector.getMetadata(sourceFile);
|
const metadata = collector.getMetadata(sourceFile);
|
||||||
expect(metadata).toEqual({
|
expect(metadata).toEqual({
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
HEROES: [
|
HEROES: [
|
||||||
{'id': 11, 'name': 'Mr. Nice', '$quoted$': ['id', 'name']},
|
{'id': 11, 'name': 'Mr. Nice', '$quoted$': ['id', 'name']},
|
||||||
|
@ -274,7 +280,7 @@ describe('Collector', () => {
|
||||||
const metadata = collector.getMetadata(unsupported1);
|
const metadata = collector.getMetadata(unsupported1);
|
||||||
expect(metadata).toEqual({
|
expect(metadata).toEqual({
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
a: {__symbolic: 'error', message: 'Destructuring not supported', line: 1, character: 16},
|
a: {__symbolic: 'error', message: 'Destructuring not supported', line: 1, character: 16},
|
||||||
b: {__symbolic: 'error', message: 'Destructuring not supported', line: 1, character: 19},
|
b: {__symbolic: 'error', message: 'Destructuring not supported', line: 1, character: 19},
|
||||||
|
@ -316,7 +322,7 @@ describe('Collector', () => {
|
||||||
const metadata = collector.getMetadata(sourceFile);
|
const metadata = collector.getMetadata(sourceFile);
|
||||||
expect(metadata).toEqual({
|
expect(metadata).toEqual({
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
SimpleClass: {__symbolic: 'class'},
|
SimpleClass: {__symbolic: 'class'},
|
||||||
AbstractClass: {__symbolic: 'class'},
|
AbstractClass: {__symbolic: 'class'},
|
||||||
|
@ -330,7 +336,7 @@ describe('Collector', () => {
|
||||||
const metadata = collector.getMetadata(exportedFunctions);
|
const metadata = collector.getMetadata(exportedFunctions);
|
||||||
expect(metadata).toEqual({
|
expect(metadata).toEqual({
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
one: {
|
one: {
|
||||||
__symbolic: 'function',
|
__symbolic: 'function',
|
||||||
|
|
|
@ -48,7 +48,7 @@ export interface StaticSymbolResolverHost {
|
||||||
fileNameToModuleName(importedFilePath: string, containingFilePath: string): string;
|
fileNameToModuleName(importedFilePath: string, containingFilePath: string): string;
|
||||||
}
|
}
|
||||||
|
|
||||||
const SUPPORTED_SCHEMA_VERSION = 3;
|
const SUPPORTED_SCHEMA_VERSION = 4;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class is responsible for loading metadata per symbol,
|
* This class is responsible for loading metadata per symbol,
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import {StaticReflector, StaticSymbol, StaticSymbolCache, StaticSymbolResolver, StaticSymbolResolverHost, core as compilerCore} from '@angular/compiler';
|
import {StaticReflector, StaticSymbol, StaticSymbolCache, StaticSymbolResolver, StaticSymbolResolverHost, core as compilerCore} from '@angular/compiler';
|
||||||
import {CollectorOptions} from '@angular/compiler-cli/src/metadata/index';
|
import {CollectorOptions, METADATA_VERSION} from '@angular/compiler-cli';
|
||||||
|
|
||||||
import {MockStaticSymbolResolverHost, MockSummaryResolver} from './static_symbol_resolver_spec';
|
import {MockStaticSymbolResolverHost, MockSummaryResolver} from './static_symbol_resolver_spec';
|
||||||
|
|
||||||
|
@ -883,7 +883,7 @@ describe('StaticReflector', () => {
|
||||||
const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
||||||
'/tmp/@angular/common/src/forms-deprecated/directives.d.ts': [{
|
'/tmp/@angular/common/src/forms-deprecated/directives.d.ts': [{
|
||||||
'__symbolic': 'module',
|
'__symbolic': 'module',
|
||||||
'version': 3,
|
'version': METADATA_VERSION,
|
||||||
'metadata': {
|
'metadata': {
|
||||||
'FORM_DIRECTIVES': [{
|
'FORM_DIRECTIVES': [{
|
||||||
'__symbolic': 'reference',
|
'__symbolic': 'reference',
|
||||||
|
@ -894,7 +894,7 @@ const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
||||||
}],
|
}],
|
||||||
'/tmp/@angular/common/src/directives/ng_for.d.ts': {
|
'/tmp/@angular/common/src/directives/ng_for.d.ts': {
|
||||||
'__symbolic': 'module',
|
'__symbolic': 'module',
|
||||||
'version': 3,
|
'version': METADATA_VERSION,
|
||||||
'metadata': {
|
'metadata': {
|
||||||
'NgFor': {
|
'NgFor': {
|
||||||
'__symbolic': 'class',
|
'__symbolic': 'class',
|
||||||
|
@ -924,19 +924,19 @@ const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'/tmp/@angular/core/src/linker/view_container_ref.d.ts':
|
'/tmp/@angular/core/src/linker/view_container_ref.d.ts':
|
||||||
{version: 3, 'metadata': {'ViewContainerRef': {'__symbolic': 'class'}}},
|
{version: METADATA_VERSION, 'metadata': {'ViewContainerRef': {'__symbolic': 'class'}}},
|
||||||
'/tmp/@angular/core/src/linker/template_ref.d.ts': {
|
'/tmp/@angular/core/src/linker/template_ref.d.ts': {
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
'module': './template_ref',
|
'module': './template_ref',
|
||||||
'metadata': {'TemplateRef': {'__symbolic': 'class'}}
|
'metadata': {'TemplateRef': {'__symbolic': 'class'}}
|
||||||
},
|
},
|
||||||
'/tmp/@angular/core/src/change_detection/differs/iterable_differs.d.ts':
|
'/tmp/@angular/core/src/change_detection/differs/iterable_differs.d.ts':
|
||||||
{version: 3, 'metadata': {'IterableDiffers': {'__symbolic': 'class'}}},
|
{version: METADATA_VERSION, 'metadata': {'IterableDiffers': {'__symbolic': 'class'}}},
|
||||||
'/tmp/@angular/core/src/change_detection/change_detector_ref.d.ts':
|
'/tmp/@angular/core/src/change_detection/change_detector_ref.d.ts':
|
||||||
{version: 3, 'metadata': {'ChangeDetectorRef': {'__symbolic': 'class'}}},
|
{version: METADATA_VERSION, 'metadata': {'ChangeDetectorRef': {'__symbolic': 'class'}}},
|
||||||
'/tmp/src/app/hero-detail.component.d.ts': {
|
'/tmp/src/app/hero-detail.component.d.ts': {
|
||||||
'__symbolic': 'module',
|
'__symbolic': 'module',
|
||||||
'version': 3,
|
'version': METADATA_VERSION,
|
||||||
'metadata': {
|
'metadata': {
|
||||||
'HeroDetailComponent': {
|
'HeroDetailComponent': {
|
||||||
'__symbolic': 'class',
|
'__symbolic': 'class',
|
||||||
|
@ -971,10 +971,10 @@ const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'/src/extern.d.ts': {'__symbolic': 'module', 'version': 3, metadata: {s: 's'}},
|
'/src/extern.d.ts': {'__symbolic': 'module', 'version': METADATA_VERSION, metadata: {s: 's'}},
|
||||||
'/tmp/src/error-reporting.d.ts': {
|
'/tmp/src/error-reporting.d.ts': {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
SomeClass: {
|
SomeClass: {
|
||||||
__symbolic: 'class',
|
__symbolic: 'class',
|
||||||
|
@ -994,7 +994,7 @@ const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
||||||
},
|
},
|
||||||
'/tmp/src/error-references.d.ts': {
|
'/tmp/src/error-references.d.ts': {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
Link1: {__symbolic: 'reference', module: 'src/error-references', name: 'Link2'},
|
Link1: {__symbolic: 'reference', module: 'src/error-references', name: 'Link2'},
|
||||||
Link2: {__symbolic: 'reference', module: 'src/error-references', name: 'ErrorSym'},
|
Link2: {__symbolic: 'reference', module: 'src/error-references', name: 'ErrorSym'},
|
||||||
|
@ -1004,7 +1004,7 @@ const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
||||||
},
|
},
|
||||||
'/tmp/src/function-declaration.d.ts': {
|
'/tmp/src/function-declaration.d.ts': {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
one: {
|
one: {
|
||||||
__symbolic: 'function',
|
__symbolic: 'function',
|
||||||
|
@ -1031,7 +1031,7 @@ const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
||||||
},
|
},
|
||||||
'/tmp/src/function-reference.ts': {
|
'/tmp/src/function-reference.ts': {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
one: {
|
one: {
|
||||||
__symbolic: 'call',
|
__symbolic: 'call',
|
||||||
|
@ -1058,7 +1058,7 @@ const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
||||||
},
|
},
|
||||||
'/tmp/src/function-recursive.d.ts': {
|
'/tmp/src/function-recursive.d.ts': {
|
||||||
__symbolic: 'modules',
|
__symbolic: 'modules',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
recursive: {
|
recursive: {
|
||||||
__symbolic: 'function',
|
__symbolic: 'function',
|
||||||
|
@ -1103,7 +1103,7 @@ const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
||||||
},
|
},
|
||||||
'/tmp/src/spread.ts': {
|
'/tmp/src/spread.ts': {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {spread: [0, {__symbolic: 'spread', expression: [1, 2, 3, 4]}, 5]}
|
metadata: {spread: [0, {__symbolic: 'spread', expression: [1, 2, 3, 4]}, 5]}
|
||||||
},
|
},
|
||||||
'/tmp/src/custom-decorator.ts': `
|
'/tmp/src/custom-decorator.ts': `
|
||||||
|
|
|
@ -7,11 +7,12 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import {StaticSymbol, StaticSymbolCache, StaticSymbolResolver, StaticSymbolResolverHost, Summary, SummaryResolver} from '@angular/compiler';
|
import {StaticSymbol, StaticSymbolCache, StaticSymbolResolver, StaticSymbolResolverHost, Summary, SummaryResolver} from '@angular/compiler';
|
||||||
|
import {CollectorOptions, METADATA_VERSION} from '@angular/compiler-cli';
|
||||||
import {MetadataCollector} from '@angular/compiler-cli/src/metadata/collector';
|
import {MetadataCollector} from '@angular/compiler-cli/src/metadata/collector';
|
||||||
import {CollectorOptions} from '@angular/compiler-cli/src/metadata/index';
|
|
||||||
import * as ts from 'typescript';
|
import * as ts from 'typescript';
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// This matches .ts files but not .d.ts files.
|
// This matches .ts files but not .d.ts files.
|
||||||
const TS_EXT = /(^.|(?!\.d)..)\.ts$/;
|
const TS_EXT = /(^.|(?!\.d)..)\.ts$/;
|
||||||
|
|
||||||
|
@ -38,7 +39,7 @@ describe('StaticSymbolResolver', () => {
|
||||||
() => symbolResolver.resolveSymbol(
|
() => symbolResolver.resolveSymbol(
|
||||||
symbolResolver.getSymbolByModule('src/version-error', 'e')))
|
symbolResolver.getSymbolByModule('src/version-error', 'e')))
|
||||||
.toThrow(new Error(
|
.toThrow(new Error(
|
||||||
'Metadata version mismatch for module /tmp/src/version-error.d.ts, found version 100, expected 3'));
|
`Metadata version mismatch for module /tmp/src/version-error.d.ts, found version 100, expected ${METADATA_VERSION}`));
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should throw an exception for version 2 metadata', () => {
|
it('should throw an exception for version 2 metadata', () => {
|
||||||
|
@ -155,14 +156,14 @@ describe('StaticSymbolResolver', () => {
|
||||||
{
|
{
|
||||||
'/test.d.ts': [{
|
'/test.d.ts': [{
|
||||||
'__symbolic': 'module',
|
'__symbolic': 'module',
|
||||||
'version': 3,
|
'version': METADATA_VERSION,
|
||||||
'metadata': {
|
'metadata': {
|
||||||
'a': {'__symbolic': 'reference', 'name': 'b', 'module': './test2'},
|
'a': {'__symbolic': 'reference', 'name': 'b', 'module': './test2'},
|
||||||
}
|
}
|
||||||
}],
|
}],
|
||||||
'/test2.d.ts': [{
|
'/test2.d.ts': [{
|
||||||
'__symbolic': 'module',
|
'__symbolic': 'module',
|
||||||
'version': 3,
|
'version': METADATA_VERSION,
|
||||||
'metadata': {
|
'metadata': {
|
||||||
'b': {'__symbolic': 'reference', 'name': 'c', 'module': './test3'},
|
'b': {'__symbolic': 'reference', 'name': 'c', 'module': './test3'},
|
||||||
}
|
}
|
||||||
|
@ -299,7 +300,7 @@ describe('StaticSymbolResolver', () => {
|
||||||
init({
|
init({
|
||||||
'/test.d.ts': [{
|
'/test.d.ts': [{
|
||||||
'__symbolic': 'module',
|
'__symbolic': 'module',
|
||||||
'version': 3,
|
'version': METADATA_VERSION,
|
||||||
'metadata': {
|
'metadata': {
|
||||||
'AParam': {__symbolic: 'class'},
|
'AParam': {__symbolic: 'class'},
|
||||||
'AClass': {
|
'AClass': {
|
||||||
|
@ -504,7 +505,7 @@ const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
||||||
'/tmp/src/version-2-error.d.ts': {'__symbolic': 'module', 'version': 2, metadata: {e: 's'}},
|
'/tmp/src/version-2-error.d.ts': {'__symbolic': 'module', 'version': 2, metadata: {e: 's'}},
|
||||||
'/tmp/src/reexport/reexport.d.ts': {
|
'/tmp/src/reexport/reexport.d.ts': {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
Six: {__symbolic: 'class'},
|
Six: {__symbolic: 'class'},
|
||||||
},
|
},
|
||||||
|
@ -515,7 +516,7 @@ const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
||||||
},
|
},
|
||||||
'/tmp/src/reexport/src/origin1.d.ts': {
|
'/tmp/src/reexport/src/origin1.d.ts': {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
One: {__symbolic: 'class'},
|
One: {__symbolic: 'class'},
|
||||||
Two: {__symbolic: 'class'},
|
Two: {__symbolic: 'class'},
|
||||||
|
@ -525,26 +526,26 @@ const DEFAULT_TEST_DATA: {[key: string]: any} = {
|
||||||
},
|
},
|
||||||
'/tmp/src/reexport/src/origin5.d.ts': {
|
'/tmp/src/reexport/src/origin5.d.ts': {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
Five: {__symbolic: 'class'},
|
Five: {__symbolic: 'class'},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
'/tmp/src/reexport/src/origin30.d.ts': {
|
'/tmp/src/reexport/src/origin30.d.ts': {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {
|
metadata: {
|
||||||
Thirty: {__symbolic: 'class'},
|
Thirty: {__symbolic: 'class'},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
'/tmp/src/reexport/src/originNone.d.ts': {
|
'/tmp/src/reexport/src/originNone.d.ts': {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {},
|
metadata: {},
|
||||||
},
|
},
|
||||||
'/tmp/src/reexport/src/reexport2.d.ts': {
|
'/tmp/src/reexport/src/reexport2.d.ts': {
|
||||||
__symbolic: 'module',
|
__symbolic: 'module',
|
||||||
version: 3,
|
version: METADATA_VERSION,
|
||||||
metadata: {},
|
metadata: {},
|
||||||
exports: [{from: './originNone'}, {from: './origin30'}]
|
exports: [{from: './originNone'}, {from: './origin30'}]
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import {AotSummaryResolver, AotSummaryResolverHost, CompileSummaryKind, StaticSymbol, StaticSymbolCache, StaticSymbolResolver, StaticSymbolResolverHost} from '@angular/compiler';
|
import {AotSummaryResolver, AotSummaryResolverHost, CompileSummaryKind, StaticSymbol, StaticSymbolCache, StaticSymbolResolver, StaticSymbolResolverHost} from '@angular/compiler';
|
||||||
|
import {METADATA_VERSION} from '@angular/compiler-cli';
|
||||||
import {deserializeSummaries, serializeSummaries} from '@angular/compiler/src/aot/summary_serializer';
|
import {deserializeSummaries, serializeSummaries} from '@angular/compiler/src/aot/summary_serializer';
|
||||||
import {summaryFileName} from '@angular/compiler/src/aot/util';
|
import {summaryFileName} from '@angular/compiler/src/aot/util';
|
||||||
|
|
||||||
|
@ -242,7 +243,7 @@ export function main() {
|
||||||
export var local = 'a';
|
export var local = 'a';
|
||||||
`,
|
`,
|
||||||
'/tmp/non_summary.d.ts':
|
'/tmp/non_summary.d.ts':
|
||||||
{__symbolic: 'module', version: 3, metadata: {'external': 'b'}}
|
{__symbolic: 'module', version: METADATA_VERSION, metadata: {'external': 'b'}}
|
||||||
});
|
});
|
||||||
const serialized = serializeSummaries(
|
const serialized = serializeSummaries(
|
||||||
'someFile.ts', createMockOutputContext(), summaryResolver, symbolResolver, [{
|
'someFile.ts', createMockOutputContext(), summaryResolver, symbolResolver, [{
|
||||||
|
|
|
@ -19,6 +19,8 @@
|
||||||
],
|
],
|
||||||
|
|
||||||
"angularCompilerOptions": {
|
"angularCompilerOptions": {
|
||||||
"skipTemplateCodegen": true
|
"skipTemplateCodegen": true,
|
||||||
|
"annotateForClosureCompiler": false,
|
||||||
|
"annotationsAs": "decorators"
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -58,7 +58,7 @@ travisFoldEnd "tsc tools"
|
||||||
|
|
||||||
|
|
||||||
travisFoldStart "tsc all"
|
travisFoldStart "tsc all"
|
||||||
$(npm bin)/tsc -p packages
|
|
||||||
node dist/tools/@angular/compiler-cli/src/main -p packages/tsconfig-metadata.json
|
node dist/tools/@angular/compiler-cli/src/main -p packages/tsconfig-metadata.json
|
||||||
|
$(npm bin)/tsc -p packages
|
||||||
$(npm bin)/tsc -p modules
|
$(npm bin)/tsc -p modules
|
||||||
travisFoldEnd "tsc all"
|
travisFoldEnd "tsc all"
|
||||||
|
|
Loading…
Reference in New Issue