UNPKG

webgme-engine

Version:

WebGME server and Client API without a GUI

123 lines (105 loc) 3.51 kB
/*globals define*/ /*eslint-env node*/ /** * @author lattmann / https://github.com/lattmann */ define([], function () { 'use strict'; /** * Class describing an executor job. The data is used for communication between the * initiator/a monitor of the job and the worker executing the job. * * @param {object} parameters * @param {hash} parameters.hash - Job identifier. * @constructor * @alias JobInfo */ var JobInfo = function (parameters) { /** * Job identifier. * @type {string} */ this.hash = parameters.hash; /** * Array of hashes to {@link Artifact}s containing each requested result. * @type {string[]} */ this.resultHashes = parameters.resultHashes || []; /** * Hash to an {@link Artifact} containing the union of all requests results. * @type {string} */ this.resultSuperSet = parameters.resultSuperSet || null; this.userId = parameters.userId || []; /** * Current status of the job. * @type {string} */ this.status = parameters.status || null; /** * Timestamp of when the job was created. * @type {string} */ this.createTime = parameters.createTime || null; /** * Timestamp of when the job execution started by a worker. * @type {string} */ this.startTime = parameters.startTime || null; /** * Timestamp of when the job execution finished on the worker. * @type {string} */ this.finishTime = parameters.finishTime || null; /** * Id/label of the worker processing the job. * @type {string} */ this.worker = parameters.worker || null; /** * Array of labels for the job. * @type {string[]} */ this.labels = parameters.labels || []; /** * The (id) outputNumber (0, 1, 2, ...) of the latest {@link OutputInfo} (for this job) available on the server. * When no output is available the number is <b>null</b>. * @type {number} */ this.outputNumber = typeof parameters.outputNumber === 'number' ? parameters.outputNumber : null; }; /** * Array of statuses where the job hash finished and won't proceed. * @type {string[]} */ JobInfo.finishedStatuses = [ 'SUCCESS', 'CANCELED', 'FAILED_TO_EXECUTE', 'FAILED_TO_GET_SOURCE_METADATA', 'FAILED_SOURCE_COULD_NOT_BE_OBTAINED', 'FAILED_CREATING_SOURCE_ZIP', 'FAILED_UNZIP', 'FAILED_EXECUTOR_CONFIG', 'FAILED_TO_ARCHIVE_FILE', 'FAILED_TO_SAVE_JOINT_ARTIFACT', 'FAILED_TO_ADD_OBJECT_HASHES', 'FAILED_TO_SAVE_ARTIFACT']; /** * Returns true of the provided status is a finished status. * @param {string} status - The status of a job. * @returns {boolean} */ JobInfo.isFinishedStatus = function (status) { return JobInfo.finishedStatuses.indexOf(status) !== -1; }; /** * Returns true if the provided status is a failed finished status. * @param {string} status - The status of a job. * @returns {boolean} */ JobInfo.isFailedFinishedStatus = function (status) { return JobInfo.isFinishedStatus(status) && status !== 'SUCCESS'; }; return JobInfo; });