v5
This commit is contained in:
		
							
								
								
									
										47
									
								
								node_modules/jest-worker/build/workers/ChildProcessWorker.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								node_modules/jest-worker/build/workers/ChildProcessWorker.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,47 @@
 | 
			
		||||
/**
 | 
			
		||||
 * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
 | 
			
		||||
 *
 | 
			
		||||
 * This source code is licensed under the MIT license found in the
 | 
			
		||||
 * LICENSE file in the root directory of this source tree.
 | 
			
		||||
 */
 | 
			
		||||
/// <reference types="node" />
 | 
			
		||||
import { WorkerInterface, ChildMessage, OnEnd, OnStart, WorkerOptions, ParentMessage } from '../types';
 | 
			
		||||
/**
 | 
			
		||||
 * This class wraps the child process and provides a nice interface to
 | 
			
		||||
 * communicate with. It takes care of:
 | 
			
		||||
 *
 | 
			
		||||
 *  - Re-spawning the process if it dies.
 | 
			
		||||
 *  - Queues calls while the worker is busy.
 | 
			
		||||
 *  - Re-sends the requests if the worker blew up.
 | 
			
		||||
 *
 | 
			
		||||
 * The reason for queueing them here (since childProcess.send also has an
 | 
			
		||||
 * internal queue) is because the worker could be doing asynchronous work, and
 | 
			
		||||
 * this would lead to the child process to read its receiving buffer and start a
 | 
			
		||||
 * second call. By queueing calls here, we don't send the next call to the
 | 
			
		||||
 * children until we receive the result of the previous one.
 | 
			
		||||
 *
 | 
			
		||||
 * As soon as a request starts to be processed by a worker, its "processed"
 | 
			
		||||
 * field is changed to "true", so that other workers which might encounter the
 | 
			
		||||
 * same call skip it.
 | 
			
		||||
 */
 | 
			
		||||
export default class ChildProcessWorker implements WorkerInterface {
 | 
			
		||||
    private _child;
 | 
			
		||||
    private _options;
 | 
			
		||||
    private _onProcessEnd;
 | 
			
		||||
    private _fakeStream;
 | 
			
		||||
    private _request;
 | 
			
		||||
    private _retries;
 | 
			
		||||
    private _stderr;
 | 
			
		||||
    private _stdout;
 | 
			
		||||
    constructor(options: WorkerOptions);
 | 
			
		||||
    initialize(): void;
 | 
			
		||||
    private _shutdown;
 | 
			
		||||
    onMessage(response: ParentMessage): void;
 | 
			
		||||
    onExit(exitCode: number): void;
 | 
			
		||||
    send(request: ChildMessage, onProcessStart: OnStart, onProcessEnd: OnEnd): void;
 | 
			
		||||
    getWorkerId(): number;
 | 
			
		||||
    getStdout(): NodeJS.ReadableStream | null;
 | 
			
		||||
    getStderr(): NodeJS.ReadableStream | null;
 | 
			
		||||
    private _getFakeStream;
 | 
			
		||||
}
 | 
			
		||||
