angular-cn/dev-infra/ts-circular-dependencies/config.ts

62 lines
2.0 KiB
TypeScript

/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
import {dirname, isAbsolute, resolve} from 'path';
import {error} from '../utils/console';
import {ModuleResolver} from './analyzer';
/** Configuration for a circular dependencies test. */
export interface CircularDependenciesTestConfig {
/** Base directory used for shortening paths in the golden file. */
baseDir: string;
/** Path to the golden file that is used for checking and approving. */
goldenFile: string;
/** Glob that resolves source files which should be checked. */
glob: string;
/**
* Optional module resolver function that can be used to resolve modules
* to absolute file paths.
*/
resolveModule?: ModuleResolver;
/**
* Optional command that will be displayed if the golden check failed. This can be used
* to consistently use script aliases for checking/approving the golden.
*/
approveCommand?: string;
}
/**
* Loads the configuration for the circular dependencies test. If the config cannot be
* loaded, an error will be printed and the process exists with a non-zero exit code.
*/
export function loadTestConfig(configPath: string): CircularDependenciesTestConfig {
const configBaseDir = dirname(configPath);
const resolveRelativePath = (relativePath: string) => resolve(configBaseDir, relativePath);
try {
const config = require(configPath) as CircularDependenciesTestConfig;
if (!isAbsolute(config.baseDir)) {
config.baseDir = resolveRelativePath(config.baseDir);
}
if (!isAbsolute(config.goldenFile)) {
config.goldenFile = resolveRelativePath(config.goldenFile);
}
if (!isAbsolute(config.glob)) {
config.glob = resolveRelativePath(config.glob);
}
return config;
} catch (e) {
error('Could not load test configuration file at: ' + configPath);
error(`Failed with: ${e.message}`);
process.exit(1);
}
}