build: fix outdated ngtools compiler-cli test logic (#28191)
* Fixes that the test logic for `ngtools` in the offline compiler test is no longer working due to being unmaintained for a long time * Makes the path comparison logic platform agnostic, so that the tests can be also executed on Windows PR Close #28191
This commit is contained in:
parent
3e6a1f0bc4
commit
4c8d17ffd4
|
@ -13,7 +13,7 @@ import 'reflect-metadata';
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as ts from 'typescript';
|
import * as ts from 'typescript';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import {__NGTOOLS_PRIVATE_API_2, readConfiguration} from '@angular/compiler-cli';
|
import {createProgram, readConfiguration} from '@angular/compiler-cli';
|
||||||
|
|
||||||
/* tslint:disable:no-console */
|
/* tslint:disable:no-console */
|
||||||
/**
|
/**
|
||||||
|
@ -22,19 +22,10 @@ import {__NGTOOLS_PRIVATE_API_2, readConfiguration} from '@angular/compiler-cli'
|
||||||
* properly read and wrote.
|
* properly read and wrote.
|
||||||
*/
|
*/
|
||||||
function main() {
|
function main() {
|
||||||
console.log(`testing ngtools API...`);
|
Promise.resolve().then(() => lazyRoutesTest()).then(() => { process.exit(0); }).catch((err) => {
|
||||||
|
console.error(err.stack);
|
||||||
Promise.resolve()
|
process.exit(1);
|
||||||
.then(() => lazyRoutesTest())
|
});
|
||||||
.then(() => {
|
|
||||||
console.log('All done!');
|
|
||||||
process.exit(0);
|
|
||||||
})
|
|
||||||
.catch((err) => {
|
|
||||||
console.error(err.stack);
|
|
||||||
console.error('Test failed');
|
|
||||||
process.exit(1);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function lazyRoutesTest() {
|
function lazyRoutesTest() {
|
||||||
|
@ -43,13 +34,15 @@ function lazyRoutesTest() {
|
||||||
|
|
||||||
const config = readConfiguration(project);
|
const config = readConfiguration(project);
|
||||||
const host = ts.createCompilerHost(config.options, true);
|
const host = ts.createCompilerHost(config.options, true);
|
||||||
const program = ts.createProgram(config.rootNames, config.options, host);
|
const program = createProgram({
|
||||||
|
rootNames: config.rootNames,
|
||||||
|
options: config.options, host,
|
||||||
|
});
|
||||||
|
|
||||||
config.options.basePath = basePath;
|
config.options.basePath = basePath;
|
||||||
|
config.options.rootDir = basePath;
|
||||||
|
|
||||||
const lazyRoutes = __NGTOOLS_PRIVATE_API_2.listLazyRoutes(
|
const lazyRoutes = program.listLazyRoutes('app.module#AppModule');
|
||||||
{program, host, angularCompilerOptions: config.options, entryModule: 'app.module#AppModule'});
|
|
||||||
|
|
||||||
const expectations: {[route: string]: string} = {
|
const expectations: {[route: string]: string} = {
|
||||||
'./lazy.module#LazyModule': 'lazy.module.ts',
|
'./lazy.module#LazyModule': 'lazy.module.ts',
|
||||||
'./feature/feature.module#FeatureModule': 'feature/feature.module.ts',
|
'./feature/feature.module#FeatureModule': 'feature/feature.module.ts',
|
||||||
|
@ -61,17 +54,25 @@ function lazyRoutesTest() {
|
||||||
'feature/feature.module#FeatureModule': 'feature/feature.module.ts'
|
'feature/feature.module#FeatureModule': 'feature/feature.module.ts'
|
||||||
};
|
};
|
||||||
|
|
||||||
Object.keys(lazyRoutes).forEach((route: string) => {
|
lazyRoutes.forEach(lazyRoute => {
|
||||||
assert(route in expectations, `Found a route that was not expected: "${route}".`);
|
const routeName = lazyRoute.route;
|
||||||
|
|
||||||
|
// Normalize the module path and the expected module path so that these can be compared
|
||||||
|
// on Windows where path separators are not consistent with TypeScript internal paths.
|
||||||
|
const modulePath = path.normalize(lazyRoute.referencedModule.filePath);
|
||||||
|
const expectedModulePath = path.normalize(path.join(basePath, expectations[routeName]));
|
||||||
|
|
||||||
|
assert(routeName in expectations, `Found a route that was not expected: "${routeName}".`);
|
||||||
assert(
|
assert(
|
||||||
lazyRoutes[route] == path.join(basePath, expectations[route]),
|
modulePath === expectedModulePath,
|
||||||
`Route "${route}" does not point to the expected absolute path ` +
|
`Route "${routeName}" does not point to the expected absolute path ` +
|
||||||
`"${path.join(basePath, expectations[route])}". It points to "${lazyRoutes[route]}"`);
|
`"${expectedModulePath}". It points to "${modulePath}"`);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Verify that all expectations were met.
|
// Verify that all expectations were met.
|
||||||
assert.deepEqual(
|
assert.deepEqual(
|
||||||
Object.keys(lazyRoutes), Object.keys(expectations), `Expected routes listed to be: \n` +
|
lazyRoutes.map(lazyRoute => lazyRoute.route), Object.keys(expectations),
|
||||||
|
`Expected routes listed to be: \n` +
|
||||||
` ${JSON.stringify(Object.keys(expectations))}\n` +
|
` ${JSON.stringify(Object.keys(expectations))}\n` +
|
||||||
`Actual:\n` +
|
`Actual:\n` +
|
||||||
` ${JSON.stringify(Object.keys(lazyRoutes))}\n`);
|
` ${JSON.stringify(Object.keys(lazyRoutes))}\n`);
|
||||||
|
|
Loading…
Reference in New Issue