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, }