UNPKG

@angular-devkit/build-angular

Version:
168 lines • 19.9 kB
"use strict"; /** * @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; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.execute = void 0; const architect_1 = require("@angular-devkit/architect"); const core_1 = require("@angular-devkit/core"); const path_1 = require("path"); const url = __importStar(require("url")); const utils_1 = require("../../utils"); const error_1 = require("../../utils/error"); function runProtractor(root, options) { const additionalProtractorConfig = { baseUrl: options.baseUrl, specs: options.specs && options.specs.length ? options.specs : undefined, suite: options.suite, jasmineNodeOpts: { grep: options.grep, invertGrep: options.invertGrep, }, }; // TODO: Protractor manages process.exit itself, so this target will allways quit the // process. To work around this we run it in a subprocess. // https://github.com/angular/protractor/issues/4160 return (0, utils_1.runModuleAsObservableFork)(root, 'protractor/built/launcher', 'init', [ (0, path_1.resolve)(root, options.protractorConfig), additionalProtractorConfig, ]).toPromise(); } async function updateWebdriver() { // The webdriver-manager update command can only be accessed via a deep import. const webdriverDeepImport = 'webdriver-manager/built/lib/cmds/update'; let path; try { const protractorPath = require.resolve('protractor'); path = require.resolve(webdriverDeepImport, { paths: [protractorPath] }); } catch (error) { (0, error_1.assertIsError)(error); if (error.code !== 'MODULE_NOT_FOUND') { throw error; } } if (!path) { throw new Error(core_1.tags.stripIndents ` Cannot automatically find webdriver-manager to update. Update webdriver-manager manually and run 'ng e2e --no-webdriver-update' instead. `); } const webdriverUpdate = await Promise.resolve(`${path}`).then(s => __importStar(require(s))); // const webdriverUpdate = await import(path) as typeof import ('webdriver-manager/built/lib/cmds/update'); // run `webdriver-manager update --standalone false --gecko false --quiet` // if you change this, update the command comment in prev line return webdriverUpdate.program.run({ standalone: false, gecko: false, quiet: true, }); } /** * @experimental Direct usage of this function is considered experimental. */ async function execute(options, context) { context.logger.warn('Protractor has been deprecated including its support in the Angular CLI. For additional information and alternatives, please see https://github.com/angular/protractor/issues/5502.'); // ensure that only one of these options is used if (options.devServerTarget && options.baseUrl) { throw new Error(core_1.tags.stripIndents ` The 'baseUrl' option cannot be used with 'devServerTarget'. When present, 'devServerTarget' will be used to automatically setup 'baseUrl' for Protractor. `); } if (options.webdriverUpdate) { await updateWebdriver(); } let baseUrl = options.baseUrl; let server; try { if (options.devServerTarget) { const target = (0, architect_1.targetFromTargetString)(options.devServerTarget); const serverOptions = await context.getTargetOptions(target); const overrides = { watch: false, liveReload: false, }; if (options.host !== undefined) { overrides.host = options.host; } else if (typeof serverOptions.host === 'string') { options.host = serverOptions.host; } else { options.host = overrides.host = 'localhost'; } if (options.port !== undefined) { overrides.port = options.port; } else if (typeof serverOptions.port === 'number') { options.port = serverOptions.port; } server = await context.scheduleTarget(target, overrides); const result = await server.result; if (!result.success) { return { success: false }; } if (typeof serverOptions.publicHost === 'string') { let publicHost = serverOptions.publicHost; if (!/^\w+:\/\//.test(publicHost)) { publicHost = `${serverOptions.ssl ? 'https' : 'http'}://${publicHost}`; } const clientUrl = url.parse(publicHost); baseUrl = url.format(clientUrl); } else if (typeof result.baseUrl === 'string') { baseUrl = result.baseUrl; } else if (typeof result.port === 'number') { baseUrl = url.format({ protocol: serverOptions.ssl ? 'https' : 'http', hostname: options.host, port: result.port.toString(), }); } } // Like the baseUrl in protractor config file when using the API we need to add // a trailing slash when provide to the baseUrl. if (baseUrl && !baseUrl.endsWith('/')) { baseUrl += '/'; } return await runProtractor(context.workspaceRoot, { ...options, baseUrl }); } catch { return { success: false }; } finally { await server?.stop(); } } exports.execute = execute; exports.default = (0, architect_1.createBuilder)(execute); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/protractor/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 {\n  BuilderContext,\n  BuilderOutput,\n  createBuilder,\n  targetFromTargetString,\n} from '@angular-devkit/architect';\nimport { json, tags } from '@angular-devkit/core';\nimport { resolve } from 'path';\nimport * as url from 'url';\nimport { runModuleAsObservableFork } from '../../utils';\nimport { assertIsError } from '../../utils/error';\nimport { DevServerBuilderOptions } from '../dev-server/index';\nimport { Schema as ProtractorBuilderOptions } from './schema';\n\ninterface JasmineNodeOpts {\n  jasmineNodeOpts: {\n    grep?: string;\n    invertGrep?: boolean;\n  };\n}\n\nfunction runProtractor(root: string, options: ProtractorBuilderOptions): Promise<BuilderOutput> {\n  const additionalProtractorConfig: Partial<ProtractorBuilderOptions> & Partial<JasmineNodeOpts> = {\n    baseUrl: options.baseUrl,\n    specs: options.specs && options.specs.length ? options.specs : undefined,\n    suite: options.suite,\n    jasmineNodeOpts: {\n      grep: options.grep,\n      invertGrep: options.invertGrep,\n    },\n  };\n\n  // TODO: Protractor manages process.exit itself, so this target will allways quit the\n  // process. To work around this we run it in a subprocess.\n  // https://github.com/angular/protractor/issues/4160\n  return runModuleAsObservableFork(root, 'protractor/built/launcher', 'init', [\n    resolve(root, options.protractorConfig),\n    additionalProtractorConfig,\n  ]).toPromise() as Promise<BuilderOutput>;\n}\n\nasync function updateWebdriver() {\n  // The webdriver-manager update command can only be accessed via a deep import.\n  const webdriverDeepImport = 'webdriver-manager/built/lib/cmds/update';\n\n  let path;\n  try {\n    const protractorPath = require.resolve('protractor');\n\n    path = require.resolve(webdriverDeepImport, { paths: [protractorPath] });\n  } catch (error) {\n    assertIsError(error);\n    if (error.code !== 'MODULE_NOT_FOUND') {\n      throw error;\n    }\n  }\n\n  if (!path) {\n    throw new Error(tags.stripIndents`\n      Cannot automatically find webdriver-manager to update.\n      Update webdriver-manager manually and run 'ng e2e --no-webdriver-update' instead.\n    `);\n  }\n\n  const webdriverUpdate = await import(path);\n  // const webdriverUpdate = await import(path) as typeof import ('webdriver-manager/built/lib/cmds/update');\n\n  // run `webdriver-manager update --standalone false --gecko false --quiet`\n  // if you change this, update the command comment in prev line\n  return webdriverUpdate.program.run({\n    standalone: false,\n    gecko: false,\n    quiet: true,\n  } as unknown as JSON);\n}\n\nexport { ProtractorBuilderOptions };\n\n/**\n * @experimental Direct usage of this function is considered experimental.\n */\nexport async function execute(\n  options: ProtractorBuilderOptions,\n  context: BuilderContext,\n): Promise<BuilderOutput> {\n  context.logger.warn(\n    'Protractor has been deprecated including its support in the Angular CLI. For additional information and alternatives, please see https://github.com/angular/protractor/issues/5502.',\n  );\n\n  // ensure that only one of these options is used\n  if (options.devServerTarget && options.baseUrl) {\n    throw new Error(tags.stripIndents`\n    The 'baseUrl' option cannot be used with 'devServerTarget'.\n    When present, 'devServerTarget' will be used to automatically setup 'baseUrl' for Protractor.\n    `);\n  }\n\n  if (options.webdriverUpdate) {\n    await updateWebdriver();\n  }\n\n  let baseUrl = options.baseUrl;\n  let server;\n\n  try {\n    if (options.devServerTarget) {\n      const target = targetFromTargetString(options.devServerTarget);\n      const serverOptions = await context.getTargetOptions(target);\n\n      const overrides = {\n        watch: false,\n        liveReload: false,\n      } as DevServerBuilderOptions & json.JsonObject;\n\n      if (options.host !== undefined) {\n        overrides.host = options.host;\n      } else if (typeof serverOptions.host === 'string') {\n        options.host = serverOptions.host;\n      } else {\n        options.host = overrides.host = 'localhost';\n      }\n\n      if (options.port !== undefined) {\n        overrides.port = options.port;\n      } else if (typeof serverOptions.port === 'number') {\n        options.port = serverOptions.port;\n      }\n\n      server = await context.scheduleTarget(target, overrides);\n      const result = await server.result;\n      if (!result.success) {\n        return { success: false };\n      }\n\n      if (typeof serverOptions.publicHost === 'string') {\n        let publicHost = serverOptions.publicHost;\n        if (!/^\\w+:\\/\\//.test(publicHost)) {\n          publicHost = `${serverOptions.ssl ? 'https' : 'http'}://${publicHost}`;\n        }\n        const clientUrl = url.parse(publicHost);\n        baseUrl = url.format(clientUrl);\n      } else if (typeof result.baseUrl === 'string') {\n        baseUrl = result.baseUrl;\n      } else if (typeof result.port === 'number') {\n        baseUrl = url.format({\n          protocol: serverOptions.ssl ? 'https' : 'http',\n          hostname: options.host,\n          port: result.port.toString(),\n        });\n      }\n    }\n\n    // Like the baseUrl in protractor config file when using the API we need to add\n    // a trailing slash when provide to the baseUrl.\n    if (baseUrl && !baseUrl.endsWith('/')) {\n      baseUrl += '/';\n    }\n\n    return await runProtractor(context.workspaceRoot, { ...options, baseUrl });\n  } catch {\n    return { success: false };\n  } finally {\n    await server?.stop();\n  }\n}\n\nexport default createBuilder<ProtractorBuilderOptions>(execute);\n"]}