@angular-devkit/build-angular
Version:
Angular Webpack Build Facade
270 lines • 35.8 kB
JavaScript
;
/**
* @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
*/
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const path = __importStar(require("path"));
const webpack_1 = __importDefault(require("webpack"));
const webpack_dev_middleware_1 = __importDefault(require("webpack-dev-middleware"));
const stats_1 = require("../../utils/stats");
const node_1 = require("@angular-devkit/core/node");
const index_1 = require("../../../../utils/index");
const KARMA_APPLICATION_PATH = '_karma_webpack_';
let blocked = [];
let isBlocked = false;
let webpackMiddleware;
let successCb;
let failureCb;
const init = (config, emitter) => {
if (!config.buildWebpack) {
throw new Error(`The '@angular-devkit/build-angular/plugins/karma' karma plugin is meant to` +
` be used from within Angular CLI and will not work correctly outside of it.`);
}
const options = config.buildWebpack.options;
const logger = config.buildWebpack.logger || (0, node_1.createConsoleLogger)();
successCb = config.buildWebpack.successCb;
failureCb = config.buildWebpack.failureCb;
// Add a reporter that fixes sourcemap urls.
if ((0, index_1.normalizeSourceMaps)(options.sourceMap).scripts) {
config.reporters.unshift('@angular-devkit/build-angular--sourcemap-reporter');
// Code taken from https://github.com/tschaub/karma-source-map-support.
// We can't use it directly because we need to add it conditionally in this file, and karma
// frameworks cannot be added dynamically.
const smsPath = path.dirname(require.resolve('source-map-support'));
const ksmsPath = path.dirname(require.resolve('karma-source-map-support'));
config.files.unshift({
pattern: path.join(smsPath, 'browser-source-map-support.js'),
included: true,
served: true,
watched: false,
}, { pattern: path.join(ksmsPath, 'client.js'), included: true, served: true, watched: false });
}
config.reporters.unshift('@angular-devkit/build-angular--event-reporter');
// When using code-coverage, auto-add karma-coverage.
if (options.codeCoverage &&
!config.reporters.some((r) => r === 'coverage' || r === 'coverage-istanbul')) {
config.reporters.push('coverage');
}
// Add webpack config.
const webpackConfig = config.buildWebpack.webpackConfig;
const webpackMiddlewareConfig = {
// Hide webpack output because its noisy.
stats: false,
publicPath: `/${KARMA_APPLICATION_PATH}/`,
};
// Use existing config if any.
config.webpack = { ...webpackConfig, ...config.webpack };
config.webpackMiddleware = { ...webpackMiddlewareConfig, ...config.webpackMiddleware };
// Our custom context and debug files list the webpack bundles directly instead of using
// the karma files array.
config.customContextFile = `${__dirname}/karma-context.html`;
config.customDebugFile = `${__dirname}/karma-debug.html`;
// Add the request blocker and the webpack server fallback.
config.beforeMiddleware = config.beforeMiddleware || [];
config.beforeMiddleware.push('@angular-devkit/build-angular--blocker');
config.middleware = config.middleware || [];
config.middleware.push('@angular-devkit/build-angular--fallback');
if (config.singleRun) {
// There's no option to turn off file watching in webpack-dev-server, but
// we can override the file watcher instead.
webpackConfig.plugins.unshift({
apply: (compiler) => {
compiler.hooks.afterEnvironment.tap('karma', () => {
compiler.watchFileSystem = { watch: () => { } };
});
},
});
}
// Files need to be served from a custom path for Karma.
webpackConfig.output.path = `/${KARMA_APPLICATION_PATH}/`;
webpackConfig.output.publicPath = `/${KARMA_APPLICATION_PATH}/`;
const compiler = (0, webpack_1.default)(webpackConfig, (error, stats) => {
if (error) {
throw error;
}
if (stats?.hasErrors()) {
// Only generate needed JSON stats and when needed.
const statsJson = stats?.toJson({
all: false,
children: true,
errors: true,
warnings: true,
});
logger.error((0, stats_1.statsErrorsToString)(statsJson, { colors: true }));
if (config.singleRun) {
// Notify potential listeners of the compile error.
emitter.emit('load_error');
}
// Finish Karma run early in case of compilation error.
emitter.emit('run_complete', [], { exitCode: 1 });
// Emit a failure build event if there are compilation errors.
failureCb();
}
});
function handler(callback) {
isBlocked = true;
callback?.();
}
compiler.hooks.invalid.tap('karma', () => handler());
compiler.hooks.watchRun.tapAsync('karma', (_, callback) => handler(callback));
compiler.hooks.run.tapAsync('karma', (_, callback) => handler(callback));
webpackMiddleware = (0, webpack_dev_middleware_1.default)(compiler, webpackMiddlewareConfig);
emitter.on('exit', (done) => {
webpackMiddleware.close();
compiler.close(() => done());
});
function unblock() {
isBlocked = false;
blocked.forEach((cb) => cb());
blocked = [];
}
let lastCompilationHash;
let isFirstRun = true;
return new Promise((resolve) => {
compiler.hooks.done.tap('karma', (stats) => {
if (isFirstRun) {
// This is needed to block Karma from launching browsers before Webpack writes the assets in memory.
// See the below:
// https://github.com/karma-runner/karma-chrome-launcher/issues/154#issuecomment-986661937
// https://github.com/angular/angular-cli/issues/22495
isFirstRun = false;
resolve();
}
if (stats.hasErrors()) {
lastCompilationHash = undefined;
}
else if (stats.hash != lastCompilationHash) {
// Refresh karma only when there are no webpack errors, and if the compilation changed.
lastCompilationHash = stats.hash;
emitter.refreshFiles();
}
unblock();
});
});
};
init.$inject = ['config', 'emitter'];
// Block requests until the Webpack compilation is done.
function requestBlocker() {
return function (_request, _response, next) {
if (isBlocked) {
blocked.push(next);
}
else {
next();
}
};
}
// Copied from "karma-jasmine-diff-reporter" source code:
// In case, when multiple reporters are used in conjunction
// with initSourcemapReporter, they both will show repetitive log
// messages when displaying everything that supposed to write to terminal.
// So just suppress any logs from initSourcemapReporter by doing nothing on
// browser log, because it is an utility reporter,
// unless it's alone in the "reporters" option and base reporter is used.
function muteDuplicateReporterLogging(context, config) {
context.writeCommonMsg = () => { };
const reporterName = '@angular/cli';
const hasTrailingReporters = config.reporters.slice(-1).pop() !== reporterName;
if (hasTrailingReporters) {
context.writeCommonMsg = () => { };
}
}
// Emits builder events.
const eventReporter = function (baseReporterDecorator, config) {
baseReporterDecorator(this);
muteDuplicateReporterLogging(this, config);
this.onRunComplete = function (_browsers, results) {
if (results.exitCode === 0) {
successCb();
}
else {
failureCb();
}
};
// avoid duplicate failure message
this.specFailure = () => { };
};
eventReporter.$inject = ['baseReporterDecorator', 'config'];
// Strip the server address and webpack scheme (webpack://) from error log.
const sourceMapReporter = function (baseReporterDecorator, config) {
baseReporterDecorator(this);
muteDuplicateReporterLogging(this, config);
const urlRegexp = /http:\/\/localhost:\d+\/_karma_webpack_\/(webpack:\/)?/gi;
this.onSpecComplete = function (_browser, result) {
if (!result.success) {
result.log = result.log.map((l) => l.replace(urlRegexp, ''));
}
};
// avoid duplicate complete message
this.onRunComplete = () => { };
// avoid duplicate failure message
this.specFailure = () => { };
};
sourceMapReporter.$inject = ['baseReporterDecorator', 'config'];
// When a request is not found in the karma server, try looking for it from the webpack server root.
function fallbackMiddleware() {
return function (request, response, next) {
if (webpackMiddleware) {
if (request.url && !new RegExp(`\\/${KARMA_APPLICATION_PATH}\\/.*`).test(request.url)) {
request.url = '/' + KARMA_APPLICATION_PATH + request.url;
}
webpackMiddleware(request, response, () => {
const alwaysServe = [
`/${KARMA_APPLICATION_PATH}/runtime.js`,
`/${KARMA_APPLICATION_PATH}/polyfills.js`,
`/${KARMA_APPLICATION_PATH}/scripts.js`,
`/${KARMA_APPLICATION_PATH}/styles.css`,
`/${KARMA_APPLICATION_PATH}/vendor.js`,
];
if (request.url && alwaysServe.includes(request.url)) {
response.statusCode = 200;
response.end();
}
else {
next();
}
});
}
else {
next();
}
};
}
module.exports = {
'framework:@angular-devkit/build-angular': ['factory', init],
'reporter:@angular-devkit/build-angular--sourcemap-reporter': ['type', sourceMapReporter],
'reporter:@angular-devkit/build-angular--event-reporter': ['type', eventReporter],
'middleware:@angular-devkit/build-angular--blocker': ['factory', requestBlocker],
'middleware:@angular-devkit/build-angular--fallback': ['factory', fallbackMiddleware],
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"karma.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/angular_devkit/build_angular/src/tools/webpack/plugins/karma/karma.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/* eslint-disable */\n// TODO: cleanup this file, it's copied as is from Angular CLI.\nimport * as http from 'http';\nimport * as path from 'path';\nimport webpack from 'webpack';\nimport webpackDevMiddleware from 'webpack-dev-middleware';\n\nimport { statsErrorsToString } from '../../utils/stats';\nimport { createConsoleLogger } from '@angular-devkit/core/node';\nimport { logging } from '@angular-devkit/core';\nimport { BuildOptions } from '../../../../utils/build-options';\nimport { normalizeSourceMaps } from '../../../../utils/index';\n\nconst KARMA_APPLICATION_PATH = '_karma_webpack_';\n\nlet blocked: any[] = [];\nlet isBlocked = false;\nlet webpackMiddleware: any;\nlet successCb: () => void;\nlet failureCb: () => void;\n\nconst init: any = (config: any, emitter: any) => {\n  if (!config.buildWebpack) {\n    throw new Error(\n      `The '@angular-devkit/build-angular/plugins/karma' karma plugin is meant to` +\n        ` be used from within Angular CLI and will not work correctly outside of it.`,\n    );\n  }\n  const options = config.buildWebpack.options as BuildOptions;\n  const logger: logging.Logger = config.buildWebpack.logger || createConsoleLogger();\n  successCb = config.buildWebpack.successCb;\n  failureCb = config.buildWebpack.failureCb;\n\n  // Add a reporter that fixes sourcemap urls.\n  if (normalizeSourceMaps(options.sourceMap).scripts) {\n    config.reporters.unshift('@angular-devkit/build-angular--sourcemap-reporter');\n\n    // Code taken from https://github.com/tschaub/karma-source-map-support.\n    // We can't use it directly because we need to add it conditionally in this file, and karma\n    // frameworks cannot be added dynamically.\n    const smsPath = path.dirname(require.resolve('source-map-support'));\n    const ksmsPath = path.dirname(require.resolve('karma-source-map-support'));\n\n    config.files.unshift(\n      {\n        pattern: path.join(smsPath, 'browser-source-map-support.js'),\n        included: true,\n        served: true,\n        watched: false,\n      },\n      { pattern: path.join(ksmsPath, 'client.js'), included: true, served: true, watched: false },\n    );\n  }\n\n  config.reporters.unshift('@angular-devkit/build-angular--event-reporter');\n\n  // When using code-coverage, auto-add karma-coverage.\n  if (\n    options.codeCoverage &&\n    !config.reporters.some((r: string) => r === 'coverage' || r === 'coverage-istanbul')\n  ) {\n    config.reporters.push('coverage');\n  }\n\n  // Add webpack config.\n  const webpackConfig = config.buildWebpack.webpackConfig;\n  const webpackMiddlewareConfig = {\n    // Hide webpack output because its noisy.\n    stats: false,\n    publicPath: `/${KARMA_APPLICATION_PATH}/`,\n  };\n\n  // Use existing config if any.\n  config.webpack = { ...webpackConfig, ...config.webpack };\n  config.webpackMiddleware = { ...webpackMiddlewareConfig, ...config.webpackMiddleware };\n\n  // Our custom context and debug files list the webpack bundles directly instead of using\n  // the karma files array.\n  config.customContextFile = `${__dirname}/karma-context.html`;\n  config.customDebugFile = `${__dirname}/karma-debug.html`;\n\n  // Add the request blocker and the webpack server fallback.\n  config.beforeMiddleware = config.beforeMiddleware || [];\n  config.beforeMiddleware.push('@angular-devkit/build-angular--blocker');\n  config.middleware = config.middleware || [];\n  config.middleware.push('@angular-devkit/build-angular--fallback');\n\n  if (config.singleRun) {\n    // There's no option to turn off file watching in webpack-dev-server, but\n    // we can override the file watcher instead.\n    webpackConfig.plugins.unshift({\n      apply: (compiler: any) => {\n        compiler.hooks.afterEnvironment.tap('karma', () => {\n          compiler.watchFileSystem = { watch: () => {} };\n        });\n      },\n    });\n  }\n  // Files need to be served from a custom path for Karma.\n  webpackConfig.output.path = `/${KARMA_APPLICATION_PATH}/`;\n  webpackConfig.output.publicPath = `/${KARMA_APPLICATION_PATH}/`;\n\n  const compiler = webpack(webpackConfig, (error, stats) => {\n    if (error) {\n      throw error;\n    }\n\n    if (stats?.hasErrors()) {\n      // Only generate needed JSON stats and when needed.\n      const statsJson = stats?.toJson({\n        all: false,\n        children: true,\n        errors: true,\n        warnings: true,\n      });\n\n      logger.error(statsErrorsToString(statsJson, { colors: true }));\n\n      if (config.singleRun) {\n        // Notify potential listeners of the compile error.\n        emitter.emit('load_error');\n      }\n\n      // Finish Karma run early in case of compilation error.\n      emitter.emit('run_complete', [], { exitCode: 1 });\n\n      // Emit a failure build event if there are compilation errors.\n      failureCb();\n    }\n  });\n\n  function handler(callback?: () => void): void {\n    isBlocked = true;\n    callback?.();\n  }\n\n  compiler.hooks.invalid.tap('karma', () => handler());\n  compiler.hooks.watchRun.tapAsync('karma', (_: any, callback: () => void) => handler(callback));\n  compiler.hooks.run.tapAsync('karma', (_: any, callback: () => void) => handler(callback));\n\n  webpackMiddleware = webpackDevMiddleware(compiler, webpackMiddlewareConfig);\n  emitter.on('exit', (done: any) => {\n    webpackMiddleware.close();\n    compiler.close(() => done());\n  });\n\n  function unblock() {\n    isBlocked = false;\n    blocked.forEach((cb) => cb());\n    blocked = [];\n  }\n\n  let lastCompilationHash: string | undefined;\n  let isFirstRun = true;\n\n  return new Promise<void>((resolve) => {\n    compiler.hooks.done.tap('karma', (stats) => {\n      if (isFirstRun) {\n        // This is needed to block Karma from launching browsers before Webpack writes the assets in memory.\n        // See the below:\n        // https://github.com/karma-runner/karma-chrome-launcher/issues/154#issuecomment-986661937\n        // https://github.com/angular/angular-cli/issues/22495\n        isFirstRun = false;\n        resolve();\n      }\n\n      if (stats.hasErrors()) {\n        lastCompilationHash = undefined;\n      } else if (stats.hash != lastCompilationHash) {\n        // Refresh karma only when there are no webpack errors, and if the compilation changed.\n        lastCompilationHash = stats.hash;\n        emitter.refreshFiles();\n      }\n\n      unblock();\n    });\n  });\n};\n\ninit.$inject = ['config', 'emitter'];\n\n// Block requests until the Webpack compilation is done.\nfunction requestBlocker() {\n  return function (_request: any, _response: any, next: () => void) {\n    if (isBlocked) {\n      blocked.push(next);\n    } else {\n      next();\n    }\n  };\n}\n\n// Copied from \"karma-jasmine-diff-reporter\" source code:\n// In case, when multiple reporters are used in conjunction\n// with initSourcemapReporter, they both will show repetitive log\n// messages when displaying everything that supposed to write to terminal.\n// So just suppress any logs from initSourcemapReporter by doing nothing on\n// browser log, because it is an utility reporter,\n// unless it's alone in the \"reporters\" option and base reporter is used.\nfunction muteDuplicateReporterLogging(context: any, config: any) {\n  context.writeCommonMsg = () => {};\n  const reporterName = '@angular/cli';\n  const hasTrailingReporters = config.reporters.slice(-1).pop() !== reporterName;\n\n  if (hasTrailingReporters) {\n    context.writeCommonMsg = () => {};\n  }\n}\n\n// Emits builder events.\nconst eventReporter: any = function (this: any, baseReporterDecorator: any, config: any) {\n  baseReporterDecorator(this);\n\n  muteDuplicateReporterLogging(this, config);\n\n  this.onRunComplete = function (_browsers: any, results: any) {\n    if (results.exitCode === 0) {\n      successCb();\n    } else {\n      failureCb();\n    }\n  };\n\n  // avoid duplicate failure message\n  this.specFailure = () => {};\n};\n\neventReporter.$inject = ['baseReporterDecorator', 'config'];\n\n// Strip the server address and webpack scheme (webpack://) from error log.\nconst sourceMapReporter: any = function (this: any, baseReporterDecorator: any, config: any) {\n  baseReporterDecorator(this);\n  muteDuplicateReporterLogging(this, config);\n\n  const urlRegexp = /http:\\/\\/localhost:\\d+\\/_karma_webpack_\\/(webpack:\\/)?/gi;\n\n  this.onSpecComplete = function (_browser: any, result: any) {\n    if (!result.success) {\n      result.log = result.log.map((l: string) => l.replace(urlRegexp, ''));\n    }\n  };\n\n  // avoid duplicate complete message\n  this.onRunComplete = () => {};\n\n  // avoid duplicate failure message\n  this.specFailure = () => {};\n};\n\nsourceMapReporter.$inject = ['baseReporterDecorator', 'config'];\n\n// When a request is not found in the karma server, try looking for it from the webpack server root.\nfunction fallbackMiddleware() {\n  return function (request: http.IncomingMessage, response: http.ServerResponse, next: () => void) {\n    if (webpackMiddleware) {\n      if (request.url && !new RegExp(`\\\\/${KARMA_APPLICATION_PATH}\\\\/.*`).test(request.url)) {\n        request.url = '/' + KARMA_APPLICATION_PATH + request.url;\n      }\n      webpackMiddleware(request, response, () => {\n        const alwaysServe = [\n          `/${KARMA_APPLICATION_PATH}/runtime.js`,\n          `/${KARMA_APPLICATION_PATH}/polyfills.js`,\n          `/${KARMA_APPLICATION_PATH}/scripts.js`,\n          `/${KARMA_APPLICATION_PATH}/styles.css`,\n          `/${KARMA_APPLICATION_PATH}/vendor.js`,\n        ];\n        if (request.url && alwaysServe.includes(request.url)) {\n          response.statusCode = 200;\n          response.end();\n        } else {\n          next();\n        }\n      });\n    } else {\n      next();\n    }\n  };\n}\n\nmodule.exports = {\n  'framework:@angular-devkit/build-angular': ['factory', init],\n  'reporter:@angular-devkit/build-angular--sourcemap-reporter': ['type', sourceMapReporter],\n  'reporter:@angular-devkit/build-angular--event-reporter': ['type', eventReporter],\n  'middleware:@angular-devkit/build-angular--blocker': ['factory', requestBlocker],\n  'middleware:@angular-devkit/build-angular--fallback': ['factory', fallbackMiddleware],\n};\n"]}