gulpTasks-dependencies.js 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. // Import Dependencies.
  2. const gulp = require("gulp");
  3. const path = require("path");
  4. const depcruise = require('dependency-cruiser');
  5. const colorConsole = require('../../NodeHelpers/colorConsole');
  6. // Read the full config.
  7. const config = require("../../Config/config.js");
  8. /*
  9. * TsLint all typescript files from the src directory.
  10. */
  11. const dependencies = function(settings, moduleName, cb) {
  12. var cruiseResult = depcruise.cruise(
  13. [path.relative(path.resolve("./"), settings.computed.mainDirectory)],
  14. {
  15. validate: true,
  16. ruleSet: {
  17. forbidden: [{
  18. name: 'no-circular',
  19. comment: 'circular dependencies will make you dizzy',
  20. severity: 'error',
  21. from: {},
  22. to: {
  23. circular: true
  24. }
  25. }],
  26. options: {
  27. doNotFollow: "node_modules",
  28. tsConfig: {
  29. fileName: settings.computed.tsConfigPath
  30. },
  31. webpackConfig: {
  32. fileName: settings.computed.webpackConfigPath
  33. }
  34. }
  35. }
  36. });
  37. if (cruiseResult.summary.error > 0) {
  38. var errors = cruiseResult.summary.violations;
  39. // Comparaison to remove once all done.
  40. // Comparaison to remove once all done.
  41. // Comparaison to remove once all done.
  42. var comparaisonData = { };
  43. for (let error of cruiseResult.summary.violations) {
  44. comparaisonData[error.from] = comparaisonData[error.from] || [];
  45. comparaisonData[error.from].push(error.to);
  46. }
  47. var fs = require("fs-extra");
  48. var baseValidationFile = "../../Config/" + moduleName + ".json";
  49. if (fs.existsSync(path.resolve(__dirname, baseValidationFile))) {
  50. var baseValidation = require(baseValidationFile);
  51. errors = [];
  52. for (let error in comparaisonData) {
  53. if (!baseValidation[error] || JSON.stringify(comparaisonData[error])!=JSON.stringify(baseValidation[error])) {
  54. errors.push({
  55. from: error.from,
  56. to: error.to
  57. });
  58. }
  59. }
  60. }
  61. else {
  62. errors = cruiseResult.summary.violations;
  63. }
  64. var minimist = require("minimist");
  65. var commandLineOptions = minimist(process.argv.slice(2), {
  66. boolean: ["saveCircular"]
  67. });
  68. if (commandLineOptions.saveCircular) {
  69. fs.writeJSONSync(path.resolve(__dirname, baseValidationFile), comparaisonData);
  70. }
  71. colorConsole.warn(`Still circular dependencies in ${moduleName.cyan}: ${("" + cruiseResult.summary.error).red}`);
  72. cb();
  73. return;
  74. // End Comparaison to remove once all done.
  75. // End Comparaison to remove once all done.
  76. // End Comparaison to remove once all done.
  77. colorConsole.error(`New circular dependencies in ${moduleName.cyan}: ${("" + cruiseResult.summary.error).red}`);
  78. for (let error of errors) {
  79. colorConsole.error(` From: '${error.from.replace(/\.\.\//g, "").yellow}' To: '${error.to.replace(/\.\.\//g, "").yellow}'`);
  80. }
  81. process.exit(1);
  82. }
  83. colorConsole.success("No New circular dependencies.");
  84. cb();
  85. }
  86. /**
  87. * Dynamic module linting for external library (mat, post processes, ...).
  88. */
  89. config.lintModules.map(function(module) {
  90. // Task will be like moduleName-circularDependencies
  91. gulp.task(module + "-circularDependencies", function(cb) {
  92. var settings = config[module];
  93. dependencies(settings, module, cb);
  94. });
  95. });
  96. /**
  97. * Full Librairies tsLint.
  98. */
  99. gulp.task("circularDependencies",
  100. gulp.series(config.lintModules.map((module) => {
  101. return module + "-circularDependencies";
  102. })
  103. ));