UNPKG

@browserstack/testcafe

Version:

Automated browser testing for the modern web development stack.

111 lines 17.2 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const device_specs_1 = require("device-specs"); const lodash_1 = require("lodash"); const argument_parsing_1 = require("../../../utils/argument-parsing"); const HEADLESS_DEFAULT_WIDTH = 1280; const HEADLESS_DEFAULT_HEIGHT = 800; const AVAILABLE_MODES = ['userProfile', 'headless', 'emulation']; const configCache = {}; function parseUserArgs(userArgs) { const parsedArgs = { headless: false, userDataDir: false, windowSize: false }; const splittedArgs = userArgs.split(' ').filter(arg => !!arg); splittedArgs.forEach(arg => { const keyValuePair = arg.split('='); const key = lodash_1.camelCase(keyValuePair[0]); parsedArgs[key] = parsedArgs[key] !== void 0; }); return parsedArgs; } function parseModes(modesStr, userArgs) { const parsed = argument_parsing_1.splitEscaped(modesStr, ':'); const path = argument_parsing_1.getPathFromParsedModes(parsed, AVAILABLE_MODES); const detectedModes = argument_parsing_1.getModes(parsed, AVAILABLE_MODES); let optionsString = ''; if (parsed.length) optionsString = parsed.shift(); while (parsed.length) optionsString += ':' + parsed.shift(); const userProfile = detectedModes.userProfile || userArgs.userDataDir; const headless = detectedModes.headless || userArgs.headless; const emulation = detectedModes.emulation || headless; const modes = { path, userProfile, headless, emulation }; return { modes, optionsString }; } function simplifyDeviceName(deviceName) { return deviceName.replace(/\s/g, '').toLowerCase(); } function findDevice(deviceName) { const simpleName = simplifyDeviceName(deviceName); return device_specs_1.emulatedDevices.filter(device => simplifyDeviceName(device.title).indexOf(simpleName) >= 0)[0]; } function getDeviceBasedOptions(deviceName, orientation) { if (!deviceName) return {}; const deviceData = findDevice(deviceName); if (!deviceData) return {}; const mobile = deviceData.capabilities.indexOf('mobile') >= 0; if (!orientation) orientation = mobile ? 'vertical' : 'horizontal'; return { mobile: mobile, orientation: orientation, touch: deviceData.capabilities.indexOf('touch') >= 0, width: deviceData.screen[orientation].width, height: deviceData.screen[orientation].height, scaleFactor: deviceData.screen['device-pixel-ratio'], userAgent: deviceData['user-agent'], }; } function parseOptions(str, useDefaultDimensions) { const parsed = argument_parsing_1.splitEscaped(str, ';'); const baseOptions = { width: useDefaultDimensions ? HEADLESS_DEFAULT_WIDTH : 0, height: useDefaultDimensions ? HEADLESS_DEFAULT_HEIGHT : 0, scaleFactor: 0, mobile: false, cdpPort: argument_parsing_1.findMatch(parsed, /^cdpPort=(.*)/) }; const deviceName = argument_parsing_1.findMatch(parsed, /^device=(.*)/); const orientation = argument_parsing_1.findMatch(parsed, /^orientation=(.*)/); const deviceBasedOptions = getDeviceBasedOptions(deviceName, orientation); let specifiedDeviceOptions = { orientation: orientation, touch: argument_parsing_1.hasMatch(parsed, /^touch=/) ? argument_parsing_1.isMatchTrue(parsed, /^touch=(.*)/) : void 0, mobile: argument_parsing_1.isMatchTrue(parsed, /^mobile=(.*)/), width: Number(argument_parsing_1.findMatch(parsed, /^width=(.*)/) || NaN), height: Number(argument_parsing_1.findMatch(parsed, /^height=(.*)/) || NaN), scaleFactor: Number(argument_parsing_1.findMatch(parsed, /^scaleFactor=(.*)/) || NaN), userAgent: argument_parsing_1.findMatch(parsed, /^userAgent=(.*)/) }; specifiedDeviceOptions = lodash_1.pickBy(specifiedDeviceOptions, optionValue => { return optionValue !== void 0 && optionValue !== '' && !Number.isNaN(optionValue); }); return Object.assign(baseOptions, deviceBasedOptions, specifiedDeviceOptions); } function getNewConfig(configString) { const { userArgs, modesString } = argument_parsing_1.parseConfig(configString); const parsedUserArgs = parseUserArgs(userArgs); const { modes, optionsString } = parseModes(modesString, parsedUserArgs); const useDefaultDimensions = modes.headless && !parsedUserArgs.windowSize; const options = parseOptions(optionsString, useDefaultDimensions); return Object.assign({ userArgs }, modes, options); } function default_1(configString) { if (!configCache[configString]) configCache[configString] = getNewConfig(configString); return configCache[configString]; } exports.default = default_1; module.exports = exports.default; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../../../../src/browser/provider/built-in/dedicated/chrome/config.js"],"names":[],"mappings":";;AAAA,+CAA+C;AAC/C,mCAA+D;AAC/D,sEAEyC;AAGzC,MAAM,sBAAsB,GAAI,IAAI,CAAC;AACrC,MAAM,uBAAuB,GAAG,GAAG,CAAC;AAEpC,MAAM,eAAe,GAAG,CAAC,aAAa,EAAE,UAAU,EAAE,WAAW,CAAC,CAAC;AAEjE,MAAM,WAAW,GAAG,EAAE,CAAC;AAEvB,SAAS,aAAa,CAAE,QAAQ;IAC5B,MAAM,UAAU,GAAG;QACf,QAAQ,EAAK,KAAK;QAClB,WAAW,EAAE,KAAK;QAClB,UAAU,EAAG,KAAK;KACrB,CAAC;IAEF,MAAM,YAAY,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IAE9D,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;QACvB,MAAM,YAAY,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACpC,MAAM,GAAG,GAAY,kBAAS,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;QAEhD,UAAU,CAAC,GAAG,CAAC,GAAG,UAAU,CAAC,GAAG,CAAC,KAAK,KAAK,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,OAAO,UAAU,CAAC;AACtB,CAAC;AAED,SAAS,UAAU,CAAE,QAAQ,EAAE,QAAQ;IACnC,MAAM,MAAM,GAAU,+BAAY,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;IAClD,MAAM,IAAI,GAAY,yCAAsB,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;IACtE,MAAM,aAAa,GAAG,2BAAQ,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;IACxD,IAAI,aAAa,GAAG,EAAE,CAAC;IAEvB,IAAI,MAAM,CAAC,MAAM;QACb,aAAa,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC;IAEnC,OAAO,MAAM,CAAC,MAAM;QAChB,aAAa,IAAI,GAAG,GAAG,MAAM,CAAC,KAAK,EAAE,CAAC;IAE1C,MAAM,WAAW,GAAG,aAAa,CAAC,WAAW,IAAI,QAAQ,CAAC,WAAW,CAAC;IACtE,MAAM,QAAQ,GAAM,aAAa,CAAC,QAAQ,IAAI,QAAQ,CAAC,QAAQ,CAAC;IAChE,MAAM,SAAS,GAAK,aAAa,CAAC,SAAS,IAAI,QAAQ,CAAC;IAExD,MAAM,KAAK,GAAG;QACV,IAAI;QACJ,WAAW;QACX,QAAQ;QACR,SAAS;KACZ,CAAC;IAEF,OAAO,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC;AACpC,CAAC;AAED,SAAS,kBAAkB,CAAE,UAAU;IACnC,OAAO,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;AACvD,CAAC;AAED,SAAS,UAAU,CAAE,UAAU;IAC3B,MAAM,UAAU,GAAG,kBAAkB,CAAC,UAAU,CAAC,CAAC;IAElD,OAAO,8BAAe,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC1G,CAAC;AAED,SAAS,qBAAqB,CAAE,UAAU,EAAE,WAAW;IACnD,IAAI,CAAC,UAAU;QACX,OAAO,EAAE,CAAC;IAEd,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC,CAAC;IAE1C,IAAI,CAAC,UAAU;QACX,OAAO,EAAE,CAAC;IAEd,MAAM,MAAM,GAAG,UAAU,CAAC,YAAY,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAE9D,IAAI,CAAC,WAAW;QACZ,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC;IAErD,OAAO;QACH,MAAM,EAAO,MAAM;QACnB,WAAW,EAAE,WAAW;QACxB,KAAK,EAAQ,UAAU,CAAC,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC;QAC1D,KAAK,EAAQ,UAAU,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,KAAK;QACjD,MAAM,EAAO,UAAU,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,MAAM;QAClD,WAAW,EAAE,UAAU,CAAC,MAAM,CAAC,oBAAoB,CAAC;QACpD,SAAS,EAAI,UAAU,CAAC,YAAY,CAAC;KACxC,CAAC;AACN,CAAC;AAED,SAAS,YAAY,CAAE,GAAG,EAAE,oBAAoB;IAC5C,MAAM,MAAM,GAAG,+BAAY,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IAEtC,MAAM,WAAW,GAAG;QAChB,KAAK,EAAQ,oBAAoB,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC;QAC9D,MAAM,EAAO,oBAAoB,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC;QAC/D,WAAW,EAAE,CAAC;QACd,MAAM,EAAO,KAAK;QAClB,OAAO,EAAM,4BAAS,CAAC,MAAM,EAAE,eAAe,CAAC;KAClD,CAAC;IAEF,MAAM,UAAU,GAAW,4BAAS,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;IAC7D,MAAM,WAAW,GAAU,4BAAS,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC;IAClE,MAAM,kBAAkB,GAAG,qBAAqB,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;IAE1E,IAAI,sBAAsB,GAAG;QACzB,WAAW,EAAE,WAAW;QACxB,KAAK,EAAQ,2BAAQ,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,8BAAW,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QACtF,MAAM,EAAO,8BAAW,CAAC,MAAM,EAAE,cAAc,CAAC;QAChD,KAAK,EAAQ,MAAM,CAAC,4BAAS,CAAC,MAAM,EAAE,aAAa,CAAC,IAAI,GAAG,CAAC;QAC5D,MAAM,EAAO,MAAM,CAAC,4BAAS,CAAC,MAAM,EAAE,cAAc,CAAC,IAAI,GAAG,CAAC;QAC7D,WAAW,EAAE,MAAM,CAAC,4BAAS,CAAC,MAAM,EAAE,mBAAmB,CAAC,IAAI,GAAG,CAAC;QAClE,SAAS,EAAI,4BAAS,CAAC,MAAM,EAAE,iBAAiB,CAAC;KACpD,CAAC;IAEF,sBAAsB,GAAG,eAAgB,CAAC,sBAAsB,EAAE,WAAW,CAAC,EAAE;QAC5E,OAAO,WAAW,KAAK,KAAK,CAAC,IAAI,WAAW,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IACtF,CAAC,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE,kBAAkB,EAAE,sBAAsB,CAAC,CAAC;AAClF,CAAC;AAGD,SAAS,YAAY,CAAE,YAAY;IAC/B,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,GAAG,8BAAW,CAAC,YAAY,CAAC,CAAC;IAC5D,MAAM,cAAc,GAAc,aAAa,CAAC,QAAQ,CAAC,CAAC;IAC1D,MAAM,EAAE,KAAK,EAAE,aAAa,EAAE,GAAI,UAAU,CAAC,WAAW,EAAE,cAAc,CAAC,CAAC;IAC1E,MAAM,oBAAoB,GAAQ,KAAK,CAAC,QAAQ,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC;IAC/E,MAAM,OAAO,GAAqB,YAAY,CAAC,aAAa,EAAE,oBAAoB,CAAC,CAAC;IAEpF,OAAO,MAAM,CAAC,MAAM,CAAC,EAAE,QAAQ,EAAE,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;AACvD,CAAC;AAED,mBAAyB,YAAY;IACjC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC;QAC1B,WAAW,CAAC,YAAY,CAAC,GAAG,YAAY,CAAC,YAAY,CAAC,CAAC;IAE3D,OAAO,WAAW,CAAC,YAAY,CAAC,CAAC;AACrC,CAAC;AALD,4BAKC","sourcesContent":["import { emulatedDevices } from 'device-specs';\nimport { pickBy as filterProperties, camelCase } from 'lodash';\nimport {\n    hasMatch, findMatch, isMatchTrue, getModes, splitEscaped, getPathFromParsedModes, parseConfig\n} from '../../../utils/argument-parsing';\n\n\nconst HEADLESS_DEFAULT_WIDTH  = 1280;\nconst HEADLESS_DEFAULT_HEIGHT = 800;\n\nconst AVAILABLE_MODES = ['userProfile', 'headless', 'emulation'];\n\nconst configCache = {};\n\nfunction parseUserArgs (userArgs) {\n    const parsedArgs = {\n        headless:    false,\n        userDataDir: false,\n        windowSize:  false\n    };\n\n    const splittedArgs = userArgs.split(' ').filter(arg => !!arg);\n\n    splittedArgs.forEach(arg => {\n        const keyValuePair = arg.split('=');\n        const key          = camelCase(keyValuePair[0]);\n\n        parsedArgs[key] = parsedArgs[key] !== void 0;\n    });\n\n    return parsedArgs;\n}\n\nfunction parseModes (modesStr, userArgs) {\n    const parsed        = splitEscaped(modesStr, ':');\n    const path          = getPathFromParsedModes(parsed, AVAILABLE_MODES);\n    const detectedModes = getModes(parsed, AVAILABLE_MODES);\n    let optionsString = '';\n\n    if (parsed.length)\n        optionsString = parsed.shift();\n\n    while (parsed.length)\n        optionsString += ':' + parsed.shift();\n\n    const userProfile = detectedModes.userProfile || userArgs.userDataDir;\n    const headless    = detectedModes.headless || userArgs.headless;\n    const emulation   = detectedModes.emulation || headless;\n\n    const modes = {\n        path,\n        userProfile,\n        headless,\n        emulation\n    };\n\n    return { modes, optionsString };\n}\n\nfunction simplifyDeviceName (deviceName) {\n    return deviceName.replace(/\\s/g, '').toLowerCase();\n}\n\nfunction findDevice (deviceName) {\n    const simpleName = simplifyDeviceName(deviceName);\n\n    return emulatedDevices.filter(device => simplifyDeviceName(device.title).indexOf(simpleName) >= 0)[0];\n}\n\nfunction getDeviceBasedOptions (deviceName, orientation) {\n    if (!deviceName)\n        return {};\n\n    const deviceData = findDevice(deviceName);\n\n    if (!deviceData)\n        return {};\n\n    const mobile = deviceData.capabilities.indexOf('mobile') >= 0;\n\n    if (!orientation)\n        orientation = mobile ? 'vertical' : 'horizontal';\n\n    return {\n        mobile:      mobile,\n        orientation: orientation,\n        touch:       deviceData.capabilities.indexOf('touch') >= 0,\n        width:       deviceData.screen[orientation].width,\n        height:      deviceData.screen[orientation].height,\n        scaleFactor: deviceData.screen['device-pixel-ratio'],\n        userAgent:   deviceData['user-agent'],\n    };\n}\n\nfunction parseOptions (str, useDefaultDimensions) {\n    const parsed = splitEscaped(str, ';');\n\n    const baseOptions = {\n        width:       useDefaultDimensions ? HEADLESS_DEFAULT_WIDTH : 0,\n        height:      useDefaultDimensions ? HEADLESS_DEFAULT_HEIGHT : 0,\n        scaleFactor: 0,\n        mobile:      false,\n        cdpPort:     findMatch(parsed, /^cdpPort=(.*)/)\n    };\n\n    const deviceName         = findMatch(parsed, /^device=(.*)/);\n    const orientation        = findMatch(parsed, /^orientation=(.*)/);\n    const deviceBasedOptions = getDeviceBasedOptions(deviceName, orientation);\n\n    let specifiedDeviceOptions = {\n        orientation: orientation,\n        touch:       hasMatch(parsed, /^touch=/) ? isMatchTrue(parsed, /^touch=(.*)/) : void 0,\n        mobile:      isMatchTrue(parsed, /^mobile=(.*)/),\n        width:       Number(findMatch(parsed, /^width=(.*)/) || NaN),\n        height:      Number(findMatch(parsed, /^height=(.*)/) || NaN),\n        scaleFactor: Number(findMatch(parsed, /^scaleFactor=(.*)/) || NaN),\n        userAgent:   findMatch(parsed, /^userAgent=(.*)/)\n    };\n\n    specifiedDeviceOptions = filterProperties(specifiedDeviceOptions, optionValue => {\n        return optionValue !== void 0 && optionValue !== '' && !Number.isNaN(optionValue);\n    });\n\n    return Object.assign(baseOptions, deviceBasedOptions, specifiedDeviceOptions);\n}\n\n\nfunction getNewConfig (configString) {\n    const { userArgs, modesString } = parseConfig(configString);\n    const parsedUserArgs            = parseUserArgs(userArgs);\n    const { modes, optionsString }  = parseModes(modesString, parsedUserArgs);\n    const useDefaultDimensions      = modes.headless && !parsedUserArgs.windowSize;\n    const options                   = parseOptions(optionsString, useDefaultDimensions);\n\n    return Object.assign({ userArgs }, modes, options);\n}\n\nexport default function (configString) {\n    if (!configCache[configString])\n        configCache[configString] = getNewConfig(configString);\n\n    return configCache[configString];\n}\n"]}