@angular-devkit/build-angular 15.2.0-next.2 → 15.2.0-next.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +13 -13
- package/src/babel/plugins/adjust-static-class-members.js +37 -2
- package/src/builders/browser-esbuild/angular/jit-compilation.d.ts +23 -0
- package/src/builders/browser-esbuild/angular/jit-compilation.js +99 -0
- package/src/builders/browser-esbuild/angular/jit-plugin-callbacks.d.ts +21 -0
- package/src/builders/browser-esbuild/angular/jit-plugin-callbacks.js +115 -0
- package/src/builders/browser-esbuild/angular/jit-resource-transformer.d.ts +17 -0
- package/src/builders/browser-esbuild/angular/jit-resource-transformer.js +186 -0
- package/src/builders/browser-esbuild/angular/uri.d.ts +54 -0
- package/src/builders/browser-esbuild/angular/uri.js +75 -0
- package/src/builders/browser-esbuild/compiler-plugin.d.ts +1 -0
- package/src/builders/browser-esbuild/compiler-plugin.js +15 -10
- package/src/builders/browser-esbuild/experimental-warnings.js +1 -4
- package/src/builders/browser-esbuild/index.js +4 -9
- package/src/builders/browser-esbuild/javascript-transformer-worker.d.ts +1 -0
- package/src/builders/browser-esbuild/javascript-transformer-worker.js +2 -2
- package/src/builders/browser-esbuild/javascript-transformer.d.ts +1 -0
- package/src/builders/browser-esbuild/javascript-transformer.js +3 -2
- package/src/builders/browser-esbuild/less-plugin.d.ts +14 -0
- package/src/builders/browser-esbuild/less-plugin.js +108 -0
- package/src/builders/browser-esbuild/options.d.ts +1 -0
- package/src/builders/browser-esbuild/options.js +3 -2
- package/src/builders/browser-esbuild/stylesheets.d.ts +1 -1
- package/src/builders/browser-esbuild/stylesheets.js +18 -7
- package/src/builders/karma/find-tests-plugin.js +12 -8
- package/src/builders/karma/index.js +13 -1
- package/src/builders/server/index.js +9 -3
- package/src/utils/esbuild-targets.js +2 -2
- package/src/webpack/plugins/karma/karma-context.html +4 -4
- package/src/webpack/plugins/karma/karma-debug.html +4 -4
|
@@ -122,7 +122,7 @@ async function normalizeOptions(context, projectName, options) {
|
|
|
122
122
|
};
|
|
123
123
|
}
|
|
124
124
|
// Initial options to keep
|
|
125
|
-
const { allowedCommonJsDependencies, baseHref, buildOptimizer, crossOrigin, externalDependencies, extractLicenses, inlineStyleLanguage = 'css', poll, preserveSymlinks, statsJson, stylePreprocessorOptions, subresourceIntegrity, verbose, watch, } = options;
|
|
125
|
+
const { allowedCommonJsDependencies, aot, baseHref, buildOptimizer, crossOrigin, externalDependencies, extractLicenses, inlineStyleLanguage = 'css', poll, preserveSymlinks, statsJson, stylePreprocessorOptions, subresourceIntegrity, verbose, watch, } = options;
|
|
126
126
|
// Return all the normalized options
|
|
127
127
|
return {
|
|
128
128
|
advancedOptimizations: buildOptimizer,
|
|
@@ -133,6 +133,7 @@ async function normalizeOptions(context, projectName, options) {
|
|
|
133
133
|
externalDependencies,
|
|
134
134
|
extractLicenses,
|
|
135
135
|
inlineStyleLanguage,
|
|
136
|
+
jit: !aot,
|
|
136
137
|
stats: !!statsJson,
|
|
137
138
|
poll,
|
|
138
139
|
// If not explicitly set, default to the Node.js process argument
|
|
@@ -157,4 +158,4 @@ async function normalizeOptions(context, projectName, options) {
|
|
|
157
158
|
};
|
|
158
159
|
}
|
|
159
160
|
exports.normalizeOptions = normalizeOptions;
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/options.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\nimport { BuilderContext } from '@angular-devkit/architect';\nimport * as path from 'path';\nimport { normalizeAssetPatterns, normalizeOptimization, normalizeSourceMaps } from '../../utils';\nimport { normalizeCacheOptions } from '../../utils/normalize-cache';\nimport { normalizePolyfills } from '../../utils/normalize-polyfills';\nimport { generateEntryPoints } from '../../utils/package-chunk-sort';\nimport { getIndexInputFile, getIndexOutputFile } from '../../utils/webpack-browser-config';\nimport { normalizeGlobalStyles } from '../../webpack/utils/helpers';\nimport { Schema as BrowserBuilderOptions, OutputHashing } from './schema';\n\nexport type NormalizedBrowserOptions = Awaited<ReturnType<typeof normalizeOptions>>;\n\n/**\n * Normalize the user provided options by creating full paths for all path based options\n * and converting multi-form options into a single form that can be directly used\n * by the build process.\n *\n * @param context The context for current builder execution.\n * @param projectName The name of the project for the current execution.\n * @param options An object containing the options to use for the build.\n * @returns An object containing normalized options required to perform the build.\n */\nexport async function normalizeOptions(\n  context: BuilderContext,\n  projectName: string,\n  options: BrowserBuilderOptions,\n) {\n  const workspaceRoot = context.workspaceRoot;\n  const projectMetadata = await context.getProjectMetadata(projectName);\n  const projectRoot = path.join(workspaceRoot, (projectMetadata.root as string | undefined) ?? '');\n  const projectSourceRoot = path.join(\n    workspaceRoot,\n    (projectMetadata.sourceRoot as string | undefined) ?? 'src',\n  );\n\n  const cacheOptions = normalizeCacheOptions(projectMetadata, workspaceRoot);\n\n  const mainEntryPoint = path.join(workspaceRoot, options.main);\n\n  // Currently esbuild do not support multiple files per entry-point\n  const [polyfillsEntryPoint, ...remainingPolyfills] = normalizePolyfills(\n    options.polyfills,\n    workspaceRoot,\n  );\n\n  if (remainingPolyfills.length) {\n    context.logger.warn(\n      `The 'polyfills' option currently does not support multiple entries by this experimental builder. The first entry will be used.`,\n    );\n  }\n\n  const tsconfig = path.join(workspaceRoot, options.tsConfig);\n  const outputPath = path.join(workspaceRoot, options.outputPath);\n  const optimizationOptions = normalizeOptimization(options.optimization);\n  const sourcemapOptions = normalizeSourceMaps(options.sourceMap ?? false);\n  const assets = options.assets?.length\n    ? normalizeAssetPatterns(options.assets, workspaceRoot, projectRoot, projectSourceRoot)\n    : undefined;\n\n  const outputNames = {\n    bundles:\n      options.outputHashing === OutputHashing.All || options.outputHashing === OutputHashing.Bundles\n        ? '[name].[hash]'\n        : '[name]',\n    media:\n      options.outputHashing === OutputHashing.All || options.outputHashing === OutputHashing.Media\n        ? '[name].[hash]'\n        : '[name]',\n  };\n  if (options.resourcesOutputPath) {\n    outputNames.media = path.join(options.resourcesOutputPath, outputNames.media);\n  }\n\n  let fileReplacements: Record<string, string> | undefined;\n  if (options.fileReplacements) {\n    for (const replacement of options.fileReplacements) {\n      fileReplacements ??= {};\n      fileReplacements[path.join(workspaceRoot, replacement.replace)] = path.join(\n        workspaceRoot,\n        replacement.with,\n      );\n    }\n  }\n\n  const globalStyles: { name: string; files: string[]; initial: boolean }[] = [];\n  if (options.styles?.length) {\n    const { entryPoints: stylesheetEntrypoints, noInjectNames } = normalizeGlobalStyles(\n      options.styles || [],\n    );\n    for (const [name, files] of Object.entries(stylesheetEntrypoints)) {\n      globalStyles.push({ name, files, initial: !noInjectNames.includes(name) });\n    }\n  }\n\n  let serviceWorkerOptions;\n  if (options.serviceWorker) {\n    // If ngswConfigPath is not specified, the default is 'ngsw-config.json' within the project root\n    serviceWorkerOptions = options.ngswConfigPath\n      ? path.join(workspaceRoot, options.ngswConfigPath)\n      : path.join(projectRoot, 'ngsw-config.json');\n  }\n\n  // Setup bundler entry points\n  const entryPoints: Record<string, string> = {\n    main: mainEntryPoint,\n  };\n  if (polyfillsEntryPoint) {\n    entryPoints['polyfills'] = polyfillsEntryPoint;\n  }\n\n  let indexHtmlOptions;\n  if (options.index) {\n    indexHtmlOptions = {\n      input: path.join(workspaceRoot, getIndexInputFile(options.index)),\n      // The output file will be created within the configured output path\n      output: getIndexOutputFile(options.index),\n      // TODO: Use existing information from above to create the insertion order\n      insertionOrder: generateEntryPoints({\n        scripts: options.scripts ?? [],\n        styles: options.styles ?? [],\n      }),\n    };\n  }\n\n  // Initial options to keep\n  const {\n    allowedCommonJsDependencies,\n    baseHref,\n    buildOptimizer,\n    crossOrigin,\n    externalDependencies,\n    extractLicenses,\n    inlineStyleLanguage = 'css',\n    poll,\n    preserveSymlinks,\n    statsJson,\n    stylePreprocessorOptions,\n    subresourceIntegrity,\n    verbose,\n    watch,\n  } = options;\n\n  // Return all the normalized options\n  return {\n    advancedOptimizations: buildOptimizer,\n    allowedCommonJsDependencies,\n    baseHref,\n    cacheOptions,\n    crossOrigin,\n    externalDependencies,\n    extractLicenses,\n    inlineStyleLanguage,\n    stats: !!statsJson,\n    poll,\n    // If not explicitly set, default to the Node.js process argument\n    preserveSymlinks: preserveSymlinks ?? process.execArgv.includes('--preserve-symlinks'),\n    stylePreprocessorOptions,\n    subresourceIntegrity,\n    verbose,\n    watch,\n    workspaceRoot,\n    entryPoints,\n    optimizationOptions,\n    outputPath,\n    sourcemapOptions,\n    tsconfig,\n    projectRoot,\n    assets,\n    outputNames,\n    fileReplacements,\n    globalStyles,\n    serviceWorkerOptions,\n    indexHtmlOptions,\n  };\n}\n"]}
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/options.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\nimport { BuilderContext } from '@angular-devkit/architect';\nimport * as path from 'path';\nimport { normalizeAssetPatterns, normalizeOptimization, normalizeSourceMaps } from '../../utils';\nimport { normalizeCacheOptions } from '../../utils/normalize-cache';\nimport { normalizePolyfills } from '../../utils/normalize-polyfills';\nimport { generateEntryPoints } from '../../utils/package-chunk-sort';\nimport { getIndexInputFile, getIndexOutputFile } from '../../utils/webpack-browser-config';\nimport { normalizeGlobalStyles } from '../../webpack/utils/helpers';\nimport { Schema as BrowserBuilderOptions, OutputHashing } from './schema';\n\nexport type NormalizedBrowserOptions = Awaited<ReturnType<typeof normalizeOptions>>;\n\n/**\n * Normalize the user provided options by creating full paths for all path based options\n * and converting multi-form options into a single form that can be directly used\n * by the build process.\n *\n * @param context The context for current builder execution.\n * @param projectName The name of the project for the current execution.\n * @param options An object containing the options to use for the build.\n * @returns An object containing normalized options required to perform the build.\n */\nexport async function normalizeOptions(\n  context: BuilderContext,\n  projectName: string,\n  options: BrowserBuilderOptions,\n) {\n  const workspaceRoot = context.workspaceRoot;\n  const projectMetadata = await context.getProjectMetadata(projectName);\n  const projectRoot = path.join(workspaceRoot, (projectMetadata.root as string | undefined) ?? '');\n  const projectSourceRoot = path.join(\n    workspaceRoot,\n    (projectMetadata.sourceRoot as string | undefined) ?? 'src',\n  );\n\n  const cacheOptions = normalizeCacheOptions(projectMetadata, workspaceRoot);\n\n  const mainEntryPoint = path.join(workspaceRoot, options.main);\n\n  // Currently esbuild do not support multiple files per entry-point\n  const [polyfillsEntryPoint, ...remainingPolyfills] = normalizePolyfills(\n    options.polyfills,\n    workspaceRoot,\n  );\n\n  if (remainingPolyfills.length) {\n    context.logger.warn(\n      `The 'polyfills' option currently does not support multiple entries by this experimental builder. The first entry will be used.`,\n    );\n  }\n\n  const tsconfig = path.join(workspaceRoot, options.tsConfig);\n  const outputPath = path.join(workspaceRoot, options.outputPath);\n  const optimizationOptions = normalizeOptimization(options.optimization);\n  const sourcemapOptions = normalizeSourceMaps(options.sourceMap ?? false);\n  const assets = options.assets?.length\n    ? normalizeAssetPatterns(options.assets, workspaceRoot, projectRoot, projectSourceRoot)\n    : undefined;\n\n  const outputNames = {\n    bundles:\n      options.outputHashing === OutputHashing.All || options.outputHashing === OutputHashing.Bundles\n        ? '[name].[hash]'\n        : '[name]',\n    media:\n      options.outputHashing === OutputHashing.All || options.outputHashing === OutputHashing.Media\n        ? '[name].[hash]'\n        : '[name]',\n  };\n  if (options.resourcesOutputPath) {\n    outputNames.media = path.join(options.resourcesOutputPath, outputNames.media);\n  }\n\n  let fileReplacements: Record<string, string> | undefined;\n  if (options.fileReplacements) {\n    for (const replacement of options.fileReplacements) {\n      fileReplacements ??= {};\n      fileReplacements[path.join(workspaceRoot, replacement.replace)] = path.join(\n        workspaceRoot,\n        replacement.with,\n      );\n    }\n  }\n\n  const globalStyles: { name: string; files: string[]; initial: boolean }[] = [];\n  if (options.styles?.length) {\n    const { entryPoints: stylesheetEntrypoints, noInjectNames } = normalizeGlobalStyles(\n      options.styles || [],\n    );\n    for (const [name, files] of Object.entries(stylesheetEntrypoints)) {\n      globalStyles.push({ name, files, initial: !noInjectNames.includes(name) });\n    }\n  }\n\n  let serviceWorkerOptions;\n  if (options.serviceWorker) {\n    // If ngswConfigPath is not specified, the default is 'ngsw-config.json' within the project root\n    serviceWorkerOptions = options.ngswConfigPath\n      ? path.join(workspaceRoot, options.ngswConfigPath)\n      : path.join(projectRoot, 'ngsw-config.json');\n  }\n\n  // Setup bundler entry points\n  const entryPoints: Record<string, string> = {\n    main: mainEntryPoint,\n  };\n  if (polyfillsEntryPoint) {\n    entryPoints['polyfills'] = polyfillsEntryPoint;\n  }\n\n  let indexHtmlOptions;\n  if (options.index) {\n    indexHtmlOptions = {\n      input: path.join(workspaceRoot, getIndexInputFile(options.index)),\n      // The output file will be created within the configured output path\n      output: getIndexOutputFile(options.index),\n      // TODO: Use existing information from above to create the insertion order\n      insertionOrder: generateEntryPoints({\n        scripts: options.scripts ?? [],\n        styles: options.styles ?? [],\n      }),\n    };\n  }\n\n  // Initial options to keep\n  const {\n    allowedCommonJsDependencies,\n    aot,\n    baseHref,\n    buildOptimizer,\n    crossOrigin,\n    externalDependencies,\n    extractLicenses,\n    inlineStyleLanguage = 'css',\n    poll,\n    preserveSymlinks,\n    statsJson,\n    stylePreprocessorOptions,\n    subresourceIntegrity,\n    verbose,\n    watch,\n  } = options;\n\n  // Return all the normalized options\n  return {\n    advancedOptimizations: buildOptimizer,\n    allowedCommonJsDependencies,\n    baseHref,\n    cacheOptions,\n    crossOrigin,\n    externalDependencies,\n    extractLicenses,\n    inlineStyleLanguage,\n    jit: !aot,\n    stats: !!statsJson,\n    poll,\n    // If not explicitly set, default to the Node.js process argument\n    preserveSymlinks: preserveSymlinks ?? process.execArgv.includes('--preserve-symlinks'),\n    stylePreprocessorOptions,\n    subresourceIntegrity,\n    verbose,\n    watch,\n    workspaceRoot,\n    entryPoints,\n    optimizationOptions,\n    outputPath,\n    sourcemapOptions,\n    tsconfig,\n    projectRoot,\n    assets,\n    outputNames,\n    fileReplacements,\n    globalStyles,\n    serviceWorkerOptions,\n    indexHtmlOptions,\n  };\n}\n"]}
|
|
@@ -36,7 +36,7 @@ export declare function createStylesheetBundleOptions(options: BundleStylesheetO
|
|
|
36
36
|
* @param options An object containing the stylesheet bundling options.
|
|
37
37
|
* @returns An object containing the output of the bundling operation.
|
|
38
38
|
*/
|
|
39
|
-
export declare function bundleComponentStylesheet(
|
|
39
|
+
export declare function bundleComponentStylesheet(language: string, data: string, filename: string, inline: boolean, options: BundleStylesheetOptions): Promise<{
|
|
40
40
|
errors: import("esbuild").Message[] | undefined;
|
|
41
41
|
warnings: import("esbuild").Message[];
|
|
42
42
|
contents: string;
|
|
@@ -34,14 +34,21 @@ exports.bundleComponentStylesheet = exports.createStylesheetBundleOptions = void
|
|
|
34
34
|
const path = __importStar(require("node:path"));
|
|
35
35
|
const css_resource_plugin_1 = require("./css-resource-plugin");
|
|
36
36
|
const esbuild_1 = require("./esbuild");
|
|
37
|
+
const less_plugin_1 = require("./less-plugin");
|
|
37
38
|
const sass_plugin_1 = require("./sass-plugin");
|
|
39
|
+
/**
|
|
40
|
+
* A counter for component styles used to generate unique build-time identifiers for each stylesheet.
|
|
41
|
+
*/
|
|
42
|
+
let componentStyleCounter = 0;
|
|
38
43
|
function createStylesheetBundleOptions(options, inlineComponentData) {
|
|
39
44
|
var _a, _b, _c;
|
|
45
|
+
// Ensure preprocessor include paths are absolute based on the workspace root
|
|
46
|
+
const includePaths = (_a = options.includePaths) === null || _a === void 0 ? void 0 : _a.map((includePath) => path.resolve(options.workspaceRoot, includePath));
|
|
40
47
|
return {
|
|
41
48
|
absWorkingDir: options.workspaceRoot,
|
|
42
49
|
bundle: true,
|
|
43
|
-
entryNames: (
|
|
44
|
-
assetNames: (
|
|
50
|
+
entryNames: (_b = options.outputNames) === null || _b === void 0 ? void 0 : _b.bundles,
|
|
51
|
+
assetNames: (_c = options.outputNames) === null || _c === void 0 ? void 0 : _c.media,
|
|
45
52
|
logLevel: 'silent',
|
|
46
53
|
minify: options.optimization,
|
|
47
54
|
metafile: true,
|
|
@@ -57,8 +64,12 @@ function createStylesheetBundleOptions(options, inlineComponentData) {
|
|
|
57
64
|
plugins: [
|
|
58
65
|
(0, sass_plugin_1.createSassPlugin)({
|
|
59
66
|
sourcemap: !!options.sourcemap,
|
|
60
|
-
|
|
61
|
-
|
|
67
|
+
loadPaths: includePaths,
|
|
68
|
+
inlineComponentData,
|
|
69
|
+
}),
|
|
70
|
+
(0, less_plugin_1.createLessPlugin)({
|
|
71
|
+
sourcemap: !!options.sourcemap,
|
|
72
|
+
includePaths,
|
|
62
73
|
inlineComponentData,
|
|
63
74
|
}),
|
|
64
75
|
(0, css_resource_plugin_1.createCssResourcePlugin)(),
|
|
@@ -80,9 +91,9 @@ exports.createStylesheetBundleOptions = createStylesheetBundleOptions;
|
|
|
80
91
|
* @param options An object containing the stylesheet bundling options.
|
|
81
92
|
* @returns An object containing the output of the bundling operation.
|
|
82
93
|
*/
|
|
83
|
-
async function bundleComponentStylesheet(
|
|
94
|
+
async function bundleComponentStylesheet(language, data, filename, inline, options) {
|
|
84
95
|
const namespace = 'angular:styles/component';
|
|
85
|
-
const entry = [language,
|
|
96
|
+
const entry = [language, componentStyleCounter++, filename].join(';');
|
|
86
97
|
const buildOptions = createStylesheetBundleOptions(options, { [entry]: data });
|
|
87
98
|
buildOptions.entryPoints = [`${namespace};${entry}`];
|
|
88
99
|
buildOptions.plugins.push({
|
|
@@ -148,4 +159,4 @@ async function bundleComponentStylesheet(identifier, language, data, filename, i
|
|
|
148
159
|
};
|
|
149
160
|
}
|
|
150
161
|
exports.bundleComponentStylesheet = bundleComponentStylesheet;
|
|
151
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stylesheets.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/stylesheets.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\nimport type { BuildOptions, OutputFile } from 'esbuild';\nimport * as path from 'node:path';\nimport { createCssResourcePlugin } from './css-resource-plugin';\nimport { BundlerContext } from './esbuild';\nimport { createSassPlugin } from './sass-plugin';\n\nexport interface BundleStylesheetOptions {\n  workspaceRoot: string;\n  optimization: boolean;\n  preserveSymlinks?: boolean;\n  sourcemap: boolean | 'external' | 'inline';\n  outputNames?: { bundles?: string; media?: string };\n  includePaths?: string[];\n  externalDependencies?: string[];\n  target: string[];\n}\n\nexport function createStylesheetBundleOptions(\n  options: BundleStylesheetOptions,\n  inlineComponentData?: Record<string, string>,\n): BuildOptions & { plugins: NonNullable<BuildOptions['plugins']> } {\n  return {\n    absWorkingDir: options.workspaceRoot,\n    bundle: true,\n    entryNames: options.outputNames?.bundles,\n    assetNames: options.outputNames?.media,\n    logLevel: 'silent',\n    minify: options.optimization,\n    metafile: true,\n    sourcemap: options.sourcemap,\n    outdir: options.workspaceRoot,\n    write: false,\n    platform: 'browser',\n    target: options.target,\n    preserveSymlinks: options.preserveSymlinks,\n    external: options.externalDependencies,\n    conditions: ['style', 'sass'],\n    mainFields: ['style', 'sass'],\n    plugins: [\n      createSassPlugin({\n        sourcemap: !!options.sourcemap,\n        // Ensure Sass load paths are absolute based on the workspace root\n        loadPaths: options.includePaths?.map((includePath) =>\n          path.resolve(options.workspaceRoot, includePath),\n        ),\n        inlineComponentData,\n      }),\n      createCssResourcePlugin(),\n    ],\n  };\n}\n\n/**\n * Bundles a component stylesheet. The stylesheet can be either an inline stylesheet that\n * is contained within the Component's metadata definition or an external file referenced\n * from the Component's metadata definition.\n *\n * @param identifier A unique string identifier for the component stylesheet.\n * @param language The language of the stylesheet such as `css` or `scss`.\n * @param data The string content of the stylesheet.\n * @param filename The filename representing the source of the stylesheet content.\n * @param inline If true, the stylesheet source is within the component metadata;\n * if false, the source is a stylesheet file.\n * @param options An object containing the stylesheet bundling options.\n * @returns An object containing the output of the bundling operation.\n */\nexport async function bundleComponentStylesheet(\n  identifier: string,\n  language: string,\n  data: string,\n  filename: string,\n  inline: boolean,\n  options: BundleStylesheetOptions,\n) {\n  const namespace = 'angular:styles/component';\n  const entry = [language, identifier, filename].join(';');\n\n  const buildOptions = createStylesheetBundleOptions(options, { [entry]: data });\n  buildOptions.entryPoints = [`${namespace};${entry}`];\n  buildOptions.plugins.push({\n    name: 'angular-component-styles',\n    setup(build) {\n      build.onResolve({ filter: /^angular:styles\\/component;/ }, (args) => {\n        if (args.kind !== 'entry-point') {\n          return null;\n        }\n\n        if (inline) {\n          return {\n            path: entry,\n            namespace,\n          };\n        } else {\n          return {\n            path: filename,\n          };\n        }\n      });\n      build.onLoad({ filter: /^css;/, namespace }, async () => {\n        return {\n          contents: data,\n          loader: 'css',\n          resolveDir: path.dirname(filename),\n        };\n      });\n    },\n  });\n\n  // Execute esbuild\n  const context = new BundlerContext(options.workspaceRoot, false, buildOptions);\n  const result = await context.bundle();\n\n  // Extract the result of the bundling from the output files\n  let contents = '';\n  let map;\n  let outputPath;\n  const resourceFiles: OutputFile[] = [];\n  if (!result.errors) {\n    for (const outputFile of result.outputFiles) {\n      const filename = path.basename(outputFile.path);\n      if (filename.endsWith('.css')) {\n        outputPath = outputFile.path;\n        contents = outputFile.text;\n      } else if (filename.endsWith('.css.map')) {\n        map = outputFile.text;\n      } else {\n        // The output files could also contain resources (images/fonts/etc.) that were referenced\n        resourceFiles.push(outputFile);\n      }\n    }\n  }\n\n  return {\n    errors: result.errors,\n    warnings: result.warnings,\n    contents,\n    map,\n    path: outputPath,\n    resourceFiles,\n    metafile: result.errors ? undefined : result.metafile,\n  };\n}\n"]}
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stylesheets.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/stylesheets.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\nimport type { BuildOptions, OutputFile } from 'esbuild';\nimport * as path from 'node:path';\nimport { createCssResourcePlugin } from './css-resource-plugin';\nimport { BundlerContext } from './esbuild';\nimport { createLessPlugin } from './less-plugin';\nimport { createSassPlugin } from './sass-plugin';\n\n/**\n * A counter for component styles used to generate unique build-time identifiers for each stylesheet.\n */\nlet componentStyleCounter = 0;\n\nexport interface BundleStylesheetOptions {\n  workspaceRoot: string;\n  optimization: boolean;\n  preserveSymlinks?: boolean;\n  sourcemap: boolean | 'external' | 'inline';\n  outputNames?: { bundles?: string; media?: string };\n  includePaths?: string[];\n  externalDependencies?: string[];\n  target: string[];\n}\n\nexport function createStylesheetBundleOptions(\n  options: BundleStylesheetOptions,\n  inlineComponentData?: Record<string, string>,\n): BuildOptions & { plugins: NonNullable<BuildOptions['plugins']> } {\n  // Ensure preprocessor include paths are absolute based on the workspace root\n  const includePaths = options.includePaths?.map((includePath) =>\n    path.resolve(options.workspaceRoot, includePath),\n  );\n\n  return {\n    absWorkingDir: options.workspaceRoot,\n    bundle: true,\n    entryNames: options.outputNames?.bundles,\n    assetNames: options.outputNames?.media,\n    logLevel: 'silent',\n    minify: options.optimization,\n    metafile: true,\n    sourcemap: options.sourcemap,\n    outdir: options.workspaceRoot,\n    write: false,\n    platform: 'browser',\n    target: options.target,\n    preserveSymlinks: options.preserveSymlinks,\n    external: options.externalDependencies,\n    conditions: ['style', 'sass'],\n    mainFields: ['style', 'sass'],\n    plugins: [\n      createSassPlugin({\n        sourcemap: !!options.sourcemap,\n        loadPaths: includePaths,\n        inlineComponentData,\n      }),\n      createLessPlugin({\n        sourcemap: !!options.sourcemap,\n        includePaths,\n        inlineComponentData,\n      }),\n      createCssResourcePlugin(),\n    ],\n  };\n}\n\n/**\n * Bundles a component stylesheet. The stylesheet can be either an inline stylesheet that\n * is contained within the Component's metadata definition or an external file referenced\n * from the Component's metadata definition.\n *\n * @param identifier A unique string identifier for the component stylesheet.\n * @param language The language of the stylesheet such as `css` or `scss`.\n * @param data The string content of the stylesheet.\n * @param filename The filename representing the source of the stylesheet content.\n * @param inline If true, the stylesheet source is within the component metadata;\n * if false, the source is a stylesheet file.\n * @param options An object containing the stylesheet bundling options.\n * @returns An object containing the output of the bundling operation.\n */\nexport async function bundleComponentStylesheet(\n  language: string,\n  data: string,\n  filename: string,\n  inline: boolean,\n  options: BundleStylesheetOptions,\n) {\n  const namespace = 'angular:styles/component';\n  const entry = [language, componentStyleCounter++, filename].join(';');\n\n  const buildOptions = createStylesheetBundleOptions(options, { [entry]: data });\n  buildOptions.entryPoints = [`${namespace};${entry}`];\n  buildOptions.plugins.push({\n    name: 'angular-component-styles',\n    setup(build) {\n      build.onResolve({ filter: /^angular:styles\\/component;/ }, (args) => {\n        if (args.kind !== 'entry-point') {\n          return null;\n        }\n\n        if (inline) {\n          return {\n            path: entry,\n            namespace,\n          };\n        } else {\n          return {\n            path: filename,\n          };\n        }\n      });\n      build.onLoad({ filter: /^css;/, namespace }, async () => {\n        return {\n          contents: data,\n          loader: 'css',\n          resolveDir: path.dirname(filename),\n        };\n      });\n    },\n  });\n\n  // Execute esbuild\n  const context = new BundlerContext(options.workspaceRoot, false, buildOptions);\n  const result = await context.bundle();\n\n  // Extract the result of the bundling from the output files\n  let contents = '';\n  let map;\n  let outputPath;\n  const resourceFiles: OutputFile[] = [];\n  if (!result.errors) {\n    for (const outputFile of result.outputFiles) {\n      const filename = path.basename(outputFile.path);\n      if (filename.endsWith('.css')) {\n        outputPath = outputFile.path;\n        contents = outputFile.text;\n      } else if (filename.endsWith('.css.map')) {\n        map = outputFile.text;\n      } else {\n        // The output files could also contain resources (images/fonts/etc.) that were referenced\n        resourceFiles.push(outputFile);\n      }\n    }\n  }\n\n  return {\n    errors: result.errors,\n    warnings: result.warnings,\n    contents,\n    map,\n    path: outputPath,\n    resourceFiles,\n    metafile: result.errors ? undefined : result.metafile,\n  };\n}\n"]}
|
|
@@ -37,9 +37,9 @@ exports.FindTestsPlugin = void 0;
|
|
|
37
37
|
const assert_1 = __importDefault(require("assert"));
|
|
38
38
|
const fs_1 = require("fs");
|
|
39
39
|
const glob_1 = __importStar(require("glob"));
|
|
40
|
+
const mini_css_extract_plugin_1 = require("mini-css-extract-plugin");
|
|
40
41
|
const path_1 = require("path");
|
|
41
42
|
const util_1 = require("util");
|
|
42
|
-
const webpack_diagnostics_1 = require("../../utils/webpack-diagnostics");
|
|
43
43
|
const globPromise = (0, util_1.promisify)(glob_1.default);
|
|
44
44
|
/**
|
|
45
45
|
* The name of the plugin provided to Webpack when tapping Webpack compiler hooks.
|
|
@@ -57,17 +57,21 @@ class FindTestsPlugin {
|
|
|
57
57
|
// Add tests files are part of the entry-point.
|
|
58
58
|
webpackOptions.entry = async () => {
|
|
59
59
|
const specFiles = await findTests(include, exclude, workspaceRoot, projectSourceRoot);
|
|
60
|
-
if (!specFiles.length) {
|
|
61
|
-
(0, assert_1.default)(this.compilation, 'Compilation cannot be undefined.');
|
|
62
|
-
(0, webpack_diagnostics_1.addError)(this.compilation, `Specified patterns: "${include.join(', ')}" did not match any spec files.`);
|
|
63
|
-
}
|
|
64
60
|
const entrypoints = await entry;
|
|
65
61
|
const entrypoint = entrypoints['main'];
|
|
66
62
|
if (!entrypoint.import) {
|
|
67
63
|
throw new Error(`Cannot find 'main' entrypoint.`);
|
|
68
64
|
}
|
|
69
|
-
|
|
70
|
-
|
|
65
|
+
if (specFiles.length) {
|
|
66
|
+
originalImport !== null && originalImport !== void 0 ? originalImport : (originalImport = entrypoint.import);
|
|
67
|
+
entrypoint.import = [...originalImport, ...specFiles];
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
(0, assert_1.default)(this.compilation, 'Compilation cannot be undefined.');
|
|
71
|
+
this.compilation
|
|
72
|
+
.getLogger(mini_css_extract_plugin_1.pluginName)
|
|
73
|
+
.error(`Specified patterns: "${include.join(', ')}" did not match any spec files.`);
|
|
74
|
+
}
|
|
71
75
|
return entrypoints;
|
|
72
76
|
};
|
|
73
77
|
compiler.hooks.thisCompilation.tap(PLUGIN_NAME, (compilation) => {
|
|
@@ -138,4 +142,4 @@ async function exists(path) {
|
|
|
138
142
|
return false;
|
|
139
143
|
}
|
|
140
144
|
}
|
|
141
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"find-tests-plugin.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/karma/find-tests-plugin.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\nimport assert from 'assert';\nimport { PathLike, constants, promises as fs } from 'fs';\nimport glob, { hasMagic } from 'glob';\nimport { basename, dirname, extname, join, relative } from 'path';\nimport { promisify } from 'util';\nimport type { Compilation, Compiler } from 'webpack';\nimport { addError } from '../../utils/webpack-diagnostics';\n\nconst globPromise = promisify(glob);\n\n/**\n * The name of the plugin provided to Webpack when tapping Webpack compiler hooks.\n */\nconst PLUGIN_NAME = 'angular-find-tests-plugin';\n\nexport interface FindTestsPluginOptions {\n  include?: string[];\n  exclude?: string[];\n  workspaceRoot: string;\n  projectSourceRoot: string;\n}\n\nexport class FindTestsPlugin {\n  private compilation: Compilation | undefined;\n\n  constructor(private options: FindTestsPluginOptions) {}\n\n  apply(compiler: Compiler): void {\n    const {\n      include = ['**/*.spec.ts'],\n      exclude = [],\n      projectSourceRoot,\n      workspaceRoot,\n    } = this.options;\n    const webpackOptions = compiler.options;\n    const entry =\n      typeof webpackOptions.entry === 'function' ? webpackOptions.entry() : webpackOptions.entry;\n\n    let originalImport: string[] | undefined;\n\n    // Add tests files are part of the entry-point.\n    webpackOptions.entry = async () => {\n      const specFiles = await findTests(include, exclude, workspaceRoot, projectSourceRoot);\n\n      if (!specFiles.length) {\n        assert(this.compilation, 'Compilation cannot be undefined.');\n        addError(\n          this.compilation,\n          `Specified patterns: \"${include.join(', ')}\" did not match any spec files.`,\n        );\n      }\n\n      const entrypoints = await entry;\n      const entrypoint = entrypoints['main'];\n      if (!entrypoint.import) {\n        throw new Error(`Cannot find 'main' entrypoint.`);\n      }\n\n      originalImport ??= entrypoint.import;\n      entrypoint.import = [...originalImport, ...specFiles];\n\n      return entrypoints;\n    };\n\n    compiler.hooks.thisCompilation.tap(PLUGIN_NAME, (compilation) => {\n      this.compilation = compilation;\n      compilation.contextDependencies.add(projectSourceRoot);\n    });\n  }\n}\n\n// go through all patterns and find unique list of files\nasync function findTests(\n  include: string[],\n  exclude: string[],\n  workspaceRoot: string,\n  projectSourceRoot: string,\n): Promise<string[]> {\n  const matchingTestsPromises = include.map((pattern) =>\n    findMatchingTests(pattern, exclude, workspaceRoot, projectSourceRoot),\n  );\n  const files = await Promise.all(matchingTestsPromises);\n\n  // Unique file names\n  return [...new Set(files.flat())];\n}\n\nconst normalizePath = (path: string): string => path.replace(/\\\\/g, '/');\n\nasync function findMatchingTests(\n  pattern: string,\n  ignore: string[],\n  workspaceRoot: string,\n  projectSourceRoot: string,\n): Promise<string[]> {\n  // normalize pattern, glob lib only accepts forward slashes\n  let normalizedPattern = normalizePath(pattern);\n  if (normalizedPattern.charAt(0) === '/') {\n    normalizedPattern = normalizedPattern.substring(1);\n  }\n\n  const relativeProjectRoot = normalizePath(relative(workspaceRoot, projectSourceRoot) + '/');\n\n  // remove relativeProjectRoot to support relative paths from root\n  // such paths are easy to get when running scripts via IDEs\n  if (normalizedPattern.startsWith(relativeProjectRoot)) {\n    normalizedPattern = normalizedPattern.substring(relativeProjectRoot.length);\n  }\n\n  // special logic when pattern does not look like a glob\n  if (!hasMagic(normalizedPattern)) {\n    if (await isDirectory(join(projectSourceRoot, normalizedPattern))) {\n      normalizedPattern = `${normalizedPattern}/**/*.spec.@(ts|tsx)`;\n    } else {\n      // see if matching spec file exists\n      const fileExt = extname(normalizedPattern);\n      // Replace extension to `.spec.ext`. Example: `src/app/app.component.ts`-> `src/app/app.component.spec.ts`\n      const potentialSpec = join(\n        projectSourceRoot,\n        dirname(normalizedPattern),\n        `${basename(normalizedPattern, fileExt)}.spec${fileExt}`,\n      );\n\n      if (await exists(potentialSpec)) {\n        return [potentialSpec];\n      }\n    }\n  }\n\n  return globPromise(normalizedPattern, {\n    cwd: projectSourceRoot,\n    root: projectSourceRoot,\n    nomount: true,\n    absolute: true,\n    ignore: ['**/node_modules/**', ...ignore],\n  });\n}\n\nasync function isDirectory(path: PathLike): Promise<boolean> {\n  try {\n    const stats = await fs.stat(path);\n\n    return stats.isDirectory();\n  } catch {\n    return false;\n  }\n}\n\nasync function exists(path: PathLike): Promise<boolean> {\n  try {\n    await fs.access(path, constants.F_OK);\n\n    return true;\n  } catch {\n    return false;\n  }\n}\n"]}
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"find-tests-plugin.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/karma/find-tests-plugin.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\nimport assert from 'assert';\nimport { PathLike, constants, promises as fs } from 'fs';\nimport glob, { hasMagic } from 'glob';\nimport { pluginName } from 'mini-css-extract-plugin';\nimport { basename, dirname, extname, join, relative } from 'path';\nimport { promisify } from 'util';\nimport type { Compilation, Compiler } from 'webpack';\n\nconst globPromise = promisify(glob);\n\n/**\n * The name of the plugin provided to Webpack when tapping Webpack compiler hooks.\n */\nconst PLUGIN_NAME = 'angular-find-tests-plugin';\n\nexport interface FindTestsPluginOptions {\n  include?: string[];\n  exclude?: string[];\n  workspaceRoot: string;\n  projectSourceRoot: string;\n}\n\nexport class FindTestsPlugin {\n  private compilation: Compilation | undefined;\n\n  constructor(private options: FindTestsPluginOptions) {}\n\n  apply(compiler: Compiler): void {\n    const {\n      include = ['**/*.spec.ts'],\n      exclude = [],\n      projectSourceRoot,\n      workspaceRoot,\n    } = this.options;\n    const webpackOptions = compiler.options;\n    const entry =\n      typeof webpackOptions.entry === 'function' ? webpackOptions.entry() : webpackOptions.entry;\n\n    let originalImport: string[] | undefined;\n\n    // Add tests files are part of the entry-point.\n    webpackOptions.entry = async () => {\n      const specFiles = await findTests(include, exclude, workspaceRoot, projectSourceRoot);\n      const entrypoints = await entry;\n      const entrypoint = entrypoints['main'];\n      if (!entrypoint.import) {\n        throw new Error(`Cannot find 'main' entrypoint.`);\n      }\n\n      if (specFiles.length) {\n        originalImport ??= entrypoint.import;\n        entrypoint.import = [...originalImport, ...specFiles];\n      } else {\n        assert(this.compilation, 'Compilation cannot be undefined.');\n        this.compilation\n          .getLogger(pluginName)\n          .error(`Specified patterns: \"${include.join(', ')}\" did not match any spec files.`);\n      }\n\n      return entrypoints;\n    };\n\n    compiler.hooks.thisCompilation.tap(PLUGIN_NAME, (compilation) => {\n      this.compilation = compilation;\n      compilation.contextDependencies.add(projectSourceRoot);\n    });\n  }\n}\n\n// go through all patterns and find unique list of files\nasync function findTests(\n  include: string[],\n  exclude: string[],\n  workspaceRoot: string,\n  projectSourceRoot: string,\n): Promise<string[]> {\n  const matchingTestsPromises = include.map((pattern) =>\n    findMatchingTests(pattern, exclude, workspaceRoot, projectSourceRoot),\n  );\n  const files = await Promise.all(matchingTestsPromises);\n\n  // Unique file names\n  return [...new Set(files.flat())];\n}\n\nconst normalizePath = (path: string): string => path.replace(/\\\\/g, '/');\n\nasync function findMatchingTests(\n  pattern: string,\n  ignore: string[],\n  workspaceRoot: string,\n  projectSourceRoot: string,\n): Promise<string[]> {\n  // normalize pattern, glob lib only accepts forward slashes\n  let normalizedPattern = normalizePath(pattern);\n  if (normalizedPattern.charAt(0) === '/') {\n    normalizedPattern = normalizedPattern.substring(1);\n  }\n\n  const relativeProjectRoot = normalizePath(relative(workspaceRoot, projectSourceRoot) + '/');\n\n  // remove relativeProjectRoot to support relative paths from root\n  // such paths are easy to get when running scripts via IDEs\n  if (normalizedPattern.startsWith(relativeProjectRoot)) {\n    normalizedPattern = normalizedPattern.substring(relativeProjectRoot.length);\n  }\n\n  // special logic when pattern does not look like a glob\n  if (!hasMagic(normalizedPattern)) {\n    if (await isDirectory(join(projectSourceRoot, normalizedPattern))) {\n      normalizedPattern = `${normalizedPattern}/**/*.spec.@(ts|tsx)`;\n    } else {\n      // see if matching spec file exists\n      const fileExt = extname(normalizedPattern);\n      // Replace extension to `.spec.ext`. Example: `src/app/app.component.ts`-> `src/app/app.component.spec.ts`\n      const potentialSpec = join(\n        projectSourceRoot,\n        dirname(normalizedPattern),\n        `${basename(normalizedPattern, fileExt)}.spec${fileExt}`,\n      );\n\n      if (await exists(potentialSpec)) {\n        return [potentialSpec];\n      }\n    }\n  }\n\n  return globPromise(normalizedPattern, {\n    cwd: projectSourceRoot,\n    root: projectSourceRoot,\n    nomount: true,\n    absolute: true,\n    ignore: ['**/node_modules/**', ...ignore],\n  });\n}\n\nasync function isDirectory(path: PathLike): Promise<boolean> {\n  try {\n    const stats = await fs.stat(path);\n\n    return stats.isDirectory();\n  } catch {\n    return false;\n  }\n}\n\nasync function exists(path: PathLike): Promise<boolean> {\n  try {\n    await fs.access(path, constants.F_OK);\n\n    return true;\n  } catch {\n    return false;\n  }\n}\n"]}
|
|
@@ -186,6 +186,18 @@ function getBuiltInKarmaConfig(workspaceRoot, projectName) {
|
|
|
186
186
|
},
|
|
187
187
|
reporters: ['progress', 'kjhtml'],
|
|
188
188
|
browsers: ['Chrome'],
|
|
189
|
+
customLaunchers: {
|
|
190
|
+
// Chrome configured to run in a bazel sandbox.
|
|
191
|
+
// Disable the use of the gpu and `/dev/shm` because it causes Chrome to
|
|
192
|
+
// crash on some environments.
|
|
193
|
+
// See:
|
|
194
|
+
// https://github.com/puppeteer/puppeteer/blob/v1.0.0/docs/troubleshooting.md#tips
|
|
195
|
+
// https://stackoverflow.com/questions/50642308/webdriverexception-unknown-error-devtoolsactiveport-file-doesnt-exist-while-t
|
|
196
|
+
ChromeHeadlessNoSandbox: {
|
|
197
|
+
base: 'ChromeHeadless',
|
|
198
|
+
flags: ['--no-sandbox', '--headless', '--disable-gpu', '--disable-dev-shm-usage'],
|
|
199
|
+
},
|
|
200
|
+
},
|
|
189
201
|
restartOnFileChange: true,
|
|
190
202
|
};
|
|
191
203
|
}
|
|
@@ -206,4 +218,4 @@ function getBuiltInMainFile() {
|
|
|
206
218
|
`).toString('base64');
|
|
207
219
|
return `ng-virtual-main.js!=!data:text/javascript;base64,${content}`;
|
|
208
220
|
}
|
|
209
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/karma/index.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\nimport { BuilderContext, BuilderOutput, createBuilder } from '@angular-devkit/architect';\nimport { strings } from '@angular-devkit/core';\nimport type { Config, ConfigOptions } from 'karma';\nimport { createRequire } from 'module';\nimport * as path from 'path';\nimport { Observable, from } from 'rxjs';\nimport { defaultIfEmpty, switchMap } from 'rxjs/operators';\nimport { Configuration } from 'webpack';\nimport { ExecutionTransformer } from '../../transforms';\nimport { purgeStaleBuildCache } from '../../utils/purge-cache';\nimport { assertCompatibleAngularVersion } from '../../utils/version';\nimport { generateBrowserWebpackConfigFromContext } from '../../utils/webpack-browser-config';\nimport { getCommonConfig, getStylesConfig } from '../../webpack/configs';\nimport { Schema as BrowserBuilderOptions, OutputHashing } from '../browser/schema';\nimport { FindTestsPlugin } from './find-tests-plugin';\nimport { Schema as KarmaBuilderOptions } from './schema';\n\nexport type KarmaConfigOptions = ConfigOptions & {\n  buildWebpack?: unknown;\n  configFile?: string;\n};\n\nasync function initialize(\n  options: KarmaBuilderOptions,\n  context: BuilderContext,\n  webpackConfigurationTransformer?: ExecutionTransformer<Configuration>,\n): Promise<[typeof import('karma'), Configuration]> {\n  // Purge old build disk cache.\n  await purgeStaleBuildCache(context);\n\n  const { config } = await generateBrowserWebpackConfigFromContext(\n    // only two properties are missing:\n    // * `outputPath` which is fixed for tests\n    // * `budgets` which might be incorrect due to extra dev libs\n    {\n      ...(options as unknown as BrowserBuilderOptions),\n      outputPath: '',\n      budgets: undefined,\n      optimization: false,\n      buildOptimizer: false,\n      aot: false,\n      vendorChunk: true,\n      namedChunks: true,\n      extractLicenses: false,\n      outputHashing: OutputHashing.None,\n      // The webpack tier owns the watch behavior so we want to force it in the config.\n      // When not in watch mode, webpack-dev-middleware will call `compiler.watch` anyway.\n      // https://github.com/webpack/webpack-dev-middleware/blob/698c9ae5e9bb9a013985add6189ff21c1a1ec185/src/index.js#L65\n      // https://github.com/webpack/webpack/blob/cde1b73e12eb8a77eb9ba42e7920c9ec5d29c2c9/lib/Compiler.js#L379-L388\n      watch: true,\n    },\n    context,\n    (wco) => [getCommonConfig(wco), getStylesConfig(wco)],\n  );\n\n  const karma = await import('karma');\n\n  return [karma, (await webpackConfigurationTransformer?.(config)) ?? config];\n}\n\n/**\n * @experimental Direct usage of this function is considered experimental.\n */\nexport function execute(\n  options: KarmaBuilderOptions,\n  context: BuilderContext,\n  transforms: {\n    webpackConfiguration?: ExecutionTransformer<Configuration>;\n    // The karma options transform cannot be async without a refactor of the builder implementation\n    karmaOptions?: (options: KarmaConfigOptions) => KarmaConfigOptions;\n  } = {},\n): Observable<BuilderOutput> {\n  // Check Angular version.\n  assertCompatibleAngularVersion(context.workspaceRoot);\n\n  let singleRun: boolean | undefined;\n  if (options.watch !== undefined) {\n    singleRun = !options.watch;\n  }\n\n  return from(initialize(options, context, transforms.webpackConfiguration)).pipe(\n    switchMap(async ([karma, webpackConfig]) => {\n      // Determine project name from builder context target\n      const projectName = context.target?.project;\n      if (!projectName) {\n        throw new Error(`The 'karma' builder requires a target to be specified.`);\n      }\n\n      const karmaOptions: KarmaConfigOptions = options.karmaConfig\n        ? {}\n        : getBuiltInKarmaConfig(context.workspaceRoot, projectName);\n\n      karmaOptions.singleRun = singleRun;\n\n      // Convert browsers from a string to an array\n      if (options.browsers) {\n        karmaOptions.browsers = options.browsers.split(',');\n      }\n\n      if (options.reporters) {\n        // Split along commas to make it more natural, and remove empty strings.\n        const reporters = options.reporters\n          .reduce<string[]>((acc, curr) => acc.concat(curr.split(',')), [])\n          .filter((x) => !!x);\n\n        if (reporters.length > 0) {\n          karmaOptions.reporters = reporters;\n        }\n      }\n\n      if (!options.main) {\n        webpackConfig.entry ??= {};\n        if (typeof webpackConfig.entry === 'object' && !Array.isArray(webpackConfig.entry)) {\n          if (Array.isArray(webpackConfig.entry['main'])) {\n            webpackConfig.entry['main'].push(getBuiltInMainFile());\n          } else {\n            webpackConfig.entry['main'] = [getBuiltInMainFile()];\n          }\n        }\n      }\n\n      const projectMetadata = await context.getProjectMetadata(projectName);\n      const sourceRoot = (projectMetadata.sourceRoot ?? projectMetadata.root ?? '') as string;\n\n      webpackConfig.plugins ??= [];\n      webpackConfig.plugins.push(\n        new FindTestsPlugin({\n          include: options.include,\n          exclude: options.exclude,\n          workspaceRoot: context.workspaceRoot,\n          projectSourceRoot: path.join(context.workspaceRoot, sourceRoot),\n        }),\n      );\n\n      karmaOptions.buildWebpack = {\n        options,\n        webpackConfig,\n        logger: context.logger,\n      };\n\n      const parsedKarmaConfig = await karma.config.parseConfig(\n        options.karmaConfig && path.resolve(context.workspaceRoot, options.karmaConfig),\n        transforms.karmaOptions ? transforms.karmaOptions(karmaOptions) : karmaOptions,\n        { promiseConfig: true, throwErrors: true },\n      );\n\n      return [karma, parsedKarmaConfig] as [typeof karma, KarmaConfigOptions];\n    }),\n    switchMap(\n      ([karma, karmaConfig]) =>\n        new Observable<BuilderOutput>((subscriber) => {\n          // Pass onto Karma to emit BuildEvents.\n          karmaConfig.buildWebpack ??= {};\n          if (typeof karmaConfig.buildWebpack === 'object') {\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            (karmaConfig.buildWebpack as any).failureCb ??= () =>\n              subscriber.next({ success: false });\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            (karmaConfig.buildWebpack as any).successCb ??= () =>\n              subscriber.next({ success: true });\n          }\n\n          // Complete the observable once the Karma server returns.\n          const karmaServer = new karma.Server(karmaConfig as Config, (exitCode) => {\n            subscriber.next({ success: exitCode === 0 });\n            subscriber.complete();\n          });\n\n          const karmaStart = karmaServer.start();\n\n          // Cleanup, signal Karma to exit.\n          return () => {\n            void karmaStart.then(() => karmaServer.stop());\n          };\n        }),\n    ),\n    defaultIfEmpty({ success: false }),\n  );\n}\n\nfunction getBuiltInKarmaConfig(\n  workspaceRoot: string,\n  projectName: string,\n): ConfigOptions & Record<string, unknown> {\n  let coverageFolderName = projectName.charAt(0) === '@' ? projectName.slice(1) : projectName;\n  if (/[A-Z]/.test(coverageFolderName)) {\n    coverageFolderName = strings.dasherize(coverageFolderName);\n  }\n\n  const workspaceRootRequire = createRequire(workspaceRoot + '/');\n\n  // Any changes to the config here need to be synced to: packages/schematics/angular/config/files/karma.conf.js.template\n  return {\n    basePath: '',\n    frameworks: ['jasmine', '@angular-devkit/build-angular'],\n    plugins: [\n      'karma-jasmine',\n      'karma-chrome-launcher',\n      'karma-jasmine-html-reporter',\n      'karma-coverage',\n      '@angular-devkit/build-angular/plugins/karma',\n    ].map((p) => workspaceRootRequire(p)),\n    client: {\n      clearContext: false, // leave Jasmine Spec Runner output visible in browser\n    },\n    jasmineHtmlReporter: {\n      suppressAll: true, // removes the duplicated traces\n    },\n    coverageReporter: {\n      dir: path.join(workspaceRoot, 'coverage', coverageFolderName),\n      subdir: '.',\n      reporters: [{ type: 'html' }, { type: 'text-summary' }],\n    },\n    reporters: ['progress', 'kjhtml'],\n    browsers: ['Chrome'],\n    restartOnFileChange: true,\n  };\n}\n\nexport { KarmaBuilderOptions };\nexport default createBuilder<Record<string, string> & KarmaBuilderOptions>(execute);\n\nfunction getBuiltInMainFile(): string {\n  const content = Buffer.from(\n    `\n  import { getTestBed } from '@angular/core/testing';\n  import {\n    BrowserDynamicTestingModule,\n    platformBrowserDynamicTesting,\n   } from '@angular/platform-browser-dynamic/testing';\n\n  // Initialize the Angular testing environment.\n  getTestBed().initTestEnvironment(BrowserDynamicTestingModule, platformBrowserDynamicTesting(), {\n    errorOnUnknownElements: true,\n    errorOnUnknownProperties: true\n  });\n`,\n  ).toString('base64');\n\n  return `ng-virtual-main.js!=!data:text/javascript;base64,${content}`;\n}\n"]}
|
|
221
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/karma/index.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\nimport { BuilderContext, BuilderOutput, createBuilder } from '@angular-devkit/architect';\nimport { strings } from '@angular-devkit/core';\nimport type { Config, ConfigOptions } from 'karma';\nimport { createRequire } from 'module';\nimport * as path from 'path';\nimport { Observable, from } from 'rxjs';\nimport { defaultIfEmpty, switchMap } from 'rxjs/operators';\nimport { Configuration } from 'webpack';\nimport { ExecutionTransformer } from '../../transforms';\nimport { purgeStaleBuildCache } from '../../utils/purge-cache';\nimport { assertCompatibleAngularVersion } from '../../utils/version';\nimport { generateBrowserWebpackConfigFromContext } from '../../utils/webpack-browser-config';\nimport { getCommonConfig, getStylesConfig } from '../../webpack/configs';\nimport { Schema as BrowserBuilderOptions, OutputHashing } from '../browser/schema';\nimport { FindTestsPlugin } from './find-tests-plugin';\nimport { Schema as KarmaBuilderOptions } from './schema';\n\nexport type KarmaConfigOptions = ConfigOptions & {\n  buildWebpack?: unknown;\n  configFile?: string;\n};\n\nasync function initialize(\n  options: KarmaBuilderOptions,\n  context: BuilderContext,\n  webpackConfigurationTransformer?: ExecutionTransformer<Configuration>,\n): Promise<[typeof import('karma'), Configuration]> {\n  // Purge old build disk cache.\n  await purgeStaleBuildCache(context);\n\n  const { config } = await generateBrowserWebpackConfigFromContext(\n    // only two properties are missing:\n    // * `outputPath` which is fixed for tests\n    // * `budgets` which might be incorrect due to extra dev libs\n    {\n      ...(options as unknown as BrowserBuilderOptions),\n      outputPath: '',\n      budgets: undefined,\n      optimization: false,\n      buildOptimizer: false,\n      aot: false,\n      vendorChunk: true,\n      namedChunks: true,\n      extractLicenses: false,\n      outputHashing: OutputHashing.None,\n      // The webpack tier owns the watch behavior so we want to force it in the config.\n      // When not in watch mode, webpack-dev-middleware will call `compiler.watch` anyway.\n      // https://github.com/webpack/webpack-dev-middleware/blob/698c9ae5e9bb9a013985add6189ff21c1a1ec185/src/index.js#L65\n      // https://github.com/webpack/webpack/blob/cde1b73e12eb8a77eb9ba42e7920c9ec5d29c2c9/lib/Compiler.js#L379-L388\n      watch: true,\n    },\n    context,\n    (wco) => [getCommonConfig(wco), getStylesConfig(wco)],\n  );\n\n  const karma = await import('karma');\n\n  return [karma, (await webpackConfigurationTransformer?.(config)) ?? config];\n}\n\n/**\n * @experimental Direct usage of this function is considered experimental.\n */\nexport function execute(\n  options: KarmaBuilderOptions,\n  context: BuilderContext,\n  transforms: {\n    webpackConfiguration?: ExecutionTransformer<Configuration>;\n    // The karma options transform cannot be async without a refactor of the builder implementation\n    karmaOptions?: (options: KarmaConfigOptions) => KarmaConfigOptions;\n  } = {},\n): Observable<BuilderOutput> {\n  // Check Angular version.\n  assertCompatibleAngularVersion(context.workspaceRoot);\n\n  let singleRun: boolean | undefined;\n  if (options.watch !== undefined) {\n    singleRun = !options.watch;\n  }\n\n  return from(initialize(options, context, transforms.webpackConfiguration)).pipe(\n    switchMap(async ([karma, webpackConfig]) => {\n      // Determine project name from builder context target\n      const projectName = context.target?.project;\n      if (!projectName) {\n        throw new Error(`The 'karma' builder requires a target to be specified.`);\n      }\n\n      const karmaOptions: KarmaConfigOptions = options.karmaConfig\n        ? {}\n        : getBuiltInKarmaConfig(context.workspaceRoot, projectName);\n\n      karmaOptions.singleRun = singleRun;\n\n      // Convert browsers from a string to an array\n      if (options.browsers) {\n        karmaOptions.browsers = options.browsers.split(',');\n      }\n\n      if (options.reporters) {\n        // Split along commas to make it more natural, and remove empty strings.\n        const reporters = options.reporters\n          .reduce<string[]>((acc, curr) => acc.concat(curr.split(',')), [])\n          .filter((x) => !!x);\n\n        if (reporters.length > 0) {\n          karmaOptions.reporters = reporters;\n        }\n      }\n\n      if (!options.main) {\n        webpackConfig.entry ??= {};\n        if (typeof webpackConfig.entry === 'object' && !Array.isArray(webpackConfig.entry)) {\n          if (Array.isArray(webpackConfig.entry['main'])) {\n            webpackConfig.entry['main'].push(getBuiltInMainFile());\n          } else {\n            webpackConfig.entry['main'] = [getBuiltInMainFile()];\n          }\n        }\n      }\n\n      const projectMetadata = await context.getProjectMetadata(projectName);\n      const sourceRoot = (projectMetadata.sourceRoot ?? projectMetadata.root ?? '') as string;\n\n      webpackConfig.plugins ??= [];\n      webpackConfig.plugins.push(\n        new FindTestsPlugin({\n          include: options.include,\n          exclude: options.exclude,\n          workspaceRoot: context.workspaceRoot,\n          projectSourceRoot: path.join(context.workspaceRoot, sourceRoot),\n        }),\n      );\n\n      karmaOptions.buildWebpack = {\n        options,\n        webpackConfig,\n        logger: context.logger,\n      };\n\n      const parsedKarmaConfig = await karma.config.parseConfig(\n        options.karmaConfig && path.resolve(context.workspaceRoot, options.karmaConfig),\n        transforms.karmaOptions ? transforms.karmaOptions(karmaOptions) : karmaOptions,\n        { promiseConfig: true, throwErrors: true },\n      );\n\n      return [karma, parsedKarmaConfig] as [typeof karma, KarmaConfigOptions];\n    }),\n    switchMap(\n      ([karma, karmaConfig]) =>\n        new Observable<BuilderOutput>((subscriber) => {\n          // Pass onto Karma to emit BuildEvents.\n          karmaConfig.buildWebpack ??= {};\n          if (typeof karmaConfig.buildWebpack === 'object') {\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            (karmaConfig.buildWebpack as any).failureCb ??= () =>\n              subscriber.next({ success: false });\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            (karmaConfig.buildWebpack as any).successCb ??= () =>\n              subscriber.next({ success: true });\n          }\n\n          // Complete the observable once the Karma server returns.\n          const karmaServer = new karma.Server(karmaConfig as Config, (exitCode) => {\n            subscriber.next({ success: exitCode === 0 });\n            subscriber.complete();\n          });\n\n          const karmaStart = karmaServer.start();\n\n          // Cleanup, signal Karma to exit.\n          return () => {\n            void karmaStart.then(() => karmaServer.stop());\n          };\n        }),\n    ),\n    defaultIfEmpty({ success: false }),\n  );\n}\n\nfunction getBuiltInKarmaConfig(\n  workspaceRoot: string,\n  projectName: string,\n): ConfigOptions & Record<string, unknown> {\n  let coverageFolderName = projectName.charAt(0) === '@' ? projectName.slice(1) : projectName;\n  if (/[A-Z]/.test(coverageFolderName)) {\n    coverageFolderName = strings.dasherize(coverageFolderName);\n  }\n\n  const workspaceRootRequire = createRequire(workspaceRoot + '/');\n\n  // Any changes to the config here need to be synced to: packages/schematics/angular/config/files/karma.conf.js.template\n  return {\n    basePath: '',\n    frameworks: ['jasmine', '@angular-devkit/build-angular'],\n    plugins: [\n      'karma-jasmine',\n      'karma-chrome-launcher',\n      'karma-jasmine-html-reporter',\n      'karma-coverage',\n      '@angular-devkit/build-angular/plugins/karma',\n    ].map((p) => workspaceRootRequire(p)),\n    client: {\n      clearContext: false, // leave Jasmine Spec Runner output visible in browser\n    },\n    jasmineHtmlReporter: {\n      suppressAll: true, // removes the duplicated traces\n    },\n    coverageReporter: {\n      dir: path.join(workspaceRoot, 'coverage', coverageFolderName),\n      subdir: '.',\n      reporters: [{ type: 'html' }, { type: 'text-summary' }],\n    },\n    reporters: ['progress', 'kjhtml'],\n    browsers: ['Chrome'],\n    customLaunchers: {\n      // Chrome configured to run in a bazel sandbox.\n      // Disable the use of the gpu and `/dev/shm` because it causes Chrome to\n      // crash on some environments.\n      // See:\n      //   https://github.com/puppeteer/puppeteer/blob/v1.0.0/docs/troubleshooting.md#tips\n      //   https://stackoverflow.com/questions/50642308/webdriverexception-unknown-error-devtoolsactiveport-file-doesnt-exist-while-t\n      ChromeHeadlessNoSandbox: {\n        base: 'ChromeHeadless',\n        flags: ['--no-sandbox', '--headless', '--disable-gpu', '--disable-dev-shm-usage'],\n      },\n    },\n    restartOnFileChange: true,\n  };\n}\n\nexport { KarmaBuilderOptions };\nexport default createBuilder<Record<string, string> & KarmaBuilderOptions>(execute);\n\nfunction getBuiltInMainFile(): string {\n  const content = Buffer.from(\n    `\n  import { getTestBed } from '@angular/core/testing';\n  import {\n    BrowserDynamicTestingModule,\n    platformBrowserDynamicTesting,\n   } from '@angular/platform-browser-dynamic/testing';\n\n  // Initialize the Angular testing environment.\n  getTestBed().initTestEnvironment(BrowserDynamicTestingModule, platformBrowserDynamicTesting(), {\n    errorOnUnknownElements: true,\n    errorOnUnknownProperties: true\n  });\n`,\n  ).toString('base64');\n\n  return `ng-virtual-main.js!=!data:text/javascript;base64,${content}`;\n}\n"]}
|
|
@@ -68,11 +68,17 @@ function execute(options, context, transforms = {}) {
|
|
|
68
68
|
},
|
|
69
69
|
}).pipe((0, operators_1.concatMap)(async (output) => {
|
|
70
70
|
var _a;
|
|
71
|
-
const { emittedFiles = [], outputPath, webpackStats } = output;
|
|
71
|
+
const { emittedFiles = [], outputPath, webpackStats, success } = output;
|
|
72
72
|
if (!webpackStats) {
|
|
73
73
|
throw new Error('Webpack stats build result is required.');
|
|
74
74
|
}
|
|
75
|
-
if (!
|
|
75
|
+
if (!success) {
|
|
76
|
+
if ((0, stats_1.statsHasWarnings)(webpackStats)) {
|
|
77
|
+
context.logger.warn((0, stats_1.statsWarningsToString)(webpackStats, { colors: true }));
|
|
78
|
+
}
|
|
79
|
+
if ((0, stats_1.statsHasErrors)(webpackStats)) {
|
|
80
|
+
context.logger.error((0, stats_1.statsErrorsToString)(webpackStats, { colors: true }));
|
|
81
|
+
}
|
|
76
82
|
return output;
|
|
77
83
|
}
|
|
78
84
|
const spinner = new spinner_1.Spinner();
|
|
@@ -178,4 +184,4 @@ function getPlatformServerExportsConfig(wco) {
|
|
|
178
184
|
}
|
|
179
185
|
: {};
|
|
180
186
|
}
|
|
181
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/server/index.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\nimport { BuilderContext, BuilderOutput, createBuilder } from '@angular-devkit/architect';\nimport { runWebpack } from '@angular-devkit/build-webpack';\nimport * as path from 'path';\nimport { Observable, from } from 'rxjs';\nimport { concatMap } from 'rxjs/operators';\nimport webpack, { Configuration } from 'webpack';\nimport { ExecutionTransformer } from '../../transforms';\nimport {\n  NormalizedBrowserBuilderSchema,\n  deleteOutputDir,\n  normalizeAssetPatterns,\n} from '../../utils';\nimport { colors } from '../../utils/color';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { assertIsError } from '../../utils/error';\nimport { i18nInlineEmittedFiles } from '../../utils/i18n-inlining';\nimport { I18nOptions } from '../../utils/i18n-options';\nimport { ensureOutputPaths } from '../../utils/output-paths';\nimport { purgeStaleBuildCache } from '../../utils/purge-cache';\nimport { Spinner } from '../../utils/spinner';\nimport { assertCompatibleAngularVersion } from '../../utils/version';\nimport {\n  BrowserWebpackConfigOptions,\n  generateI18nBrowserWebpackConfigFromContext,\n} from '../../utils/webpack-browser-config';\nimport { getCommonConfig, getStylesConfig } from '../../webpack/configs';\nimport { isPlatformServerInstalled } from '../../webpack/utils/helpers';\nimport { webpackStatsLogger } from '../../webpack/utils/stats';\nimport { Schema as ServerBuilderOptions } from './schema';\n\n/**\n * @experimental Direct usage of this type is considered experimental.\n */\nexport type ServerBuilderOutput = BuilderOutput & {\n  baseOutputPath: string;\n  /**\n   * @deprecated in version 14. Use 'outputs' instead.\n   */\n  outputPaths: string[];\n  /**\n   * @deprecated in version 9. Use 'outputs' instead.\n   */\n  outputPath: string;\n\n  outputs: {\n    locale?: string;\n    path: string;\n  }[];\n};\n\nexport { ServerBuilderOptions };\n\n/**\n * @experimental Direct usage of this function is considered experimental.\n */\nexport function execute(\n  options: ServerBuilderOptions,\n  context: BuilderContext,\n  transforms: {\n    webpackConfiguration?: ExecutionTransformer<webpack.Configuration>;\n  } = {},\n): Observable<ServerBuilderOutput> {\n  const root = context.workspaceRoot;\n\n  // Check Angular version.\n  assertCompatibleAngularVersion(root);\n\n  const baseOutputPath = path.resolve(root, options.outputPath);\n  let outputPaths: undefined | Map<string, string>;\n\n  return from(initialize(options, context, transforms.webpackConfiguration)).pipe(\n    concatMap(({ config, i18n, projectRoot, projectSourceRoot }) => {\n      return runWebpack(config, context, {\n        webpackFactory: require('webpack') as typeof webpack,\n        logging: (stats, config) => {\n          if (options.verbose) {\n            context.logger.info(stats.toString(config.stats));\n          }\n        },\n      }).pipe(\n        concatMap(async (output) => {\n          const { emittedFiles = [], outputPath, webpackStats } = output;\n          if (!webpackStats) {\n            throw new Error('Webpack stats build result is required.');\n          }\n\n          if (!output.success) {\n            return output;\n          }\n\n          const spinner = new Spinner();\n          spinner.enabled = options.progress !== false;\n          outputPaths = ensureOutputPaths(baseOutputPath, i18n);\n\n          // Copy assets\n          if (!options.watch && options.assets?.length) {\n            spinner.start('Copying assets...');\n            try {\n              await copyAssets(\n                normalizeAssetPatterns(\n                  options.assets,\n                  context.workspaceRoot,\n                  projectRoot,\n                  projectSourceRoot,\n                ),\n                Array.from(outputPaths.values()),\n                context.workspaceRoot,\n              );\n              spinner.succeed('Copying assets complete.');\n            } catch (err) {\n              spinner.fail(colors.redBright('Copying of assets failed.'));\n              assertIsError(err);\n\n              return {\n                ...output,\n                success: false,\n                error: 'Unable to copy assets: ' + err.message,\n              };\n            }\n          }\n\n          if (i18n.shouldInline) {\n            const success = await i18nInlineEmittedFiles(\n              context,\n              emittedFiles,\n              i18n,\n              baseOutputPath,\n              Array.from(outputPaths.values()),\n              [],\n              outputPath,\n              options.i18nMissingTranslation,\n            );\n            if (!success) {\n              return {\n                ...output,\n                success: false,\n              };\n            }\n          }\n\n          webpackStatsLogger(context.logger, webpackStats, config);\n\n          return output;\n        }),\n      );\n    }),\n    concatMap(async (output) => {\n      if (!output.success) {\n        return output as ServerBuilderOutput;\n      }\n\n      return {\n        ...output,\n        baseOutputPath,\n        outputPath: baseOutputPath,\n        outputPaths: outputPaths || [baseOutputPath],\n        outputs: (outputPaths &&\n          [...outputPaths.entries()].map(([locale, path]) => ({\n            locale,\n            path,\n          }))) || {\n          path: baseOutputPath,\n        },\n      } as ServerBuilderOutput;\n    }),\n  );\n}\n\nexport default createBuilder<ServerBuilderOptions, ServerBuilderOutput>(execute);\n\nasync function initialize(\n  options: ServerBuilderOptions,\n  context: BuilderContext,\n  webpackConfigurationTransform?: ExecutionTransformer<webpack.Configuration>,\n): Promise<{\n  config: webpack.Configuration;\n  i18n: I18nOptions;\n  projectRoot: string;\n  projectSourceRoot?: string;\n}> {\n  // Purge old build disk cache.\n  await purgeStaleBuildCache(context);\n\n  const browserslist = (await import('browserslist')).default;\n  const originalOutputPath = options.outputPath;\n  // Assets are processed directly by the builder except when watching\n  const adjustedOptions = options.watch ? options : { ...options, assets: [] };\n\n  const { config, projectRoot, projectSourceRoot, i18n } =\n    await generateI18nBrowserWebpackConfigFromContext(\n      {\n        ...adjustedOptions,\n        buildOptimizer: false,\n        aot: true,\n        platform: 'server',\n      } as NormalizedBrowserBuilderSchema,\n      context,\n      (wco) => {\n        // We use the platform to determine the JavaScript syntax output.\n        wco.buildOptions.supportedBrowsers ??= [];\n        wco.buildOptions.supportedBrowsers.push(...browserslist('maintained node versions'));\n\n        return [getPlatformServerExportsConfig(wco), getCommonConfig(wco), getStylesConfig(wco)];\n      },\n    );\n\n  if (options.deleteOutputPath) {\n    deleteOutputDir(context.workspaceRoot, originalOutputPath);\n  }\n\n  const transformedConfig = (await webpackConfigurationTransform?.(config)) ?? config;\n\n  return { config: transformedConfig, i18n, projectRoot, projectSourceRoot };\n}\n\n/**\n * Add `@angular/platform-server` exports.\n * This is needed so that DI tokens can be referenced and set at runtime outside of the bundle.\n */\nfunction getPlatformServerExportsConfig(wco: BrowserWebpackConfigOptions): Partial<Configuration> {\n  // Add `@angular/platform-server` exports.\n  // This is needed so that DI tokens can be referenced and set at runtime outside of the bundle.\n\n  // Only add `@angular/platform-server` exports when it is installed.\n  // In some cases this builder is used when `@angular/platform-server` is not installed.\n  // Example: when using `@nguniversal/common/clover` which does not need `@angular/platform-server`.\n\n  return isPlatformServerInstalled(wco.root)\n    ? {\n        module: {\n          rules: [\n            {\n              loader: require.resolve('./platform-server-exports-loader'),\n              include: [path.resolve(wco.root, wco.buildOptions.main)],\n            },\n          ],\n        },\n      }\n    : {};\n}\n"]}
|
|
187
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/server/index.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\nimport { BuilderContext, BuilderOutput, createBuilder } from '@angular-devkit/architect';\nimport { runWebpack } from '@angular-devkit/build-webpack';\nimport * as path from 'path';\nimport { Observable, from } from 'rxjs';\nimport { concatMap } from 'rxjs/operators';\nimport webpack, { Configuration } from 'webpack';\nimport { ExecutionTransformer } from '../../transforms';\nimport {\n  NormalizedBrowserBuilderSchema,\n  deleteOutputDir,\n  normalizeAssetPatterns,\n} from '../../utils';\nimport { colors } from '../../utils/color';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { assertIsError } from '../../utils/error';\nimport { i18nInlineEmittedFiles } from '../../utils/i18n-inlining';\nimport { I18nOptions } from '../../utils/i18n-options';\nimport { ensureOutputPaths } from '../../utils/output-paths';\nimport { purgeStaleBuildCache } from '../../utils/purge-cache';\nimport { Spinner } from '../../utils/spinner';\nimport { assertCompatibleAngularVersion } from '../../utils/version';\nimport {\n  BrowserWebpackConfigOptions,\n  generateI18nBrowserWebpackConfigFromContext,\n} from '../../utils/webpack-browser-config';\nimport { getCommonConfig, getStylesConfig } from '../../webpack/configs';\nimport { isPlatformServerInstalled } from '../../webpack/utils/helpers';\nimport {\n  statsErrorsToString,\n  statsHasErrors,\n  statsHasWarnings,\n  statsWarningsToString,\n  webpackStatsLogger,\n} from '../../webpack/utils/stats';\nimport { Schema as ServerBuilderOptions } from './schema';\n\n/**\n * @experimental Direct usage of this type is considered experimental.\n */\nexport type ServerBuilderOutput = BuilderOutput & {\n  baseOutputPath: string;\n  /**\n   * @deprecated in version 14. Use 'outputs' instead.\n   */\n  outputPaths: string[];\n  /**\n   * @deprecated in version 9. Use 'outputs' instead.\n   */\n  outputPath: string;\n\n  outputs: {\n    locale?: string;\n    path: string;\n  }[];\n};\n\nexport { ServerBuilderOptions };\n\n/**\n * @experimental Direct usage of this function is considered experimental.\n */\nexport function execute(\n  options: ServerBuilderOptions,\n  context: BuilderContext,\n  transforms: {\n    webpackConfiguration?: ExecutionTransformer<webpack.Configuration>;\n  } = {},\n): Observable<ServerBuilderOutput> {\n  const root = context.workspaceRoot;\n\n  // Check Angular version.\n  assertCompatibleAngularVersion(root);\n\n  const baseOutputPath = path.resolve(root, options.outputPath);\n  let outputPaths: undefined | Map<string, string>;\n\n  return from(initialize(options, context, transforms.webpackConfiguration)).pipe(\n    concatMap(({ config, i18n, projectRoot, projectSourceRoot }) => {\n      return runWebpack(config, context, {\n        webpackFactory: require('webpack') as typeof webpack,\n        logging: (stats, config) => {\n          if (options.verbose) {\n            context.logger.info(stats.toString(config.stats));\n          }\n        },\n      }).pipe(\n        concatMap(async (output) => {\n          const { emittedFiles = [], outputPath, webpackStats, success } = output;\n          if (!webpackStats) {\n            throw new Error('Webpack stats build result is required.');\n          }\n\n          if (!success) {\n            if (statsHasWarnings(webpackStats)) {\n              context.logger.warn(statsWarningsToString(webpackStats, { colors: true }));\n            }\n            if (statsHasErrors(webpackStats)) {\n              context.logger.error(statsErrorsToString(webpackStats, { colors: true }));\n            }\n\n            return output;\n          }\n\n          const spinner = new Spinner();\n          spinner.enabled = options.progress !== false;\n          outputPaths = ensureOutputPaths(baseOutputPath, i18n);\n\n          // Copy assets\n          if (!options.watch && options.assets?.length) {\n            spinner.start('Copying assets...');\n            try {\n              await copyAssets(\n                normalizeAssetPatterns(\n                  options.assets,\n                  context.workspaceRoot,\n                  projectRoot,\n                  projectSourceRoot,\n                ),\n                Array.from(outputPaths.values()),\n                context.workspaceRoot,\n              );\n              spinner.succeed('Copying assets complete.');\n            } catch (err) {\n              spinner.fail(colors.redBright('Copying of assets failed.'));\n              assertIsError(err);\n\n              return {\n                ...output,\n                success: false,\n                error: 'Unable to copy assets: ' + err.message,\n              };\n            }\n          }\n\n          if (i18n.shouldInline) {\n            const success = await i18nInlineEmittedFiles(\n              context,\n              emittedFiles,\n              i18n,\n              baseOutputPath,\n              Array.from(outputPaths.values()),\n              [],\n              outputPath,\n              options.i18nMissingTranslation,\n            );\n            if (!success) {\n              return {\n                ...output,\n                success: false,\n              };\n            }\n          }\n\n          webpackStatsLogger(context.logger, webpackStats, config);\n\n          return output;\n        }),\n      );\n    }),\n    concatMap(async (output) => {\n      if (!output.success) {\n        return output as ServerBuilderOutput;\n      }\n\n      return {\n        ...output,\n        baseOutputPath,\n        outputPath: baseOutputPath,\n        outputPaths: outputPaths || [baseOutputPath],\n        outputs: (outputPaths &&\n          [...outputPaths.entries()].map(([locale, path]) => ({\n            locale,\n            path,\n          }))) || {\n          path: baseOutputPath,\n        },\n      } as ServerBuilderOutput;\n    }),\n  );\n}\n\nexport default createBuilder<ServerBuilderOptions, ServerBuilderOutput>(execute);\n\nasync function initialize(\n  options: ServerBuilderOptions,\n  context: BuilderContext,\n  webpackConfigurationTransform?: ExecutionTransformer<webpack.Configuration>,\n): Promise<{\n  config: webpack.Configuration;\n  i18n: I18nOptions;\n  projectRoot: string;\n  projectSourceRoot?: string;\n}> {\n  // Purge old build disk cache.\n  await purgeStaleBuildCache(context);\n\n  const browserslist = (await import('browserslist')).default;\n  const originalOutputPath = options.outputPath;\n  // Assets are processed directly by the builder except when watching\n  const adjustedOptions = options.watch ? options : { ...options, assets: [] };\n\n  const { config, projectRoot, projectSourceRoot, i18n } =\n    await generateI18nBrowserWebpackConfigFromContext(\n      {\n        ...adjustedOptions,\n        buildOptimizer: false,\n        aot: true,\n        platform: 'server',\n      } as NormalizedBrowserBuilderSchema,\n      context,\n      (wco) => {\n        // We use the platform to determine the JavaScript syntax output.\n        wco.buildOptions.supportedBrowsers ??= [];\n        wco.buildOptions.supportedBrowsers.push(...browserslist('maintained node versions'));\n\n        return [getPlatformServerExportsConfig(wco), getCommonConfig(wco), getStylesConfig(wco)];\n      },\n    );\n\n  if (options.deleteOutputPath) {\n    deleteOutputDir(context.workspaceRoot, originalOutputPath);\n  }\n\n  const transformedConfig = (await webpackConfigurationTransform?.(config)) ?? config;\n\n  return { config: transformedConfig, i18n, projectRoot, projectSourceRoot };\n}\n\n/**\n * Add `@angular/platform-server` exports.\n * This is needed so that DI tokens can be referenced and set at runtime outside of the bundle.\n */\nfunction getPlatformServerExportsConfig(wco: BrowserWebpackConfigOptions): Partial<Configuration> {\n  // Add `@angular/platform-server` exports.\n  // This is needed so that DI tokens can be referenced and set at runtime outside of the bundle.\n\n  // Only add `@angular/platform-server` exports when it is installed.\n  // In some cases this builder is used when `@angular/platform-server` is not installed.\n  // Example: when using `@nguniversal/common/clover` which does not need `@angular/platform-server`.\n\n  return isPlatformServerInstalled(wco.root)\n    ? {\n        module: {\n          rules: [\n            {\n              loader: require.resolve('./platform-server-exports-loader'),\n              include: [path.resolve(wco.root, wco.buildOptions.main)],\n            },\n          ],\n        },\n      }\n    : {};\n}\n"]}
|
|
@@ -35,7 +35,7 @@ function transformSupportedBrowsersToTargets(supportedBrowsers) {
|
|
|
35
35
|
// to perform minimum supported feature checks. esbuild also expects a single version.
|
|
36
36
|
[version] = version.split('-');
|
|
37
37
|
if (esBuildSupportedBrowsers.has(browserName)) {
|
|
38
|
-
if (browserName === 'safari' && version === '
|
|
38
|
+
if (browserName === 'safari' && version === 'tp') {
|
|
39
39
|
// esbuild only supports numeric versions so `TP` is converted to a high number (999) since
|
|
40
40
|
// a Technology Preview (TP) of Safari is assumed to support all currently known features.
|
|
41
41
|
version = '999';
|
|
@@ -52,4 +52,4 @@ function transformSupportedBrowsersToTargets(supportedBrowsers) {
|
|
|
52
52
|
return transformed;
|
|
53
53
|
}
|
|
54
54
|
exports.transformSupportedBrowsersToTargets = transformSupportedBrowsersToTargets;
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNidWlsZC10YXJnZXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfYW5ndWxhci9zcmMvdXRpbHMvZXNidWlsZC10YXJnZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7OztBQUVIOzs7R0FHRztBQUNILFNBQWdCLG1DQUFtQyxDQUFDLGlCQUEyQjtJQUM3RSxNQUFNLFdBQVcsR0FBYSxFQUFFLENBQUM7SUFFakMsd0NBQXdDO0lBQ3hDLE1BQU0sd0JBQXdCLEdBQUcsSUFBSSxHQUFHLENBQUM7UUFDdkMsUUFBUTtRQUNSLE1BQU07UUFDTixTQUFTO1FBQ1QsSUFBSTtRQUNKLEtBQUs7UUFDTCxNQUFNO1FBQ04sT0FBTztRQUNQLFFBQVE7S0FDVCxDQUFDLENBQUM7SUFFSCxLQUFLLE1BQU0sT0FBTyxJQUFJLGlCQUFpQixFQUFFO1FBQ3ZDLElBQUksQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDLEdBQUcsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUU5RCxpRkFBaUY7UUFDakYsSUFBSSxXQUFXLEtBQUssU0FBUyxFQUFFO1lBQzdCLFdBQVcsR0FBRyxLQUFLLENBQUM7U0FDckI7UUFFRCxnRkFBZ0Y7UUFDaEYsc0ZBQXNGO1FBQ3RGLENBQUMsT0FBTyxDQUFDLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUUvQixJQUFJLHdCQUF3QixDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsRUFBRTtZQUM3QyxJQUFJLFdBQVcsS0FBSyxRQUFRLElBQUksT0FBTyxLQUFLLElBQUksRUFBRTtnQkFDaEQsMkZBQTJGO2dCQUMzRiwwRkFBMEY7Z0JBQzFGLE9BQU8sR0FBRyxLQUFLLENBQUM7YUFDakI7aUJBQU0sSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEVBQUU7Z0JBQ2pDLHdGQUF3RjtnQkFDeEYsMEZBQTBGO2dCQUMxRiwyRUFBMkU7Z0JBQzNFLE9BQU8sSUFBSSxJQUFJLENBQUM7YUFDakI7WUFFRCxXQUFXLENBQUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxPQUFPLENBQUMsQ0FBQztTQUN6QztLQUNGO0lBRUQsT0FBTyxXQUFXLENBQUM7QUFDckIsQ0FBQztBQTVDRCxrRkE0Q0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuLyoqXG4gKiBUcmFuc2Zvcm0gYnJvd3Nlcmxpc3RzIHJlc3VsdCB0byBlc2J1aWxkIHRhcmdldC5cbiAqIEBzZWUgaHR0cHM6Ly9lc2J1aWxkLmdpdGh1Yi5pby9hcGkvI3RhcmdldFxuICovXG5leHBvcnQgZnVuY3Rpb24gdHJhbnNmb3JtU3VwcG9ydGVkQnJvd3NlcnNUb1RhcmdldHMoc3VwcG9ydGVkQnJvd3NlcnM6IHN0cmluZ1tdKTogc3RyaW5nW10ge1xuICBjb25zdCB0cmFuc2Zvcm1lZDogc3RyaW5nW10gPSBbXTtcblxuICAvLyBodHRwczovL2VzYnVpbGQuZ2l0aHViLmlvL2FwaS8jdGFyZ2V0XG4gIGNvbnN0IGVzQnVpbGRTdXBwb3J0ZWRCcm93c2VycyA9IG5ldyBTZXQoW1xuICAgICdjaHJvbWUnLFxuICAgICdlZGdlJyxcbiAgICAnZmlyZWZveCcsXG4gICAgJ2llJyxcbiAgICAnaW9zJyxcbiAgICAnbm9kZScsXG4gICAgJ29wZXJhJyxcbiAgICAnc2FmYXJpJyxcbiAgXSk7XG5cbiAgZm9yIChjb25zdCBicm93c2VyIG9mIHN1cHBvcnRlZEJyb3dzZXJzKSB7XG4gICAgbGV0IFticm93c2VyTmFtZSwgdmVyc2lvbl0gPSBicm93c2VyLnRvTG93ZXJDYXNlKCkuc3BsaXQoJyAnKTtcblxuICAgIC8vIGJyb3dzZXJzbGlzdCB1c2VzIHRoZSBuYW1lIGBpb3Nfc2FmYCBmb3IgaU9TIFNhZmFyaSB3aGVyZWFzIGVzYnVpbGQgdXNlcyBgaW9zYFxuICAgIGlmIChicm93c2VyTmFtZSA9PT0gJ2lvc19zYWYnKSB7XG4gICAgICBicm93c2VyTmFtZSA9ICdpb3MnO1xuICAgIH1cblxuICAgIC8vIGJyb3dzZXJzbGlzdCB1c2VzIHJhbmdlcyBgMTUuMi0xNS4zYCB2ZXJzaW9ucyBidXQgb25seSB0aGUgbG93ZXN0IGlzIHJlcXVpcmVkXG4gICAgLy8gdG8gcGVyZm9ybSBtaW5pbXVtIHN1cHBvcnRlZCBmZWF0dXJlIGNoZWNrcy4gZXNidWlsZCBhbHNvIGV4cGVjdHMgYSBzaW5nbGUgdmVyc2lvbi5cbiAgICBbdmVyc2lvbl0gPSB2ZXJzaW9uLnNwbGl0KCctJyk7XG5cbiAgICBpZiAoZXNCdWlsZFN1cHBvcnRlZEJyb3dzZXJzLmhhcyhicm93c2VyTmFtZSkpIHtcbiAgICAgIGlmIChicm93c2VyTmFtZSA9PT0gJ3NhZmFyaScgJiYgdmVyc2lvbiA9PT0gJ3RwJykge1xuICAgICAgICAvLyBlc2J1aWxkIG9ubHkgc3VwcG9ydHMgbnVtZXJpYyB2ZXJzaW9ucyBzbyBgVFBgIGlzIGNvbnZlcnRlZCB0byBhIGhpZ2ggbnVtYmVyICg5OTkpIHNpbmNlXG4gICAgICAgIC8vIGEgVGVjaG5vbG9neSBQcmV2aWV3IChUUCkgb2YgU2FmYXJpIGlzIGFzc3VtZWQgdG8gc3VwcG9ydCBhbGwgY3VycmVudGx5IGtub3duIGZlYXR1cmVzLlxuICAgICAgICB2ZXJzaW9uID0gJzk5OSc7XG4gICAgICB9IGVsc2UgaWYgKCF2ZXJzaW9uLmluY2x1ZGVzKCcuJykpIHtcbiAgICAgICAgLy8gQSBsb25lIG1ham9yIHZlcnNpb24gaXMgY29uc2lkZXJlZCBieSBlc2J1aWxkIHRvIGluY2x1ZGUgYWxsIG1pbm9yIHZlcnNpb25zLiBIb3dldmVyLFxuICAgICAgICAvLyBicm93c2Vyc2xpc3QgZG9lcyBub3QgYW5kIGlzIGFsc28gaW5jb25zaXN0ZW50IGluIGl0cyBgLjBgIHZlcnNpb24gbmFtaW5nLiBGb3IgZXhhbXBsZSxcbiAgICAgICAgLy8gU2FmYXJpIDE1LjAgaXMgbmFtZWQgYHNhZmFyaSAxNWAgYnV0IFNhZmFyaSAxNi4wIGlzIG5hbWVkIGBzYWZhcmkgMTYuMGAuXG4gICAgICAgIHZlcnNpb24gKz0gJy4wJztcbiAgICAgIH1cblxuICAgICAgdHJhbnNmb3JtZWQucHVzaChicm93c2VyTmFtZSArIHZlcnNpb24pO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB0cmFuc2Zvcm1lZDtcbn1cbiJdfQ==
|
|
@@ -34,10 +34,10 @@ Reloaded before every execution run.
|
|
|
34
34
|
<script src="_karma_webpack_/polyfills.js" crossorigin="anonymous"></script>
|
|
35
35
|
<!-- Dynamically replaced with <script> tags -->
|
|
36
36
|
%SCRIPTS%
|
|
37
|
-
<script src="_karma_webpack_/scripts.js" crossorigin="anonymous"></script>
|
|
38
|
-
<script src="_karma_webpack_/vendor.js" crossorigin="anonymous"></script>
|
|
39
|
-
<script src="_karma_webpack_/main.js" crossorigin="anonymous"></script>
|
|
40
|
-
<script type="
|
|
37
|
+
<script src="_karma_webpack_/scripts.js" crossorigin="anonymous" defer></script>
|
|
38
|
+
<script src="_karma_webpack_/vendor.js" crossorigin="anonymous" type="module"></script>
|
|
39
|
+
<script src="_karma_webpack_/main.js" crossorigin="anonymous" type="module"></script>
|
|
40
|
+
<script type="module">
|
|
41
41
|
window.__karma__.loaded();
|
|
42
42
|
</script>
|
|
43
43
|
</body>
|
|
@@ -36,10 +36,10 @@ just for immediate execution, without reporting to Karma server.
|
|
|
36
36
|
<script src="_karma_webpack_/polyfills.js" crossorigin="anonymous"></script>
|
|
37
37
|
<!-- Dynamically replaced with <script> tags -->
|
|
38
38
|
%SCRIPTS%
|
|
39
|
-
<script src="_karma_webpack_/scripts.js" crossorigin="anonymous"></script>
|
|
40
|
-
<script src="_karma_webpack_/vendor.js" crossorigin="anonymous"></script>
|
|
41
|
-
<script src="_karma_webpack_/main.js" crossorigin="anonymous"></script>
|
|
42
|
-
<script type="
|
|
39
|
+
<script src="_karma_webpack_/scripts.js" crossorigin="anonymous" defer></script>
|
|
40
|
+
<script src="_karma_webpack_/vendor.js" crossorigin="anonymous" type="module"></script>
|
|
41
|
+
<script src="_karma_webpack_/main.js" crossorigin="anonymous" type="module"></script>
|
|
42
|
+
<script type="module">
|
|
43
43
|
window.__karma__.loaded();
|
|
44
44
|
</script>
|
|
45
45
|
</body>
|