UNPKG

nx

Version:

The core Nx plugin contains the core functionality of Nx like the project graph, nx commands and task orchestration.

144 lines (143 loc) 6.28 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.initTasksRunner = initTasksRunner; exports.runDiscreteTasks = runDiscreteTasks; exports.runContinuousTasks = runContinuousTasks; const nx_json_1 = require("../config/nx-json"); const project_graph_1 = require("../project-graph/project-graph"); const run_command_1 = require("./run-command"); const invoke_runner_terminal_output_life_cycle_1 = require("./life-cycles/invoke-runner-terminal-output-life-cycle"); const perf_hooks_1 = require("perf_hooks"); const utils_1 = require("./utils"); const dotenv_1 = require("../utils/dotenv"); const life_cycle_1 = require("./life-cycle"); const task_orchestrator_1 = require("./task-orchestrator"); const create_task_hasher_1 = require("../hasher/create-task-hasher"); const client_1 = require("../daemon/client/client"); const task_results_life_cycle_1 = require("./life-cycles/task-results-life-cycle"); /** * This function is deprecated. Do not use this * @deprecated This function is deprecated. Do not use this */ async function initTasksRunner(nxArgs) { perf_hooks_1.performance.mark('init-local'); (0, dotenv_1.loadRootEnvFiles)(); const nxJson = (0, nx_json_1.readNxJson)(); if (nxArgs.verbose) { process.env.NX_VERBOSE_LOGGING = 'true'; } const projectGraph = await (0, project_graph_1.createProjectGraphAsync)({ exitOnError: true }); return { invoke: async (opts) => { perf_hooks_1.performance.mark('code-loading:end'); // TODO: This polyfills the outputs if someone doesn't pass a task with outputs. Remove this in Nx 20 opts.tasks.forEach((t) => { if (!t.outputs) { t.outputs = (0, utils_1.getOutputs)(projectGraph.nodes, t.target, t.overrides); } }); const lifeCycle = new invoke_runner_terminal_output_life_cycle_1.InvokeRunnerTerminalOutputLifeCycle(opts.tasks); const taskGraph = { roots: opts.tasks.map((task) => task.id), tasks: opts.tasks.reduce((acc, task) => { acc[task.id] = task; return acc; }, {}), dependencies: opts.tasks.reduce((acc, task) => { acc[task.id] = []; return acc; }, {}), continuousDependencies: opts.tasks.reduce((acc, task) => { acc[task.id] = []; return acc; }, {}), }; const taskResults = await (0, run_command_1.invokeTasksRunner)({ tasks: opts.tasks, projectGraph, taskGraph, lifeCycle, nxJson, nxArgs: { ...nxArgs, parallel: opts.parallel }, loadDotEnvFiles: true, initiatingProject: null, initiatingTasks: [], }); return { status: Object.values(taskResults).some((taskResult) => taskResult.status === 'failure' || taskResult.status === 'skipped') ? 1 : 0, taskGraph, taskResults, }; }, }; } async function createOrchestrator(tasks, projectGraph, taskGraphForHashing, nxJson, lifeCycle) { (0, dotenv_1.loadRootEnvFiles)(); const invokeRunnerTerminalLifecycle = new invoke_runner_terminal_output_life_cycle_1.InvokeRunnerTerminalOutputLifeCycle(tasks); const taskResultsLifecycle = new task_results_life_cycle_1.TaskResultsLifeCycle(); const compositedLifeCycle = new life_cycle_1.CompositeLifeCycle([ ...(0, run_command_1.constructLifeCycles)(invokeRunnerTerminalLifecycle), taskResultsLifecycle, lifeCycle, ]); const { runnerOptions: options } = (0, run_command_1.getRunner)({}, nxJson); let hasher = (0, create_task_hasher_1.createTaskHasher)(projectGraph, nxJson, options); const taskGraph = { roots: tasks.map((task) => task.id), tasks: tasks.reduce((acc, task) => { acc[task.id] = task; return acc; }, {}), dependencies: tasks.reduce((acc, task) => { acc[task.id] = []; return acc; }, {}), continuousDependencies: tasks.reduce((acc, task) => { acc[task.id] = []; return acc; }, {}), }; const nxArgs = { ...options, parallel: tasks.length, lifeCycle: compositedLifeCycle, }; (0, run_command_1.setEnvVarsBasedOnArgs)(nxArgs, true); const orchestrator = new task_orchestrator_1.TaskOrchestrator(hasher, null, [], projectGraph, taskGraph, nxJson, nxArgs, false, client_1.daemonClient, undefined, taskGraphForHashing); await orchestrator.init(); orchestrator.processAllScheduledTasks(); return orchestrator; } async function runDiscreteTasks(tasks, projectGraph, taskGraphForHashing, nxJson, lifeCycle) { const orchestrator = await createOrchestrator(tasks, projectGraph, taskGraphForHashing, nxJson, lifeCycle); let groupId = 0; let nextBatch = orchestrator.nextBatch(); let batchResults = []; /** * Set of task ids that were part of batches */ const batchTasks = new Set(); while (nextBatch) { for (const task in nextBatch.taskGraph.tasks) { batchTasks.add(task); } batchResults.push(orchestrator.applyFromCacheOrRunBatch(true, nextBatch, groupId++)); nextBatch = orchestrator.nextBatch(); } const taskResults = tasks // Filter out tasks which were not part of batches .filter((task) => !batchTasks.has(task.id)) .map((task) => orchestrator .applyFromCacheOrRunTask(true, task, groupId++) .then((r) => [r])); return [...batchResults, ...taskResults]; } async function runContinuousTasks(tasks, projectGraph, taskGraphForHashing, nxJson, lifeCycle) { const orchestrator = await createOrchestrator(tasks, projectGraph, taskGraphForHashing, nxJson, lifeCycle); return tasks.reduce((current, task, index) => { current[task.id] = orchestrator.startContinuousTask(task, index); return current; }, {}); }