UNPKG

testcafe

Version:

Automated browser testing for the modern web development stack.

116 lines 18.1 kB
"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"]}