testcafe
Version:
Automated browser testing for the modern web development stack.
73 lines • 11.1 kB
JavaScript
;
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.RawCommandCallsiteRecord = exports.renderers = exports.HtmlRender = exports.NoColorRender = exports.Render = void 0;
const chalk_1 = __importDefault(require("chalk"));
const lodash_1 = require("lodash");
class Render {
static getCommandStr(command) {
const { type, assertionType, selector, actual, expected, } = command;
const mainStr = `${(0, lodash_1.upperFirst)((0, lodash_1.camelCase)(type))} (${(assertionType ? actual === null || actual === void 0 ? void 0 : actual.value : selector === null || selector === void 0 ? void 0 : selector.value) || ''})`;
const subStr = assertionType ? ` ${assertionType} (${(expected === null || expected === void 0 ? void 0 : expected.value) || ''})` : '';
return `${mainStr}${subStr}`;
}
static codeFrame(str) {
return str;
}
static commandLine(num, command, base) {
let commandNum = `${base ? ' > ' : ' '}${num} `;
if (base)
commandNum = chalk_1.default.bgRed(commandNum);
return `${commandNum}|${Render.getCommandStr(command)}\n`;
}
}
exports.Render = Render;
class NoColorRender extends Render {
static commandLine(num, command, base) {
const commandNum = `${base ? ' > ' : ' '}${num} `;
return `${commandNum}|${Render.getCommandStr(command)}\n`;
}
}
exports.NoColorRender = NoColorRender;
class HtmlRender extends Render {
static codeFrame(str) {
return '<div class="code-frame">' + str + '</div>';
}
static commandLine(num, command, base) {
const numClass = base ? 'code-line-num-base' : 'code-line-num';
return `<div class="code-line">` +
`<div class="${numClass}">${num}</div>` +
`<div class="code-line-src">${Render.getCommandStr(command)}</div>` +
`</div>`;
}
}
exports.HtmlRender = HtmlRender;
exports.renderers = {
default: Render,
html: HtmlRender,
noColor: NoColorRender,
};
class RawCommandCallsiteRecord {
constructor(actionId, list) {
this.actionId = actionId;
this._list = list;
}
renderSync(opts) {
const { renderer = Render, frameSize = 1, codeFrame = true, } = opts;
if (!codeFrame)
return '';
const baseId = this._list.findIndex(item => item.actionId === this.actionId);
if (baseId < 0)
return '';
const firstId = Math.max(baseId - frameSize, 0);
const lastId = Math.min(baseId + frameSize, this._list.length - 1);
let frame = '';
for (let i = firstId; i <= lastId; i++)
frame += renderer.commandLine(i + 1, this._list[i], i === baseId);
return renderer.codeFrame(frame);
}
}
exports.RawCommandCallsiteRecord = RawCommandCallsiteRecord;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"raw-command-callsite-record.js","sourceRoot":"","sources":["../../src/utils/raw-command-callsite-record.ts"],"names":[],"mappings":"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","sourcesContent":["import chalk from 'chalk';\nimport { camelCase, upperFirst } from 'lodash';\n\ninterface Command {\n    id: number;\n    selector?: {\n        type: string;\n        value: string;\n    };\n    actual?: {\n        type: string;\n        value: string;\n    };\n    expected?: {\n        type: string;\n        value: string;\n    };\n    type: string;\n    assertionType?: string;\n    [key: string]: unknown;\n}\n\nexport class Render {\n    public static getCommandStr (command: Command): string {\n        const {\n            type,\n            assertionType,\n            selector,\n            actual,\n            expected,\n        } = command;\n\n        const mainStr = `${upperFirst(camelCase(type))} (${(assertionType ? actual?.value : selector?.value) || ''})`;\n        const subStr  = assertionType ? ` ${assertionType} (${expected?.value || ''})` : '';\n\n        return `${mainStr}${subStr}`;\n    }\n    public static codeFrame (str: string): string {\n        return str;\n    }\n    public static commandLine (num: number, command: Command, base: boolean): string {\n        let commandNum = `${base ? ' > ' : '   '}${num} `;\n\n        if (base)\n            commandNum = chalk.bgRed(commandNum);\n\n        return `${commandNum}|${Render.getCommandStr(command)}\\n`;\n    }\n}\n\nexport class NoColorRender extends Render {\n    public static commandLine (num: number, command: Command, base: boolean): string {\n        const commandNum = `${base ? ' > ' : '   '}${num} `;\n\n        return `${commandNum}|${Render.getCommandStr(command)}\\n`;\n    }\n}\n\nexport class HtmlRender extends Render {\n    public static codeFrame (str: string): string {\n        return '<div class=\"code-frame\">' + str + '</div>';\n    }\n\n    public static commandLine (num: number, command: Command, base: boolean): string {\n        const numClass  = base ? 'code-line-num-base' : 'code-line-num';\n\n        return `<div class=\"code-line\">` +\n            `<div class=\"${numClass}\">${num}</div>` +\n            `<div class=\"code-line-src\">${Render.getCommandStr(command)}</div>` +\n            `</div>`;\n    }\n}\n\ninterface RenderOptions {\n    renderer?: typeof Render;\n    frameSize?: number;\n    codeFrame?: boolean;\n}\n\nexport const renderers = {\n    default: Render,\n    html:    HtmlRender,\n    noColor: NoColorRender,\n};\n\nexport class RawCommandCallsiteRecord {\n    public readonly actionId: string;\n    private readonly _list: Command[];\n\n    public constructor (actionId: string, list: Command[]) {\n        this.actionId = actionId;\n        this._list    = list;\n    }\n\n    public renderSync (opts: RenderOptions): string {\n        const {\n            renderer = Render,\n            frameSize = 1,\n            codeFrame = true,\n        } = opts;\n\n        if (!codeFrame)\n            return '';\n\n        const baseId = this._list.findIndex(item => item.actionId === this.actionId);\n\n        if (baseId < 0)\n            return '';\n\n        const firstId = Math.max(baseId - frameSize, 0);\n        const lastId  = Math.min(baseId + frameSize, this._list.length - 1);\n        let frame     = '';\n\n        for (let i = firstId; i <= lastId; i++)\n            frame += renderer.commandLine(i + 1, this._list[i], i === baseId);\n\n        return renderer.codeFrame(frame);\n    }\n}\n"]}