lib-tools
Version:
The lib-tools helps you simplify the build, bundle, test and npm packaging workflows for Typescript, JavaScript, Angular library projects and assets module projects.
148 lines • 22.3 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.detectWorkflowConfig = void 0;
const path = require("path");
const util_1 = require("util");
const fs_extra_1 = require("fs-extra");
const glob = require("glob");
const globAsync = util_1.promisify(glob);
const utils_1 = require("../utils");
const detect_ts_entry_name_1 = require("./detect-ts-entry-name");
const find_build_tsconfig_file_1 = require("./find-build-tsconfig-file");
const find_test_index_file_1 = require("./find-test-index-file");
const find_test_tsconfig_file_1 = require("./find-test-tsconfig-file");
const find_karma_config_file_1 = require("./find-karma-config-file");
const parse_ts_json_config_file_content_1 = require("./parse-ts-json-config-file-content");
const read_tsconfig_json_1 = require("./read-tsconfig-json");
const read_package_json_1 = require("./read-package-json");
const read_workflow_config_1 = require("./read-workflow-config");
async function detectWorkflowConfig(taskName) {
const foundPackageJsonPaths = await globAsync('*(src|modules|packages|projects|libs|samples|examples|demos)/**/package.json', {
cwd: process.cwd(),
dot: false,
absolute: true,
ignore: ['**/lib-tools/package.json', '**/node_modules/**/package.json', '**/dist/**/package.json']
});
if (!foundPackageJsonPaths.length) {
return null;
}
const projects = [];
for (const packageJsonPath of foundPackageJsonPaths) {
const workflowConfigPath = path.resolve(path.dirname(packageJsonPath), 'workflow.json');
if (await fs_extra_1.pathExists(workflowConfigPath)) {
const workflowConfig = await read_workflow_config_1.readWorkflowConfig(workflowConfigPath);
const workspaceRoot = path.dirname(workflowConfigPath);
const keys = Object.keys(workflowConfig.projects);
for (const key of keys) {
const project = workflowConfig.projects[key];
if (project.root && path.isAbsolute(project.root)) {
throw new Error(`Invalid configuration. The 'projects[${key}].root' must be relative path.`);
}
const projectRoot = path.resolve(workspaceRoot, project.root || '');
const projectInternal = Object.assign(Object.assign({}, project), { _workspaceRoot: workspaceRoot, _config: workflowConfigPath, _projectRoot: projectRoot, _projectName: key });
projects.push(projectInternal);
}
}
else {
const packageJson = await read_package_json_1.readPackageJson(packageJsonPath);
const packageName = packageJson.name;
if (!packageName) {
continue;
}
let packageNameWithoutScope = packageName;
const slashIndex = packageName.indexOf('/');
if (slashIndex > -1 && packageName.startsWith('@')) {
packageNameWithoutScope = packageName.substr(slashIndex + 1);
}
const projectName = packageNameWithoutScope.replace(/\//g, '-');
const workspaceRoot = process.cwd();
const projectRoot = path.dirname(packageJsonPath);
if (taskName === 'build') {
const buildConfig = await detectBuildConfig(workspaceRoot, projectRoot, packageNameWithoutScope);
if (buildConfig != null) {
const projectInternal = {
_config: 'auto',
_workspaceRoot: workspaceRoot,
_projectRoot: projectRoot,
_projectName: projectName,
root: utils_1.normalizePath(path.relative(workspaceRoot, projectRoot)),
tasks: {
build: buildConfig
}
};
projects.push(projectInternal);
}
}
else if (taskName === 'test') {
const testConfig = await detectTestConfig(workspaceRoot, projectRoot);
if (testConfig != null) {
const projectInternal = {
_config: 'auto',
_workspaceRoot: workspaceRoot,
_projectRoot: projectRoot,
_projectName: projectName,
root: utils_1.normalizePath(path.relative(workspaceRoot, projectRoot)),
tasks: {
test: testConfig
}
};
projects.push(projectInternal);
}
}
}
}
if (!projects.length) {
return null;
}
const projectMap = {};
for (const project of projects) {
projectMap[project._projectName] = project;
}
return {
projects: projectMap
};
}
exports.detectWorkflowConfig = detectWorkflowConfig;
async function detectBuildConfig(workspaceRoot, projectRoot, packageNameWithoutScope) {
const tsConfigPath = await find_build_tsconfig_file_1.findBuildTsconfigFile(projectRoot, workspaceRoot);
if (!tsConfigPath) {
return null;
}
const tsConfigJson = read_tsconfig_json_1.readTsconfigJson(tsConfigPath);
const tsCompilerConfig = parse_ts_json_config_file_content_1.parseTsJsonConfigFileContent(tsConfigPath);
const tsConfigInfo = {
tsConfigPath,
tsConfigJson,
tsCompilerConfig
};
const entryName = await detect_ts_entry_name_1.detectTsEntryName(tsConfigInfo, packageNameWithoutScope);
if (!entryName) {
return null;
}
return {
script: {
compilations: 'auto'
}
};
}
async function detectTestConfig(workspaceRoot, projectRoot) {
const tsConfigPath = await find_test_tsconfig_file_1.findTestTsconfigFile(projectRoot, workspaceRoot);
const testIndexFile = await find_test_index_file_1.findTestIndexFile(projectRoot, workspaceRoot, tsConfigPath);
const karmaConfigFilePath = await find_karma_config_file_1.findKarmaConfigFile(projectRoot, workspaceRoot);
if (!karmaConfigFilePath && !testIndexFile) {
return null;
}
return {
tsConfig: tsConfigPath ? path.relative(projectRoot, tsConfigPath) : undefined,
testIndexFile: testIndexFile ? path.relative(projectRoot, testIndexFile) : undefined,
karmaConfig: karmaConfigFilePath ? path.relative(projectRoot, karmaConfigFilePath) : undefined,
codeCoverageExclude: ['**/test.ts', '**/index.ts', '**/public_api.ts'],
envOverrides: {
ci: {
browsers: ['ChromeHeadlessCI'],
reporters: ['junit', 'coverage']
}
}
};
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"detect-workflow-config.js","sourceRoot":"./","sources":["helpers/detect-workflow-config.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { promisify } from 'util';\n\nimport { pathExists } from 'fs-extra';\nimport * as glob from 'glob';\n\nconst globAsync = promisify(glob);\n\nimport { BuildConfig, ProjectConfigInternal, TestConfig, TsConfigInfo, WorkflowConfigInternal } from '../models';\nimport { normalizePath } from '../utils';\n\nimport { detectTsEntryName } from './detect-ts-entry-name';\nimport { findBuildTsconfigFile } from './find-build-tsconfig-file';\nimport { findTestIndexFile } from './find-test-index-file';\nimport { findTestTsconfigFile } from './find-test-tsconfig-file';\nimport { findKarmaConfigFile } from './find-karma-config-file';\nimport { parseTsJsonConfigFileContent } from './parse-ts-json-config-file-content';\nimport { readTsconfigJson } from './read-tsconfig-json';\nimport { readPackageJson } from './read-package-json';\nimport { readWorkflowConfig } from './read-workflow-config';\n\nexport async function detectWorkflowConfig(taskName: 'build' | 'test'): Promise<WorkflowConfigInternal | null> {\n    const foundPackageJsonPaths = await globAsync(\n        '*(src|modules|packages|projects|libs|samples|examples|demos)/**/package.json',\n        {\n            cwd: process.cwd(),\n            dot: false,\n            absolute: true,\n            ignore: ['**/lib-tools/package.json', '**/node_modules/**/package.json', '**/dist/**/package.json']\n        }\n    );\n\n    if (!foundPackageJsonPaths.length) {\n        return null;\n    }\n\n    const projects: ProjectConfigInternal[] = [];\n\n    for (const packageJsonPath of foundPackageJsonPaths) {\n        const workflowConfigPath = path.resolve(path.dirname(packageJsonPath), 'workflow.json');\n        if (await pathExists(workflowConfigPath)) {\n            const workflowConfig = await readWorkflowConfig(workflowConfigPath);\n            const workspaceRoot = path.dirname(workflowConfigPath);\n            const keys = Object.keys(workflowConfig.projects);\n            for (const key of keys) {\n                const project = workflowConfig.projects[key];\n\n                if (project.root && path.isAbsolute(project.root)) {\n                    throw new Error(`Invalid configuration. The 'projects[${key}].root' must be relative path.`);\n                }\n\n                const projectRoot = path.resolve(workspaceRoot, project.root || '');\n                const projectInternal: ProjectConfigInternal = {\n                    ...project,\n                    _workspaceRoot: workspaceRoot,\n                    _config: workflowConfigPath,\n                    _projectRoot: projectRoot,\n                    _projectName: key\n                };\n\n                projects.push(projectInternal);\n            }\n        } else {\n            const packageJson = await readPackageJson(packageJsonPath);\n            const packageName = packageJson.name;\n            if (!packageName) {\n                continue;\n            }\n\n            let packageNameWithoutScope = packageName;\n            const slashIndex = packageName.indexOf('/');\n            if (slashIndex > -1 && packageName.startsWith('@')) {\n                packageNameWithoutScope = packageName.substr(slashIndex + 1);\n            }\n            const projectName = packageNameWithoutScope.replace(/\\//g, '-');\n\n            const workspaceRoot = process.cwd();\n            const projectRoot = path.dirname(packageJsonPath);\n\n            if (taskName === 'build') {\n                const buildConfig = await detectBuildConfig(workspaceRoot, projectRoot, packageNameWithoutScope);\n                if (buildConfig != null) {\n                    const projectInternal: ProjectConfigInternal = {\n                        _config: 'auto',\n                        _workspaceRoot: workspaceRoot,\n                        _projectRoot: projectRoot,\n                        _projectName: projectName,\n                        root: normalizePath(path.relative(workspaceRoot, projectRoot)),\n                        tasks: {\n                            build: buildConfig\n                        }\n                    };\n\n                    projects.push(projectInternal);\n                }\n            } else if (taskName === 'test') {\n                const testConfig = await detectTestConfig(workspaceRoot, projectRoot);\n                if (testConfig != null) {\n                    const projectInternal: ProjectConfigInternal = {\n                        _config: 'auto',\n                        _workspaceRoot: workspaceRoot,\n                        _projectRoot: projectRoot,\n                        _projectName: projectName,\n                        root: normalizePath(path.relative(workspaceRoot, projectRoot)),\n                        tasks: {\n                            test: testConfig\n                        }\n                    };\n\n                    projects.push(projectInternal);\n                }\n            }\n        }\n    }\n\n    if (!projects.length) {\n        return null;\n    }\n\n    const projectMap: { [key: string]: ProjectConfigInternal } = {};\n    for (const project of projects) {\n        projectMap[project._projectName] = project;\n    }\n\n    return {\n        projects: projectMap\n    };\n}\n\nasync function detectBuildConfig(\n    workspaceRoot: string,\n    projectRoot: string,\n    packageNameWithoutScope: string\n): Promise<BuildConfig | null> {\n    const tsConfigPath = await findBuildTsconfigFile(projectRoot, workspaceRoot);\n    if (!tsConfigPath) {\n        return null;\n    }\n\n    const tsConfigJson = readTsconfigJson(tsConfigPath);\n    const tsCompilerConfig = parseTsJsonConfigFileContent(tsConfigPath);\n    const tsConfigInfo: TsConfigInfo = {\n        tsConfigPath,\n        tsConfigJson,\n        tsCompilerConfig\n    };\n\n    const entryName = await detectTsEntryName(tsConfigInfo, packageNameWithoutScope);\n    if (!entryName) {\n        return null;\n    }\n\n    return {\n        script: {\n            compilations: 'auto'\n        }\n    };\n}\n\nasync function detectTestConfig(workspaceRoot: string, projectRoot: string): Promise<TestConfig | null> {\n    const tsConfigPath = await findTestTsconfigFile(projectRoot, workspaceRoot);\n    const testIndexFile = await findTestIndexFile(projectRoot, workspaceRoot, tsConfigPath);\n\n    const karmaConfigFilePath = await findKarmaConfigFile(projectRoot, workspaceRoot);\n\n    if (!karmaConfigFilePath && !testIndexFile) {\n        return null;\n    }\n\n    return {\n        tsConfig: tsConfigPath ? path.relative(projectRoot, tsConfigPath) : undefined,\n        testIndexFile: testIndexFile ? path.relative(projectRoot, testIndexFile) : undefined,\n        karmaConfig: karmaConfigFilePath ? path.relative(projectRoot, karmaConfigFilePath) : undefined,\n        codeCoverageExclude: ['**/test.ts', '**/index.ts', '**/public_api.ts'],\n        envOverrides: {\n            ci: {\n                browsers: ['ChromeHeadlessCI'],\n                reporters: ['junit', 'coverage']\n            }\n        }\n    };\n}\n"]}