testcafe
Version:
Automated browser testing for the modern web development stack.
116 lines • 18.1 kB
JavaScript
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const lodash_1 = require("lodash");
const correct_file_path_1 = __importDefault(require("../utils/correct-file-path"));
const escape_user_agent_1 = __importDefault(require("../utils/escape-user-agent"));
const events_1 = __importDefault(require("events"));
const DATE_FORMAT = 'YYYY-MM-DD';
const TIME_FORMAT = 'HH-mm-ss';
const ERRORS_FOLDER = 'errors';
const PROBLEMATIC_PLACEHOLDER_VALUE = '';
const PLACEHOLDERS = {
DATE: '${DATE}',
TIME: '${TIME}',
TEST_INDEX: '${TEST_INDEX}',
FILE_INDEX: '${FILE_INDEX}',
QUARANTINE_ATTEMPT: '${QUARANTINE_ATTEMPT}',
FIXTURE: '${FIXTURE}',
TEST: '${TEST}',
USERAGENT: '${USERAGENT}',
BROWSER: '${BROWSER}',
BROWSER_VERSION: '${BROWSER_VERSION}',
OS: '${OS}',
OS_VERSION: '${OS_VERSION}',
TEST_ID: '${TEST_ID}',
RUN_ID: '${RUN_ID}'
};
const DEFAULT_PATH_PATTERN_FOR_REPORT = `${PLACEHOLDERS.DATE}_${PLACEHOLDERS.TIME}\\${PLACEHOLDERS.TEST_ID}\\` +
`${PLACEHOLDERS.RUN_ID}\\${PLACEHOLDERS.USERAGENT}\\${PLACEHOLDERS.FILE_INDEX}`;
const TEST_ID_TEMPLATE = data => data.testIndex ? `test-${data.testIndex}` : '';
const RUN_ID_TEMPLATE = data => data.quarantineAttempt ? `run-${data.quarantineAttempt}` : '';
class PathPattern extends events_1.default {
constructor(pattern, fileExtension, data) {
super();
this.pattern = this._ensurePattern(pattern);
this.data = this._addDefaultFields(data);
this.placeholderToDataMap = this._createPlaceholderToDataMap();
this.fileExtension = fileExtension;
}
_ensurePattern(pattern) {
if (pattern)
return pattern;
return DEFAULT_PATH_PATTERN_FOR_REPORT;
}
_addDefaultFields(data) {
const defaultFields = {
testId: TEST_ID_TEMPLATE(data),
runId: RUN_ID_TEMPLATE(data),
formattedDate: data.now.format(DATE_FORMAT),
formattedTime: data.now.format(TIME_FORMAT),
fileIndex: 1,
errorFileIndex: 1
};
return Object.assign({}, defaultFields, data);
}
_createPlaceholderToDataMap() {
return {
[PLACEHOLDERS.TEST_ID]: this.data.testId,
[PLACEHOLDERS.RUN_ID]: this.data.runId,
[PLACEHOLDERS.DATE]: this.data.formattedDate,
[PLACEHOLDERS.TIME]: this.data.formattedTime,
[PLACEHOLDERS.TEST_INDEX]: this.data.testIndex,
[PLACEHOLDERS.QUARANTINE_ATTEMPT]: this.data.quarantineAttempt || 1,
[PLACEHOLDERS.FIXTURE]: this.data.fixture,
[PLACEHOLDERS.TEST]: this.data.test,
[PLACEHOLDERS.FILE_INDEX]: forError => forError ? this.data.errorFileIndex : this.data.fileIndex,
[PLACEHOLDERS.USERAGENT]: this.data.parsedUserAgent.toString(),
[PLACEHOLDERS.BROWSER]: this.data.parsedUserAgent.family,
[PLACEHOLDERS.BROWSER_VERSION]: this.data.parsedUserAgent.toVersion(),
[PLACEHOLDERS.OS]: this.data.parsedUserAgent.os.family,
[PLACEHOLDERS.OS_VERSION]: this.data.parsedUserAgent.os.toVersion()
};
}
_buildPath(pattern, placeholderToDataMap, forError) {
let resultFilePath = pattern;
const problematicPlaceholders = [];
for (const placeholder in placeholderToDataMap) {
const findPlaceholderRegExp = new RegExp(lodash_1.escapeRegExp(placeholder), 'g');
resultFilePath = resultFilePath.replace(findPlaceholderRegExp, () => {
if (placeholder === PLACEHOLDERS.FILE_INDEX) {
const getFileIndexFn = placeholderToDataMap[placeholder];
let result = getFileIndexFn(forError);
if (forError)
result = `${ERRORS_FOLDER}\\${result}`;
return result;
}
else if (placeholder === PLACEHOLDERS.USERAGENT) {
const userAgent = placeholderToDataMap[placeholder];
return escape_user_agent_1.default(userAgent);
}
let calculatedValue = placeholderToDataMap[placeholder];
if (calculatedValue === null || calculatedValue === void 0) {
problematicPlaceholders.push(placeholder);
calculatedValue = PROBLEMATIC_PLACEHOLDER_VALUE;
}
return calculatedValue;
});
}
if (problematicPlaceholders.length)
this.emit('problematic-placeholders-found', { placeholders: problematicPlaceholders });
return resultFilePath;
}
getPath(forError) {
const path = this._buildPath(this.pattern, this.placeholderToDataMap, forError);
return correct_file_path_1.default(path, this.fileExtension);
}
// For testing purposes
static get PLACEHOLDERS() {
return PLACEHOLDERS;
}
}
exports.default = PathPattern;
module.exports = exports.default;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"path-pattern.js","sourceRoot":"","sources":["../../src/utils/path-pattern.js"],"names":[],"mappings":"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","sourcesContent":["import { escapeRegExp as escapeRe } from 'lodash';\nimport correctFilePath from '../utils/correct-file-path';\nimport escapeUserAgent from '../utils/escape-user-agent';\nimport EventEmitter from 'events';\n\nconst DATE_FORMAT = 'YYYY-MM-DD';\nconst TIME_FORMAT = 'HH-mm-ss';\n\nconst ERRORS_FOLDER = 'errors';\n\nconst PROBLEMATIC_PLACEHOLDER_VALUE = '';\n\nconst PLACEHOLDERS = {\n    DATE:               '${DATE}',\n    TIME:               '${TIME}',\n    TEST_INDEX:         '${TEST_INDEX}',\n    FILE_INDEX:         '${FILE_INDEX}',\n    QUARANTINE_ATTEMPT: '${QUARANTINE_ATTEMPT}',\n    FIXTURE:            '${FIXTURE}',\n    TEST:               '${TEST}',\n    USERAGENT:          '${USERAGENT}',\n    BROWSER:            '${BROWSER}',\n    BROWSER_VERSION:    '${BROWSER_VERSION}',\n    OS:                 '${OS}',\n    OS_VERSION:         '${OS_VERSION}',\n    TEST_ID:            '${TEST_ID}',\n    RUN_ID:             '${RUN_ID}'\n};\n\nconst DEFAULT_PATH_PATTERN_FOR_REPORT = `${PLACEHOLDERS.DATE}_${PLACEHOLDERS.TIME}\\\\${PLACEHOLDERS.TEST_ID}\\\\` +\n                                        `${PLACEHOLDERS.RUN_ID}\\\\${PLACEHOLDERS.USERAGENT}\\\\${PLACEHOLDERS.FILE_INDEX}`;\n\nconst TEST_ID_TEMPLATE = data => data.testIndex ? `test-${data.testIndex}` : '';\nconst RUN_ID_TEMPLATE  = data => data.quarantineAttempt ? `run-${data.quarantineAttempt}` : '';\n\nexport default class PathPattern extends EventEmitter {\n    constructor (pattern, fileExtension, data) {\n        super();\n\n        this.pattern              = this._ensurePattern(pattern);\n        this.data                 = this._addDefaultFields(data);\n        this.placeholderToDataMap = this._createPlaceholderToDataMap();\n        this.fileExtension        = fileExtension;\n    }\n\n    _ensurePattern (pattern) {\n        if (pattern)\n            return pattern;\n\n        return DEFAULT_PATH_PATTERN_FOR_REPORT;\n    }\n\n    _addDefaultFields (data) {\n        const defaultFields = {\n            testId:         TEST_ID_TEMPLATE(data),\n            runId:          RUN_ID_TEMPLATE(data),\n            formattedDate:  data.now.format(DATE_FORMAT),\n            formattedTime:  data.now.format(TIME_FORMAT),\n            fileIndex:      1,\n            errorFileIndex: 1\n        };\n\n        return Object.assign({}, defaultFields, data);\n    }\n\n    _createPlaceholderToDataMap () {\n        return {\n            [PLACEHOLDERS.TEST_ID]:            this.data.testId,\n            [PLACEHOLDERS.RUN_ID]:             this.data.runId,\n            [PLACEHOLDERS.DATE]:               this.data.formattedDate,\n            [PLACEHOLDERS.TIME]:               this.data.formattedTime,\n            [PLACEHOLDERS.TEST_INDEX]:         this.data.testIndex,\n            [PLACEHOLDERS.QUARANTINE_ATTEMPT]: this.data.quarantineAttempt || 1,\n            [PLACEHOLDERS.FIXTURE]:            this.data.fixture,\n            [PLACEHOLDERS.TEST]:               this.data.test,\n            [PLACEHOLDERS.FILE_INDEX]:         forError => forError ? this.data.errorFileIndex : this.data.fileIndex,\n            [PLACEHOLDERS.USERAGENT]:          this.data.parsedUserAgent.toString(),\n            [PLACEHOLDERS.BROWSER]:            this.data.parsedUserAgent.family,\n            [PLACEHOLDERS.BROWSER_VERSION]:    this.data.parsedUserAgent.toVersion(),\n            [PLACEHOLDERS.OS]:                 this.data.parsedUserAgent.os.family,\n            [PLACEHOLDERS.OS_VERSION]:         this.data.parsedUserAgent.os.toVersion()\n        };\n    }\n\n    _buildPath (pattern, placeholderToDataMap, forError) {\n        let resultFilePath            = pattern;\n        const problematicPlaceholders = [];\n\n        for (const placeholder in placeholderToDataMap) {\n            const findPlaceholderRegExp = new RegExp(escapeRe(placeholder), 'g');\n\n            resultFilePath = resultFilePath.replace(findPlaceholderRegExp, () => {\n                if (placeholder === PLACEHOLDERS.FILE_INDEX) {\n                    const getFileIndexFn = placeholderToDataMap[placeholder];\n                    let result           = getFileIndexFn(forError);\n\n                    if (forError)\n                        result = `${ERRORS_FOLDER}\\\\${result}`;\n\n                    return result;\n                }\n\n                else if (placeholder === PLACEHOLDERS.USERAGENT) {\n                    const userAgent = placeholderToDataMap[placeholder];\n\n                    return escapeUserAgent(userAgent);\n                }\n\n                let calculatedValue = placeholderToDataMap[placeholder];\n\n                if (calculatedValue === null || calculatedValue === void 0) {\n                    problematicPlaceholders.push(placeholder);\n\n                    calculatedValue = PROBLEMATIC_PLACEHOLDER_VALUE;\n                }\n\n                return calculatedValue;\n            });\n        }\n\n        if (problematicPlaceholders.length)\n            this.emit('problematic-placeholders-found', { placeholders: problematicPlaceholders });\n\n        return resultFilePath;\n    }\n\n    getPath (forError) {\n        const path = this._buildPath(this.pattern, this.placeholderToDataMap, forError);\n\n        return correctFilePath(path, this.fileExtension);\n    }\n\n    // For testing purposes\n    static get PLACEHOLDERS () {\n        return PLACEHOLDERS;\n    }\n}\n"]}