import * as q from 'smartq'; import { ProjectinfoNpm } from 'projectinfo'; // interfaces import { INpmtsConfig } from '../npmts.config'; import * as paths from '../npmts.paths'; import * as plugins from './mod.plugins'; export let projectInfo: ProjectinfoNpm; let checkProjectTypings = (configArg: INpmtsConfig) => { let done = q.defer(); plugins.beautylog.ora.text('Check Module: Check Project Typings...'); projectInfo = new ProjectinfoNpm(paths.cwd); if (typeof projectInfo.packageJson.typings === 'undefined') { plugins.beautylog.error(`please add typings field to package.json`); process.exit(1); } done.resolve(configArg); return done.promise; }; const depcheckOptions = { ignoreBinPackage: false, // ignore the packages with bin entry parsers: { // the target parsers '*.ts': plugins.depcheck.parser.typescript }, detectors: [ // the target detectors plugins.depcheck.detector.requireCallExpression, plugins.depcheck.detector.importDeclaration ], specials: [ // the target special parsers plugins.depcheck.special.eslint, plugins.depcheck.special.webpack ] }; let checkDependencies = (configArg: INpmtsConfig) => { let done = q.defer(); plugins.beautylog.ora.text('Check Module: Check Dependencies...'); let depcheckOptionsMerged = plugins.lodash.merge(depcheckOptions, { ignoreDirs: [ // folder with these names will be ignored 'test', 'dist', 'bower_components' ], ignoreMatches: [ // ignore dependencies that matches these globs '@types/*', 'babel-preset-*' ] }); plugins.depcheck(paths.cwd, depcheckOptionsMerged, unused => { for (let item of unused.dependencies) { plugins.beautylog.warn(`Watch out: unused dependency "${item}"`); } for (let item in unused.missing) { plugins.beautylog.error(`missing dependency "${item}" in package.json`); } if (unused.missing.length > 0) { plugins.beautylog.info('exiting due to missing dependencies in package.json'); process.exit(1); } for (let item in unused.invalidFiles) { plugins.beautylog.warn(`Watch out: could not parse file ${item}`); } for (let item in unused.invalidDirs) { plugins.beautylog.warn(`Watch out: could not parse directory ${item}`); } done.resolve(configArg); }); return done.promise; }; let checkDevDependencies = (configArg: INpmtsConfig) => { let done = q.defer(); plugins.beautylog.ora.text('Check Module: Check devDependencies...'); let depcheckOptionsMerged = plugins.lodash.merge(depcheckOptions, { ignoreDirs: [ // folder with these names will be ignored 'ts', 'dist', 'bower_components' ], ignoreMatches: [ // ignore dependencies that matches these globs '@types/*', 'babel-preset-*' ] }); plugins.depcheck(paths.cwd, depcheckOptionsMerged, unused => { for (let item of unused.devDependencies) { plugins.beautylog.log(`unused devDependency ${item}`); } for (let item in unused.missing) { plugins.beautylog.error(`missing devDependency ${item}`); } if (unused.missing.length > 0) { plugins.beautylog.info('exiting due to missing dependencies in package.json'); process.exit(1); } for (let item in unused.invalidFiles) { plugins.beautylog.warn(`Watch out: could not parse file ${item}`); } for (let item in unused.invalidDirs) { plugins.beautylog.warn(`Watch out: could not parse directory ${item}`); } done.resolve(configArg); }); return done.promise; }; let checkNodeVersion = (configArg: INpmtsConfig) => { let done = q.defer(); plugins.beautylog.ora.text('checking node version'); done.resolve(configArg); return done.promise; }; export let run = async (configArg: INpmtsConfig) => { plugins.beautylog.ora.text('Check Module: ...'); if (configArg.checkDependencies) { configArg = await checkProjectTypings(configArg); configArg = await checkDependencies(configArg); configArg = await checkDevDependencies(configArg); configArg = await checkNodeVersion(configArg); return configArg; } else { configArg = await checkProjectTypings(configArg); return configArg; } };