//# sourceMappingURL=ChildProcessWorker.d.ts.map
 | 
			
		||||
							
								
								
									
										1
									
								
								node_modules/jest-worker/build/workers/ChildProcessWorker.d.ts.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/jest-worker/build/workers/ChildProcessWorker.d.ts.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
			
		||||
{"version":3,"file":"ChildProcessWorker.d.ts","sourceRoot":"","sources":["../../src/workers/ChildProcessWorker.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;;AAOH,OAAO,EAKL,eAAe,EACf,YAAY,EACZ,KAAK,EACL,OAAO,EACP,aAAa,EACb,aAAa,EACd,MAAM,UAAU,CAAC;AAElB;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,CAAC,OAAO,OAAO,kBAAmB,YAAW,eAAe;IAChE,OAAO,CAAC,MAAM,CAAgB;IAC9B,OAAO,CAAC,QAAQ,CAAgB;IAChC,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,WAAW,CAAqB;IACxC,OAAO,CAAC,QAAQ,CAAsB;IACtC,OAAO,CAAC,QAAQ,CAAU;IAC1B,OAAO,CAAC,OAAO,CAAwC;IACvD,OAAO,CAAC,OAAO,CAAwC;gBAE3C,OAAO,EAAE,aAAa;IAUlC,UAAU;IAiEV,OAAO,CAAC,SAAS;IAQjB,SAAS,CAAC,QAAQ,EAAE,aAAa;IA6CjC,MAAM,CAAC,QAAQ,EAAE,MAAM;IAYvB,IAAI,CAAC,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,OAAO,EAAE,YAAY,EAAE,KAAK;IAcxE,WAAW;IAIX,SAAS,IAAI,MAAM,CAAC,cAAc,GAAG,IAAI;IAIzC,SAAS,IAAI,MAAM,CAAC,cAAc,GAAG,IAAI;IAIzC,OAAO,CAAC,cAAc;CAMvB"}
 | 
			
		||||
							
								
								
									
										310
									
								
								node_modules/jest-worker/build/workers/ChildProcessWorker.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										310
									
								
								node_modules/jest-worker/build/workers/ChildProcessWorker.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,310 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
Object.defineProperty(exports, '__esModule', {
 | 
			
		||||
  value: true
 | 
			
		||||
});
 | 
			
		||||
exports.default = void 0;
 | 
			
		||||
 | 
			
		||||
function _child_process() {
 | 
			
		||||
  const data = _interopRequireDefault(require('child_process'));
 | 
			
		||||
 | 
			
		||||
  _child_process = function _child_process() {
 | 
			
		||||
    return data;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return data;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _stream() {
 | 
			
		||||
  const data = require('stream');
 | 
			
		||||
 | 
			
		||||
  _stream = function _stream() {
 | 
			
		||||
    return data;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return data;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _mergeStream() {
 | 
			
		||||
  const data = _interopRequireDefault(require('merge-stream'));
 | 
			
		||||
 | 
			
		||||
  _mergeStream = function _mergeStream() {
 | 
			
		||||
    return data;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return data;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _supportsColor() {
 | 
			
		||||
  const data = _interopRequireDefault(require('supports-color'));
 | 
			
		||||
 | 
			
		||||
  _supportsColor = function _supportsColor() {
 | 
			
		||||
    return data;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return data;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var _types = require('../types');
 | 
			
		||||
 | 
			
		||||
function _interopRequireDefault(obj) {
 | 
			
		||||
  return obj && obj.__esModule ? obj : {default: obj};
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _objectSpread(target) {
 | 
			
		||||
  for (var i = 1; i < arguments.length; i++) {
 | 
			
		||||
    var source = arguments[i] != null ? arguments[i] : {};
 | 
			
		||||
    var ownKeys = Object.keys(source);
 | 
			
		||||
    if (typeof Object.getOwnPropertySymbols === 'function') {
 | 
			
		||||
      ownKeys = ownKeys.concat(
 | 
			
		||||
        Object.getOwnPropertySymbols(source).filter(function(sym) {
 | 
			
		||||
          return Object.getOwnPropertyDescriptor(source, sym).enumerable;
 | 
			
		||||
        })
 | 
			
		||||
      );
 | 
			
		||||
    }
 | 
			
		||||
    ownKeys.forEach(function(key) {
 | 
			
		||||
      _defineProperty(target, key, source[key]);
 | 
			
		||||
    });
 | 
			
		||||
  }
 | 
			
		||||
  return target;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _defineProperty(obj, key, value) {
 | 
			
		||||
  if (key in obj) {
 | 
			
		||||
    Object.defineProperty(obj, key, {
 | 
			
		||||
      value: value,
 | 
			
		||||
      enumerable: true,
 | 
			
		||||
      configurable: true,
 | 
			
		||||
      writable: true
 | 
			
		||||
    });
 | 
			
		||||
  } else {
 | 
			
		||||
    obj[key] = value;
 | 
			
		||||
  }
 | 
			
		||||
  return obj;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * This class wraps the child process and provides a nice interface to
 | 
			
		||||
 * communicate with. It takes care of:
 | 
			
		||||
 *
 | 
			
		||||
 *  - Re-spawning the process if it dies.
 | 
			
		||||
 *  - Queues calls while the worker is busy.
 | 
			
		||||
 *  - Re-sends the requests if the worker blew up.
 | 
			
		||||
 *
 | 
			
		||||
 * The reason for queueing them here (since childProcess.send also has an
 | 
			
		||||
 * internal queue) is because the worker could be doing asynchronous work, and
 | 
			
		||||
 * this would lead to the child process to read its receiving buffer and start a
 | 
			
		||||
 * second call. By queueing calls here, we don't send the next call to the
 | 
			
		||||
 * children until we receive the result of the previous one.
 | 
			
		||||
 *
 | 
			
		||||
 * As soon as a request starts to be processed by a worker, its "processed"
 | 
			
		||||
 * field is changed to "true", so that other workers which might encounter the
 | 
			
		||||
 * same call skip it.
 | 
			
		||||
 */
 | 
			
		||||
class ChildProcessWorker {
 | 
			
		||||
  constructor(options) {
 | 
			
		||||
    _defineProperty(this, '_child', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_options', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_onProcessEnd', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_fakeStream', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_request', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_retries', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_stderr', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_stdout', void 0);
 | 
			
		||||
 | 
			
		||||
    this._options = options;
 | 
			
		||||
    this._fakeStream = null;
 | 
			
		||||
    this._request = null;
 | 
			
		||||
    this._stderr = null;
 | 
			
		||||
    this._stdout = null;
 | 
			
		||||
    this.initialize();
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  initialize() {
 | 
			
		||||
    const forceColor = _supportsColor().default.stdout
 | 
			
		||||
      ? {
 | 
			
		||||
          FORCE_COLOR: '1'
 | 
			
		||||
        }
 | 
			
		||||
      : {};
 | 
			
		||||
 | 
			
		||||
    const child = _child_process().default.fork(
 | 
			
		||||
      require.resolve('./processChild'),
 | 
			
		||||
      [],
 | 
			
		||||
      _objectSpread(
 | 
			
		||||
        {
 | 
			
		||||
          cwd: process.cwd(),
 | 
			
		||||
          env: _objectSpread(
 | 
			
		||||
            {},
 | 
			
		||||
            process.env,
 | 
			
		||||
            {
 | 
			
		||||
              JEST_WORKER_ID: String(this._options.workerId + 1)
 | 
			
		||||
            },
 | 
			
		||||
            forceColor
 | 
			
		||||
          ),
 | 
			
		||||
          // Suppress --debug / --inspect flags while preserving others (like --harmony).
 | 
			
		||||
          execArgv: process.execArgv.filter(v => !/^--(debug|inspect)/.test(v)),
 | 
			
		||||
          silent: true
 | 
			
		||||
        },
 | 
			
		||||
        this._options.forkOptions
 | 
			
		||||
      )
 | 
			
		||||
    );
 | 
			
		||||
 | 
			
		||||
    if (child.stdout) {
 | 
			
		||||
      if (!this._stdout) {
 | 
			
		||||
        // We need to add a permanent stream to the merged stream to prevent it
 | 
			
		||||
        // from ending when the subprocess stream ends
 | 
			
		||||
        this._stdout = (0, _mergeStream().default)(this._getFakeStream());
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      this._stdout.add(child.stdout);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (child.stderr) {
 | 
			
		||||
      if (!this._stderr) {
 | 
			
		||||
        // We need to add a permanent stream to the merged stream to prevent it
 | 
			
		||||
        // from ending when the subprocess stream ends
 | 
			
		||||
        this._stderr = (0, _mergeStream().default)(this._getFakeStream());
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      this._stderr.add(child.stderr);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    child.on('message', this.onMessage.bind(this));
 | 
			
		||||
    child.on('exit', this.onExit.bind(this));
 | 
			
		||||
    child.send([
 | 
			
		||||
      _types.CHILD_MESSAGE_INITIALIZE,
 | 
			
		||||
      false,
 | 
			
		||||
      this._options.workerPath,
 | 
			
		||||
      this._options.setupArgs
 | 
			
		||||
    ]);
 | 
			
		||||
    this._child = child;
 | 
			
		||||
    this._retries++; // If we exceeded the amount of retries, we will emulate an error reply
 | 
			
		||||
    // coming from the child. This avoids code duplication related with cleaning
 | 
			
		||||
    // the queue, and scheduling the next call.
 | 
			
		||||
 | 
			
		||||
    if (this._retries > this._options.maxRetries) {
 | 
			
		||||
      const error = new Error('Call retries were exceeded');
 | 
			
		||||
      this.onMessage([
 | 
			
		||||
        _types.PARENT_MESSAGE_CLIENT_ERROR,
 | 
			
		||||
        error.name,
 | 
			
		||||
        error.message,
 | 
			
		||||
        error.stack,
 | 
			
		||||
        {
 | 
			
		||||
          type: 'WorkerError'
 | 
			
		||||
        }
 | 
			
		||||
      ]);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  _shutdown() {
 | 
			
		||||
    // End the temporary streams so the merged streams end too
 | 
			
		||||
    if (this._fakeStream) {
 | 
			
		||||
      this._fakeStream.end();
 | 
			
		||||
 | 
			
		||||
      this._fakeStream = null;
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  onMessage(response) {
 | 
			
		||||
    let error;
 | 
			
		||||
 | 
			
		||||
    switch (response[0]) {
 | 
			
		||||
      case _types.PARENT_MESSAGE_OK:
 | 
			
		||||
        this._onProcessEnd(null, response[1]);
 | 
			
		||||
 | 
			
		||||
        break;
 | 
			
		||||
 | 
			
		||||
      case _types.PARENT_MESSAGE_CLIENT_ERROR:
 | 
			
		||||
        error = response[4];
 | 
			
		||||
 | 
			
		||||
        if (error != null && typeof error === 'object') {
 | 
			
		||||
          const extra = error; // @ts-ignore: no index
 | 
			
		||||
 | 
			
		||||
          const NativeCtor = global[response[1]];
 | 
			
		||||
          const Ctor = typeof NativeCtor === 'function' ? NativeCtor : Error;
 | 
			
		||||
          error = new Ctor(response[2]);
 | 
			
		||||
          error.type = response[1];
 | 
			
		||||
          error.stack = response[3];
 | 
			
		||||
 | 
			
		||||
          for (const key in extra) {
 | 
			
		||||
            // @ts-ignore: adding custom properties to errors.
 | 
			
		||||
            error[key] = extra[key];
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        this._onProcessEnd(error, null);
 | 
			
		||||
 | 
			
		||||
        break;
 | 
			
		||||
 | 
			
		||||
      case _types.PARENT_MESSAGE_SETUP_ERROR:
 | 
			
		||||
        error = new Error('Error when calling setup: ' + response[2]); // @ts-ignore: adding custom properties to errors.
 | 
			
		||||
 | 
			
		||||
        error.type = response[1];
 | 
			
		||||
        error.stack = response[3];
 | 
			
		||||
 | 
			
		||||
        this._onProcessEnd(error, null);
 | 
			
		||||
 | 
			
		||||
        break;
 | 
			
		||||
 | 
			
		||||
      default:
 | 
			
		||||
        throw new TypeError('Unexpected response from worker: ' + response[0]);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  onExit(exitCode) {
 | 
			
		||||
    if (exitCode !== 0) {
 | 
			
		||||
      this.initialize();
 | 
			
		||||
 | 
			
		||||
      if (this._request) {
 | 
			
		||||
        this._child.send(this._request);
 | 
			
		||||
      }
 | 
			
		||||
    } else {
 | 
			
		||||
      this._shutdown();
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  send(request, onProcessStart, onProcessEnd) {
 | 
			
		||||
    onProcessStart(this);
 | 
			
		||||
 | 
			
		||||
    this._onProcessEnd = (...args) => {
 | 
			
		||||
      // Clean the request to avoid sending past requests to workers that fail
 | 
			
		||||
      // while waiting for a new request (timers, unhandled rejections...)
 | 
			
		||||
      this._request = null;
 | 
			
		||||
      return onProcessEnd(...args);
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    this._request = request;
 | 
			
		||||
    this._retries = 0;
 | 
			
		||||
 | 
			
		||||
    this._child.send(request);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  getWorkerId() {
 | 
			
		||||
    return this._options.workerId;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  getStdout() {
 | 
			
		||||
    return this._stdout;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  getStderr() {
 | 
			
		||||
    return this._stderr;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  _getFakeStream() {
 | 
			
		||||
    if (!this._fakeStream) {
 | 
			
		||||
      this._fakeStream = new (_stream()).PassThrough();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return this._fakeStream;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
exports.default = ChildProcessWorker;
 | 
			
		||||
							
								
								
									
										29
									
								
								node_modules/jest-worker/build/workers/NodeThreadsWorker.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								node_modules/jest-worker/build/workers/NodeThreadsWorker.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,29 @@
 | 
			
		||||
/**
 | 
			
		||||
 * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
 | 
			
		||||
 *
 | 
			
		||||
 * This source code is licensed under the MIT license found in the
 | 
			
		||||
 * LICENSE file in the root directory of this source tree.
 | 
			
		||||
 */
 | 
			
		||||
/// <reference types="node" />
 | 
			
		||||
import { ChildMessage, OnEnd, OnStart, WorkerOptions, WorkerInterface, ParentMessage } from '../types';
 | 
			
		||||
export default class ExperimentalWorker implements WorkerInterface {
 | 
			
		||||
    private _worker;
 | 
			
		||||
    private _options;
 | 
			
		||||
    private _onProcessEnd;
 | 
			
		||||
    private _request;
 | 
			
		||||
    private _retries;
 | 
			
		||||
    private _stderr;
 | 
			
		||||
    private _stdout;
 | 
			
		||||
    private _fakeStream;
 | 
			
		||||
    constructor(options: WorkerOptions);
 | 
			
		||||
    initialize(): void;
 | 
			
		||||
    private _shutdown;
 | 
			
		||||
    onMessage(response: ParentMessage): void;
 | 
			
		||||
    onExit(exitCode: number): void;
 | 
			
		||||
    send(request: ChildMessage, onProcessStart: OnStart, onProcessEnd: OnEnd): void;
 | 
			
		||||
    getWorkerId(): number;
 | 
			
		||||
    getStdout(): NodeJS.ReadableStream | null;
 | 
			
		||||
    getStderr(): NodeJS.ReadableStream | null;
 | 
			
		||||
    private _getFakeStream;
 | 
			
		||||
}
 | 
			
		||||
//# sourceMappingURL=NodeThreadsWorker.d.ts.map
 | 
			
		||||
							
								
								
									
										1
									
								
								node_modules/jest-worker/build/workers/NodeThreadsWorker.d.ts.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/jest-worker/build/workers/NodeThreadsWorker.d.ts.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
			
		||||
{"version":3,"file":"NodeThreadsWorker.d.ts","sourceRoot":"","sources":["../../src/workers/NodeThreadsWorker.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;;AASH,OAAO,EAKL,YAAY,EACZ,KAAK,EACL,OAAO,EACP,aAAa,EACb,eAAe,EACf,aAAa,EACd,MAAM,UAAU,CAAC;AAElB,MAAM,CAAC,OAAO,OAAO,kBAAmB,YAAW,eAAe;IAChE,OAAO,CAAC,OAAO,CAAU;IACzB,OAAO,CAAC,QAAQ,CAAgB;IAChC,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,QAAQ,CAAsB;IACtC,OAAO,CAAC,QAAQ,CAAU;IAC1B,OAAO,CAAC,OAAO,CAAwC;IACvD,OAAO,CAAC,OAAO,CAAwC;IACvD,OAAO,CAAC,WAAW,CAAqB;gBAE5B,OAAO,EAAE,aAAa;IAUlC,UAAU;IAkEV,OAAO,CAAC,SAAS;IAQjB,SAAS,CAAC,QAAQ,EAAE,aAAa;IA2CjC,MAAM,CAAC,QAAQ,EAAE,MAAM;IAYvB,IAAI,CAAC,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,OAAO,EAAE,YAAY,EAAE,KAAK;IAexE,WAAW;IAIX,SAAS,IAAI,MAAM,CAAC,cAAc,GAAG,IAAI;IAIzC,SAAS,IAAI,MAAM,CAAC,cAAc,GAAG,IAAI;IAIzC,OAAO,CAAC,cAAc;CAMvB"}
 | 
			
		||||
							
								
								
									
										289
									
								
								node_modules/jest-worker/build/workers/NodeThreadsWorker.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										289
									
								
								node_modules/jest-worker/build/workers/NodeThreadsWorker.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,289 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
Object.defineProperty(exports, '__esModule', {
 | 
			
		||||
  value: true
 | 
			
		||||
});
 | 
			
		||||
exports.default = void 0;
 | 
			
		||||
 | 
			
		||||
function _path() {
 | 
			
		||||
  const data = _interopRequireDefault(require('path'));
 | 
			
		||||
 | 
			
		||||
  _path = function _path() {
 | 
			
		||||
    return data;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return data;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _stream() {
 | 
			
		||||
  const data = require('stream');
 | 
			
		||||
 | 
			
		||||
  _stream = function _stream() {
 | 
			
		||||
    return data;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return data;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _worker_threads() {
 | 
			
		||||
  const data = require('worker_threads');
 | 
			
		||||
 | 
			
		||||
  _worker_threads = function _worker_threads() {
 | 
			
		||||
    return data;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return data;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _mergeStream() {
 | 
			
		||||
  const data = _interopRequireDefault(require('merge-stream'));
 | 
			
		||||
 | 
			
		||||
  _mergeStream = function _mergeStream() {
 | 
			
		||||
    return data;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return data;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var _types = require('../types');
 | 
			
		||||
 | 
			
		||||
function _interopRequireDefault(obj) {
 | 
			
		||||
  return obj && obj.__esModule ? obj : {default: obj};
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _objectSpread(target) {
 | 
			
		||||
  for (var i = 1; i < arguments.length; i++) {
 | 
			
		||||
    var source = arguments[i] != null ? arguments[i] : {};
 | 
			
		||||
    var ownKeys = Object.keys(source);
 | 
			
		||||
    if (typeof Object.getOwnPropertySymbols === 'function') {
 | 
			
		||||
      ownKeys = ownKeys.concat(
 | 
			
		||||
        Object.getOwnPropertySymbols(source).filter(function(sym) {
 | 
			
		||||
          return Object.getOwnPropertyDescriptor(source, sym).enumerable;
 | 
			
		||||
        })
 | 
			
		||||
      );
 | 
			
		||||
    }
 | 
			
		||||
    ownKeys.forEach(function(key) {
 | 
			
		||||
      _defineProperty(target, key, source[key]);
 | 
			
		||||
    });
 | 
			
		||||
  }
 | 
			
		||||
  return target;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _defineProperty(obj, key, value) {
 | 
			
		||||
  if (key in obj) {
 | 
			
		||||
    Object.defineProperty(obj, key, {
 | 
			
		||||
      value: value,
 | 
			
		||||
      enumerable: true,
 | 
			
		||||
      configurable: true,
 | 
			
		||||
      writable: true
 | 
			
		||||
    });
 | 
			
		||||
  } else {
 | 
			
		||||
    obj[key] = value;
 | 
			
		||||
  }
 | 
			
		||||
  return obj;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
class ExperimentalWorker {
 | 
			
		||||
  constructor(options) {
 | 
			
		||||
    _defineProperty(this, '_worker', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_options', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_onProcessEnd', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_request', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_retries', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_stderr', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_stdout', void 0);
 | 
			
		||||
 | 
			
		||||
    _defineProperty(this, '_fakeStream', void 0);
 | 
			
		||||
 | 
			
		||||
    this._options = options;
 | 
			
		||||
    this._request = null;
 | 
			
		||||
    this._stderr = null;
 | 
			
		||||
    this._stdout = null;
 | 
			
		||||
    this._fakeStream = null;
 | 
			
		||||
    this.initialize();
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  initialize() {
 | 
			
		||||
    this._worker = new (_worker_threads()).Worker(
 | 
			
		||||
      _path().default.resolve(__dirname, './threadChild.js'),
 | 
			
		||||
      {
 | 
			
		||||
        eval: false,
 | 
			
		||||
        stderr: true,
 | 
			
		||||
        stdout: true,
 | 
			
		||||
        workerData: _objectSpread(
 | 
			
		||||
          {
 | 
			
		||||
            cwd: process.cwd(),
 | 
			
		||||
            env: _objectSpread({}, process.env, {
 | 
			
		||||
              JEST_WORKER_ID: String(this._options.workerId + 1) // 0-indexed workerId, 1-indexed JEST_WORKER_ID
 | 
			
		||||
            }),
 | 
			
		||||
            // Suppress --debug / --inspect flags while preserving others (like --harmony).
 | 
			
		||||
            execArgv: process.execArgv.filter(
 | 
			
		||||
              v => !/^--(debug|inspect)/.test(v)
 | 
			
		||||
            ),
 | 
			
		||||
            silent: true
 | 
			
		||||
          },
 | 
			
		||||
          this._options.forkOptions
 | 
			
		||||
        )
 | 
			
		||||
      }
 | 
			
		||||
    );
 | 
			
		||||
 | 
			
		||||
    if (this._worker.stdout) {
 | 
			
		||||
      if (!this._stdout) {
 | 
			
		||||
        // We need to add a permanent stream to the merged stream to prevent it
 | 
			
		||||
        // from ending when the subprocess stream ends
 | 
			
		||||
        this._stdout = (0, _mergeStream().default)(this._getFakeStream());
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      this._stdout.add(this._worker.stdout);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (this._worker.stderr) {
 | 
			
		||||
      if (!this._stderr) {
 | 
			
		||||
        // We need to add a permanent stream to the merged stream to prevent it
 | 
			
		||||
        // from ending when the subprocess stream ends
 | 
			
		||||
        this._stderr = (0, _mergeStream().default)(this._getFakeStream());
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      this._stderr.add(this._worker.stderr);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    this._worker.on('message', this.onMessage.bind(this));
 | 
			
		||||
 | 
			
		||||
    this._worker.on('exit', this.onExit.bind(this));
 | 
			
		||||
 | 
			
		||||
    this._worker.postMessage([
 | 
			
		||||
      _types.CHILD_MESSAGE_INITIALIZE,
 | 
			
		||||
      false,
 | 
			
		||||
      this._options.workerPath,
 | 
			
		||||
      this._options.setupArgs
 | 
			
		||||
    ]);
 | 
			
		||||
 | 
			
		||||
    this._retries++; // If we exceeded the amount of retries, we will emulate an error reply
 | 
			
		||||
    // coming from the child. This avoids code duplication related with cleaning
 | 
			
		||||
    // the queue, and scheduling the next call.
 | 
			
		||||
 | 
			
		||||
    if (this._retries > this._options.maxRetries) {
 | 
			
		||||
      const error = new Error('Call retries were exceeded');
 | 
			
		||||
      this.onMessage([
 | 
			
		||||
        _types.PARENT_MESSAGE_CLIENT_ERROR,
 | 
			
		||||
        error.name,
 | 
			
		||||
        error.message,
 | 
			
		||||
        error.stack,
 | 
			
		||||
        {
 | 
			
		||||
          type: 'WorkerError'
 | 
			
		||||
        }
 | 
			
		||||
      ]);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  _shutdown() {
 | 
			
		||||
    // End the permanent stream so the merged stream end too
 | 
			
		||||
    if (this._fakeStream) {
 | 
			
		||||
      this._fakeStream.end();
 | 
			
		||||
 | 
			
		||||
      this._fakeStream = null;
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  onMessage(response) {
 | 
			
		||||
    let error;
 | 
			
		||||
 | 
			
		||||
    switch (response[0]) {
 | 
			
		||||
      case _types.PARENT_MESSAGE_OK:
 | 
			
		||||
        this._onProcessEnd(null, response[1]);
 | 
			
		||||
 | 
			
		||||
        break;
 | 
			
		||||
 | 
			
		||||
      case _types.PARENT_MESSAGE_CLIENT_ERROR:
 | 
			
		||||
        error = response[4];
 | 
			
		||||
 | 
			
		||||
        if (error != null && typeof error === 'object') {
 | 
			
		||||
          const extra = error; // @ts-ignore: no index
 | 
			
		||||
 | 
			
		||||
          const NativeCtor = global[response[1]];
 | 
			
		||||
          const Ctor = typeof NativeCtor === 'function' ? NativeCtor : Error;
 | 
			
		||||
          error = new Ctor(response[2]);
 | 
			
		||||
          error.type = response[1];
 | 
			
		||||
          error.stack = response[3];
 | 
			
		||||
 | 
			
		||||
          for (const key in extra) {
 | 
			
		||||
            // @ts-ignore: no index
 | 
			
		||||
            error[key] = extra[key];
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        this._onProcessEnd(error, null);
 | 
			
		||||
 | 
			
		||||
        break;
 | 
			
		||||
 | 
			
		||||
      case _types.PARENT_MESSAGE_SETUP_ERROR:
 | 
			
		||||
        error = new Error('Error when calling setup: ' + response[2]); // @ts-ignore: adding custom properties to errors.
 | 
			
		||||
 | 
			
		||||
        error.type = response[1];
 | 
			
		||||
        error.stack = response[3];
 | 
			
		||||
 | 
			
		||||
        this._onProcessEnd(error, null);
 | 
			
		||||
 | 
			
		||||
        break;
 | 
			
		||||
 | 
			
		||||
      default:
 | 
			
		||||
        throw new TypeError('Unexpected response from worker: ' + response[0]);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  onExit(exitCode) {
 | 
			
		||||
    if (exitCode !== 0) {
 | 
			
		||||
      this.initialize();
 | 
			
		||||
 | 
			
		||||
      if (this._request) {
 | 
			
		||||
        this._worker.postMessage(this._request);
 | 
			
		||||
      }
 | 
			
		||||
    } else {
 | 
			
		||||
      this._shutdown();
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  send(request, onProcessStart, onProcessEnd) {
 | 
			
		||||
    onProcessStart(this);
 | 
			
		||||
 | 
			
		||||
    this._onProcessEnd = (...args) => {
 | 
			
		||||
      // Clean the request to avoid sending past requests to workers that fail
 | 
			
		||||
      // while waiting for a new request (timers, unhandled rejections...)
 | 
			
		||||
      this._request = null;
 | 
			
		||||
      return onProcessEnd(...args);
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    this._request = request;
 | 
			
		||||
    this._retries = 0;
 | 
			
		||||
 | 
			
		||||
    this._worker.postMessage(request);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  getWorkerId() {
 | 
			
		||||
    return this._options.workerId;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  getStdout() {
 | 
			
		||||
    return this._stdout;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  getStderr() {
 | 
			
		||||
    return this._stderr;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  _getFakeStream() {
 | 
			
		||||
    if (!this._fakeStream) {
 | 
			
		||||
      this._fakeStream = new (_stream()).PassThrough();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return this._fakeStream;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
exports.default = ExperimentalWorker;
 | 
			
		||||
							
								
								
									
										8
									
								
								node_modules/jest-worker/build/workers/processChild.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								node_modules/jest-worker/build/workers/processChild.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,8 @@
 | 
			
		||||
/**
 | 
			
		||||
 * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
 | 
			
		||||
 *
 | 
			
		||||
 * This source code is licensed under the MIT license found in the
 | 
			
		||||
 * LICENSE file in the root directory of this source tree.
 | 
			
		||||
 */
 | 
			
		||||
export {};
 | 
			
		||||
//# sourceMappingURL=processChild.d.ts.map
 | 
			
		||||
							
								
								
									
										1
									
								
								node_modules/jest-worker/build/workers/processChild.d.ts.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/jest-worker/build/workers/processChild.d.ts.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
			
		||||
{"version":3,"file":"processChild.d.ts","sourceRoot":"","sources":["../../src/workers/processChild.ts"],"names":[],"mappings":"AAAA;;;;;GAKG"}
 | 
			
		||||
							
								
								
									
										166
									
								
								node_modules/jest-worker/build/workers/processChild.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								node_modules/jest-worker/build/workers/processChild.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,166 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
var _types = require('../types');
 | 
			
		||||
 | 
			
		||||
function _objectSpread(target) {
 | 
			
		||||
  for (var i = 1; i < arguments.length; i++) {
 | 
			
		||||
    var source = arguments[i] != null ? arguments[i] : {};
 | 
			
		||||
    var ownKeys = Object.keys(source);
 | 
			
		||||
    if (typeof Object.getOwnPropertySymbols === 'function') {
 | 
			
		||||
      ownKeys = ownKeys.concat(
 | 
			
		||||
        Object.getOwnPropertySymbols(source).filter(function(sym) {
 | 
			
		||||
          return Object.getOwnPropertyDescriptor(source, sym).enumerable;
 | 
			
		||||
        })
 | 
			
		||||
      );
 | 
			
		||||
    }
 | 
			
		||||
    ownKeys.forEach(function(key) {
 | 
			
		||||
      _defineProperty(target, key, source[key]);
 | 
			
		||||
    });
 | 
			
		||||
  }
 | 
			
		||||
  return target;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _defineProperty(obj, key, value) {
 | 
			
		||||
  if (key in obj) {
 | 
			
		||||
    Object.defineProperty(obj, key, {
 | 
			
		||||
      value: value,
 | 
			
		||||
      enumerable: true,
 | 
			
		||||
      configurable: true,
 | 
			
		||||
      writable: true
 | 
			
		||||
    });
 | 
			
		||||
  } else {
 | 
			
		||||
    obj[key] = value;
 | 
			
		||||
  }
 | 
			
		||||
  return obj;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
let file = null;
 | 
			
		||||
let setupArgs = [];
 | 
			
		||||
let initialized = false;
 | 
			
		||||
/**
 | 
			
		||||
 * This file is a small bootstrapper for workers. It sets up the communication
 | 
			
		||||
 * between the worker and the parent process, interpreting parent messages and
 | 
			
		||||
 * sending results back.
 | 
			
		||||
 *
 | 
			
		||||
 * The file loaded will be lazily initialized the first time any of the workers
 | 
			
		||||
 * is called. This is done for optimal performance: if the farm is initialized,
 | 
			
		||||
 * but no call is made to it, child Node processes will be consuming the least
 | 
			
		||||
 * possible amount of memory.
 | 
			
		||||
 *
 | 
			
		||||
 * If an invalid message is detected, the child will exit (by throwing) with a
 | 
			
		||||
 * non-zero exit code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
process.on('message', request => {
 | 
			
		||||
  switch (request[0]) {
 | 
			
		||||
    case _types.CHILD_MESSAGE_INITIALIZE:
 | 
			
		||||
      const init = request;
 | 
			
		||||
      file = init[2];
 | 
			
		||||
      setupArgs = request[3];
 | 
			
		||||
      break;
 | 
			
		||||
 | 
			
		||||
    case _types.CHILD_MESSAGE_CALL:
 | 
			
		||||
      const call = request;
 | 
			
		||||
      execMethod(call[2], call[3]);
 | 
			
		||||
      break;
 | 
			
		||||
 | 
			
		||||
    case _types.CHILD_MESSAGE_END:
 | 
			
		||||
      end();
 | 
			
		||||
      break;
 | 
			
		||||
 | 
			
		||||
    default:
 | 
			
		||||
      throw new TypeError(
 | 
			
		||||
        'Unexpected request from parent process: ' + request[0]
 | 
			
		||||
      );
 | 
			
		||||
  }
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
function reportSuccess(result) {
 | 
			
		||||
  if (!process || !process.send) {
 | 
			
		||||
    throw new Error('Child can only be used on a forked process');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  process.send([_types.PARENT_MESSAGE_OK, result]);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function reportClientError(error) {
 | 
			
		||||
  return reportError(error, _types.PARENT_MESSAGE_CLIENT_ERROR);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function reportInitializeError(error) {
 | 
			
		||||
  return reportError(error, _types.PARENT_MESSAGE_SETUP_ERROR);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function reportError(error, type) {
 | 
			
		||||
  if (!process || !process.send) {
 | 
			
		||||
    throw new Error('Child can only be used on a forked process');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  if (error == null) {
 | 
			
		||||
    error = new Error('"null" or "undefined" thrown');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  process.send([
 | 
			
		||||
    type,
 | 
			
		||||
    error.constructor && error.constructor.name,
 | 
			
		||||
    error.message,
 | 
			
		||||
    error.stack,
 | 
			
		||||
    typeof error === 'object' ? _objectSpread({}, error) : error
 | 
			
		||||
  ]);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function end() {
 | 
			
		||||
  const main = require(file);
 | 
			
		||||
 | 
			
		||||
  if (!main.teardown) {
 | 
			
		||||
    exitProcess();
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  execFunction(main.teardown, main, [], exitProcess, exitProcess);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function exitProcess() {
 | 
			
		||||
  process.exit(0);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function execMethod(method, args) {
 | 
			
		||||
  const main = require(file);
 | 
			
		||||
 | 
			
		||||
  let fn;
 | 
			
		||||
 | 
			
		||||
  if (method === 'default') {
 | 
			
		||||
    fn = main.__esModule ? main['default'] : main;
 | 
			
		||||
  } else {
 | 
			
		||||
    fn = main[method];
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  function execHelper() {
 | 
			
		||||
    execFunction(fn, main, args, reportSuccess, reportClientError);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  if (initialized || !main.setup) {
 | 
			
		||||
    execHelper();
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  initialized = true;
 | 
			
		||||
  execFunction(main.setup, main, setupArgs, execHelper, reportInitializeError);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function execFunction(fn, ctx, args, onResult, onError) {
 | 
			
		||||
  let result;
 | 
			
		||||
 | 
			
		||||
  try {
 | 
			
		||||
    result = fn.apply(ctx, args);
 | 
			
		||||
  } catch (err) {
 | 
			
		||||
    onError(err);
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  if (result && typeof result.then === 'function') {
 | 
			
		||||
    result.then(onResult, onError);
 | 
			
		||||
  } else {
 | 
			
		||||
    onResult(result);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										8
									
								
								node_modules/jest-worker/build/workers/threadChild.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								node_modules/jest-worker/build/workers/threadChild.d.ts
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,8 @@
 | 
			
		||||
/**
 | 
			
		||||
 * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
 | 
			
		||||
 *
 | 
			
		||||
 * This source code is licensed under the MIT license found in the
 | 
			
		||||
 * LICENSE file in the root directory of this source tree.
 | 
			
		||||
 */
 | 
			
		||||
export {};
 | 
			
		||||
//# sourceMappingURL=threadChild.d.ts.map
 | 
			
		||||
							
								
								
									
										1
									
								
								node_modules/jest-worker/build/workers/threadChild.d.ts.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								node_modules/jest-worker/build/workers/threadChild.d.ts.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
			
		||||
{"version":3,"file":"threadChild.d.ts","sourceRoot":"","sources":["../../src/workers/threadChild.ts"],"names":[],"mappings":"AAAA;;;;;GAKG"}
 | 
			
		||||
							
								
								
									
										176
									
								
								node_modules/jest-worker/build/workers/threadChild.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										176
									
								
								node_modules/jest-worker/build/workers/threadChild.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,176 @@
 | 
			
		||||
'use strict';
 | 
			
		||||
 | 
			
		||||
function _worker_threads() {
 | 
			
		||||
  const data = require('worker_threads');
 | 
			
		||||
 | 
			
		||||
  _worker_threads = function _worker_threads() {
 | 
			
		||||
    return data;
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return data;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
var _types = require('../types');
 | 
			
		||||
 | 
			
		||||
function _objectSpread(target) {
 | 
			
		||||
  for (var i = 1; i < arguments.length; i++) {
 | 
			
		||||
    var source = arguments[i] != null ? arguments[i] : {};
 | 
			
		||||
    var ownKeys = Object.keys(source);
 | 
			
		||||
    if (typeof Object.getOwnPropertySymbols === 'function') {
 | 
			
		||||
      ownKeys = ownKeys.concat(
 | 
			
		||||
        Object.getOwnPropertySymbols(source).filter(function(sym) {
 | 
			
		||||
          return Object.getOwnPropertyDescriptor(source, sym).enumerable;
 | 
			
		||||
        })
 | 
			
		||||
      );
 | 
			
		||||
    }
 | 
			
		||||
    ownKeys.forEach(function(key) {
 | 
			
		||||
      _defineProperty(target, key, source[key]);
 | 
			
		||||
    });
 | 
			
		||||
  }
 | 
			
		||||
  return target;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function _defineProperty(obj, key, value) {
 | 
			
		||||
  if (key in obj) {
 | 
			
		||||
    Object.defineProperty(obj, key, {
 | 
			
		||||
      value: value,
 | 
			
		||||
      enumerable: true,
 | 
			
		||||
      configurable: true,
 | 
			
		||||
      writable: true
 | 
			
		||||
    });
 | 
			
		||||
  } else {
 | 
			
		||||
    obj[key] = value;
 | 
			
		||||
  }
 | 
			
		||||
  return obj;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
let file = null;
 | 
			
		||||
let setupArgs = [];
 | 
			
		||||
let initialized = false;
 | 
			
		||||
/**
 | 
			
		||||
 * This file is a small bootstrapper for workers. It sets up the communication
 | 
			
		||||
 * between the worker and the parent process, interpreting parent messages and
 | 
			
		||||
 * sending results back.
 | 
			
		||||
 *
 | 
			
		||||
 * The file loaded will be lazily initialized the first time any of the workers
 | 
			
		||||
 * is called. This is done for optimal performance: if the farm is initialized,
 | 
			
		||||
 * but no call is made to it, child Node processes will be consuming the least
 | 
			
		||||
 * possible amount of memory.
 | 
			
		||||
 *
 | 
			
		||||
 * If an invalid message is detected, the child will exit (by throwing) with a
 | 
			
		||||
 * non-zero exit code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
_worker_threads().parentPort.on('message', request => {
 | 
			
		||||
  switch (request[0]) {
 | 
			
		||||
    case _types.CHILD_MESSAGE_INITIALIZE:
 | 
			
		||||
      const init = request;
 | 
			
		||||
      file = init[2];
 | 
			
		||||
      setupArgs = request[3];
 | 
			
		||||
      break;
 | 
			
		||||
 | 
			
		||||
    case _types.CHILD_MESSAGE_CALL:
 | 
			
		||||
      const call = request;
 | 
			
		||||
      execMethod(call[2], call[3]);
 | 
			
		||||
      break;
 | 
			
		||||
 | 
			
		||||
    case _types.CHILD_MESSAGE_END:
 | 
			
		||||
      end();
 | 
			
		||||
      break;
 | 
			
		||||
 | 
			
		||||
    default:
 | 
			
		||||
      throw new TypeError(
 | 
			
		||||
        'Unexpected request from parent process: ' + request[0]
 | 
			
		||||
      );
 | 
			
		||||
  }
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
function reportSuccess(result) {
 | 
			
		||||
  if (_worker_threads().isMainThread) {
 | 
			
		||||
    throw new Error('Child can only be used on a forked process');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  _worker_threads().parentPort.postMessage([_types.PARENT_MESSAGE_OK, result]);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function reportClientError(error) {
 | 
			
		||||
  return reportError(error, _types.PARENT_MESSAGE_CLIENT_ERROR);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function reportInitializeError(error) {
 | 
			
		||||
  return reportError(error, _types.PARENT_MESSAGE_SETUP_ERROR);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function reportError(error, type) {
 | 
			
		||||
  if (_worker_threads().isMainThread) {
 | 
			
		||||
    throw new Error('Child can only be used on a forked process');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  if (error == null) {
 | 
			
		||||
    error = new Error('"null" or "undefined" thrown');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  _worker_threads().parentPort.postMessage([
 | 
			
		||||
    type,
 | 
			
		||||
    error.constructor && error.constructor.name,
 | 
			
		||||
    error.message,
 | 
			
		||||
    error.stack,
 | 
			
		||||
    typeof error === 'object' ? _objectSpread({}, error) : error
 | 
			
		||||
  ]);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function end() {
 | 
			
		||||
  const main = require(file);
 | 
			
		||||
 | 
			
		||||
  if (!main.teardown) {
 | 
			
		||||
    exitProcess();
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  execFunction(main.teardown, main, [], exitProcess, exitProcess);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function exitProcess() {
 | 
			
		||||
  process.exit(0);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function execMethod(method, args) {
 | 
			
		||||
  const main = require(file);
 | 
			
		||||
 | 
			
		||||
  let fn;
 | 
			
		||||
 | 
			
		||||
  if (method === 'default') {
 | 
			
		||||
    fn = main.__esModule ? main['default'] : main;
 | 
			
		||||
  } else {
 | 
			
		||||
    fn = main[method];
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  function execHelper() {
 | 
			
		||||
    execFunction(fn, main, args, reportSuccess, reportClientError);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  if (initialized || !main.setup) {
 | 
			
		||||
    execHelper();
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  initialized = true;
 | 
			
		||||
  execFunction(main.setup, main, setupArgs, execHelper, reportInitializeError);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function execFunction(fn, ctx, args, onResult, onError) {
 | 
			
		||||
  let result;
 | 
			
		||||
 | 
			
		||||
  try {
 | 
			
		||||
    result = fn.apply(ctx, args);
 | 
			
		||||
  } catch (err) {
 | 
			
		||||
    onError(err);
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  if (result && typeof result.then === 'function') {
 | 
			
		||||
    result.then(onResult, onError);
 | 
			
		||||
  } else {
 | 
			
		||||
    onResult(result);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user