testcafe
Version:
Automated browser testing for the modern web development stack.
112 lines • 17.6 kB
JavaScript
;
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 = (0, lodash_1.camelCase)(keyValuePair[0]);
parsedArgs[key] = parsedArgs[key] !== void 0;
});
return parsedArgs;
}
function parseModes(modesStr, userArgs) {
const parsed = (0, argument_parsing_1.splitEscaped)(modesStr, ':');
const path = (0, argument_parsing_1.getPathFromParsedModes)(parsed, AVAILABLE_MODES);
const detectedModes = (0, 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 {
deviceName: deviceData.title,
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 = (0, argument_parsing_1.splitEscaped)(str, ';');
const baseOptions = {
width: useDefaultDimensions ? HEADLESS_DEFAULT_WIDTH : 0,
height: useDefaultDimensions ? HEADLESS_DEFAULT_HEIGHT : 0,
scaleFactor: 0,
mobile: false,
cdpPort: (0, argument_parsing_1.findMatch)(parsed, /^cdpPort=(.*)/),
};
const deviceName = (0, argument_parsing_1.findMatch)(parsed, /^device=(.*)/);
const orientation = (0, argument_parsing_1.findMatch)(parsed, /^orientation=(.*)/);
const deviceBasedOptions = getDeviceBasedOptions(deviceName, orientation);
let specifiedDeviceOptions = {
orientation: orientation,
touch: (0, argument_parsing_1.hasMatch)(parsed, /^touch=/) ? (0, argument_parsing_1.isMatchTrue)(parsed, /^touch=(.*)/) : void 0,
mobile: (0, argument_parsing_1.isMatchTrue)(parsed, /^mobile=(.*)/),
width: Number((0, argument_parsing_1.findMatch)(parsed, /^width=(.*)/) || NaN),
height: Number((0, argument_parsing_1.findMatch)(parsed, /^height=(.*)/) || NaN),
scaleFactor: Number((0, argument_parsing_1.findMatch)(parsed, /^scaleFactor=(.*)/) || NaN),
userAgent: (0, argument_parsing_1.findMatch)(parsed, /^userAgent=(.*)/),
};
specifiedDeviceOptions = (0, 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 } = (0, 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":"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","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        deviceName:  deviceData.title,\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"]}