fix(ngcc): do not crash on packages that specify typings as an array (#33973)

In a package.json file, the "typings" or "types" field could be an array
of typings files. ngcc would previously crash unexpectedly for such
packages, as it assumed that the typings field would be a string. This
commit lets ngcc skip over such packages, as having multiple typing
entry-points is not supported for Angular packages so it is safe to
ignore them.

Fixes #33646

PR Close #33973
This commit is contained in:
JoostK 2019-11-21 21:56:02 +01:00 committed by Matias Niemelä
parent 5024e217d7
commit 310ce6dcc2
2 changed files with 26 additions and 5 deletions

View File

@ -108,7 +108,7 @@ export function getEntryPointInfo(
// We must have a typings property // We must have a typings property
const typings = entryPointPackageJson.typings || entryPointPackageJson.types || const typings = entryPointPackageJson.typings || entryPointPackageJson.types ||
guessTypingsFromPackageJson(fs, entryPointPath, entryPointPackageJson); guessTypingsFromPackageJson(fs, entryPointPath, entryPointPackageJson);
if (!typings) { if (typeof typings !== 'string') {
return null; return null;
} }

View File

@ -184,6 +184,26 @@ runInEachFileSystem(() => {
expect(entryPoint).toBe(null); expect(entryPoint).toBe(null);
}); });
it('should return null if the typings or types field is not a string in the package.json',
() => {
loadTestFiles([
{
name: _('/project/node_modules/some_package/typings_array/package.json'),
contents: createPackageJson('typings_array', {typingsIsArray: true})
},
{
name: _(
'/project/node_modules/some_package/typings_array/missing_typings.metadata.json'),
contents: 'some meta data'
},
]);
const config = new NgccConfiguration(fs, _('/project'));
const entryPoint = getEntryPointInfo(
fs, config, new MockLogger(), SOME_PACKAGE,
_('/project/node_modules/some_package/typings_array'));
expect(entryPoint).toBe(null);
});
for (let prop of SUPPORTED_FORMAT_PROPERTIES) { for (let prop of SUPPORTED_FORMAT_PROPERTIES) {
// Ignore the UMD format // Ignore the UMD format
if (prop === 'main') continue; if (prop === 'main') continue;
@ -279,7 +299,7 @@ runInEachFileSystem(() => {
loadTestFiles([ loadTestFiles([
{ {
name: _('/project/node_modules/some_package/types_rather_than_typings/package.json'), name: _('/project/node_modules/some_package/types_rather_than_typings/package.json'),
contents: createPackageJson('types_rather_than_typings', {}, 'types') contents: createPackageJson('types_rather_than_typings', {typingsProp: 'types'})
}, },
{ {
name: _( name: _(
@ -443,11 +463,12 @@ runInEachFileSystem(() => {
}); });
function createPackageJson( function createPackageJson(
packageName: string, {excludes}: {excludes?: string[]} = {}, packageName: string,
typingsProp: string = 'typings'): string { {excludes, typingsProp = 'typings', typingsIsArray}:
{excludes?: string[], typingsProp?: string, typingsIsArray?: boolean} = {}): string {
const packageJson: any = { const packageJson: any = {
name: `some_package/${packageName}`, name: `some_package/${packageName}`,
[typingsProp]: `./${packageName}.d.ts`, [typingsProp]: typingsIsArray ? [`./${packageName}.d.ts`] : `./${packageName}.d.ts`,
fesm2015: `./fesm2015/${packageName}.js`, fesm2015: `./fesm2015/${packageName}.js`,
esm2015: `./esm2015/${packageName}.js`, esm2015: `./esm2015/${packageName}.js`,
es2015: `./es2015/${packageName}.js`, es2015: `./es2015/${packageName}.js`,