"use strict"; const { errors } = require('../errors'); /** * Throws an error with "details" property from * "errors" object. * @param {Object} details - Error details */ const throwInvalidOptionError = details => { if (!details) { details = errors.unknownError; } // throw this error synchronously, it will be caught later on and // the details will be propagated to the promise chain const err = new Error(); err.details = details; throw err; }; /** * Selects exec args based on the configured `testingType` * @param {string} testingType The type of tests being executed * @returns {string[]} The array of new exec arguments */ const processTestingType = options => { if (options.e2e && options.component) { return throwInvalidOptionError(errors.incompatibleTestTypeFlags); } if (options.testingType && (options.component || options.e2e)) { return throwInvalidOptionError(errors.incompatibleTestTypeFlags); } if (options.testingType === 'component' || options.component || options.ct) { return ['--testing-type', 'component']; } if (options.testingType === 'e2e' || options.e2e) { return ['--testing-type', 'e2e']; } if (options.testingType) { return throwInvalidOptionError(errors.invalidTestingType); } return []; }; /** * Throws an error if configFile is string 'false' or boolean false * @param {*} options */ const checkConfigFile = options => { // CLI will parse as string, module API can pass in boolean if (options.configFile === 'false' || options.configFile === false) { throwInvalidOptionError(errors.invalidConfigFile); } }; module.exports = { throwInvalidOptionError, processTestingType, checkConfigFile };