mirror of
https://github.com/cypress-io/cypress.git
synced 2026-01-08 15:39:54 -06:00
* cli, server: introduce --config-file argument * server: remove unused import * server: wip * server: consider --config-file in settings * server: pass options to settings.read from config * server: store options in Project class, pass to all settings calls * server: _initPlugins needs to accept options, for being called from server * server: accept optional external options in open * cli: update help snapshots * server: realizing now that these were written like this so they could be stubbed - removing some unnecessary usages of @options * cli: pass configFile when it's false * server: --config-file false and --config-file blah.json work * server: add unit tests for --config-file * server: pass configFile to desktop-gui * desktop-gui: display 'cypress.json' according to --config-file arg * desktop-gui: add integration tests for --config-file * cli: add tests for --config-file * PR changes * PR changes * cli: update snapshots * server: updating error messages * runner: update cypress.json mention * fixing name overlap * server: integration tests for --config-file * runner: update Header component tests * cli: fix snapshot * desktop-gui: fix test * driver: fixing error messages - not really any visibility to cli args from here so just static strings * server: update snapshots * server: update snapshots * cli: updating snapshot * driver: how did i miss this? * add skipped blank line to the snapshot * fix missing proxy require statement (was lost in merge of develop)...weird * add module API defs to types * module API tests * send better error when config file can't be found * fix dtslint test * update cli help to use 'configuration file' * update snapshot using 7.7.1 in place * fix failing config_spec * be.visible * show custom config file name in driver errors * add tests for non-default config file in driver error messages * single-quote config file name * 🙅 IIFEs 🙅 * 🤦 * fix failing test * fix failing test, cleanup * lint * delete duplicate coffee spec * Update run.js * Delete app_spec.js.mp4 * in open mode, only store projects to recents list if 'cypress.json' is the configFile discussion: https://git.io/JeGyF * feedback
132 lines
2.9 KiB
JavaScript
132 lines
2.9 KiB
JavaScript
const _ = require('lodash')
|
|
const debug = require('debug')('cypress:cli')
|
|
|
|
const util = require('../util')
|
|
const spawn = require('./spawn')
|
|
const verify = require('../tasks/verify')
|
|
|
|
// maps options collected by the CLI
|
|
// and forms list of CLI arguments to the server
|
|
const processRunOptions = (options = {}) => {
|
|
debug('processing run options')
|
|
|
|
const args = ['--run-project', options.project]
|
|
|
|
//// if key is set use that - else attempt to find it by environment variable
|
|
if (options.key == null) {
|
|
debug('--key is not set, looking up environment variable CYPRESS_RECORD_KEY')
|
|
options.key = util.getEnv('CYPRESS_RECORD_KEY') || util.getEnv('CYPRESS_CI_KEY')
|
|
}
|
|
|
|
if (options.env) {
|
|
args.push('--env', options.env)
|
|
}
|
|
|
|
if (options.config) {
|
|
args.push('--config', options.config)
|
|
}
|
|
|
|
if (options.configFile !== undefined) {
|
|
args.push('--config-file', options.configFile)
|
|
}
|
|
|
|
if (options.port) {
|
|
args.push('--port', options.port)
|
|
}
|
|
|
|
// if we have specific spec(s) push that into the args
|
|
if (options.spec) {
|
|
args.push('--spec', options.spec)
|
|
}
|
|
|
|
//// if we have a specific reporter push that into the args
|
|
if (options.reporter) {
|
|
args.push('--reporter', options.reporter)
|
|
}
|
|
|
|
//// if we have a specific reporter push that into the args
|
|
if (options.reporterOptions) {
|
|
args.push('--reporter-options', options.reporterOptions)
|
|
}
|
|
|
|
if (options.ci) {
|
|
//// push to display the deprecation message
|
|
args.push('--ci')
|
|
|
|
//// also automatically record
|
|
args.push('--record', true)
|
|
}
|
|
|
|
//// if we have a key assume we're in record mode
|
|
if (options.key) {
|
|
args.push('--key', options.key)
|
|
}
|
|
|
|
//// if record is defined and we're not
|
|
//// already in ci mode, then send it up
|
|
if (options.record != null && !options.ci) {
|
|
args.push('--record', options.record)
|
|
}
|
|
|
|
if (options.parallel) {
|
|
args.push('--parallel')
|
|
}
|
|
|
|
if (options.group) {
|
|
args.push('--group', options.group)
|
|
}
|
|
|
|
if (options.ciBuildId) {
|
|
args.push('--ci-build-id', options.ciBuildId)
|
|
}
|
|
|
|
if (options.outputPath) {
|
|
args.push('--output-path', options.outputPath)
|
|
}
|
|
|
|
if (options.browser) {
|
|
args.push('--browser', options.browser)
|
|
}
|
|
|
|
if (options.headed) {
|
|
args.push('--headed', options.headed)
|
|
}
|
|
|
|
if (options.exit === false) {
|
|
args.push('--no-exit')
|
|
}
|
|
|
|
return args
|
|
}
|
|
|
|
module.exports = {
|
|
processRunOptions,
|
|
// resolves with the number of failed tests
|
|
start (options = {}) {
|
|
_.defaults(options, {
|
|
key: null,
|
|
spec: null,
|
|
reporter: null,
|
|
reporterOptions: null,
|
|
project: process.cwd(),
|
|
})
|
|
|
|
function run () {
|
|
const args = processRunOptions(options)
|
|
|
|
debug('run to spawn.start args %j', args)
|
|
|
|
return spawn.start(args, {
|
|
dev: options.dev,
|
|
})
|
|
}
|
|
|
|
if (options.dev) {
|
|
return run()
|
|
}
|
|
|
|
return verify.start()
|
|
.then(run)
|
|
},
|
|
}
|