zulip/frontend_tests/zjsunit/zblueslip.js

103 lines
2.9 KiB
JavaScript
Raw Normal View History

exports.make_zblueslip = function () {
const lib = {};
const opts = {
// Silently swallow all debug, log and info calls.
debug: false,
log: false,
info: false,
// Check against expected error values for the following.
warn: true,
error: true,
};
const names = Array.from(Object.keys(opts));
// For fatal messages, we should use assert.throws
lib.fatal = (msg) => {
throw Error(msg);
};
// Store valid test data for options.
lib.test_data = {};
lib.test_logs = {};
lib.seen_messages = {};
for (const name of names) {
lib.test_data[name] = [];
lib.test_logs[name] = [];
lib.seen_messages[name] = new Set();
}
lib.expect = (name, message) => {
if (opts[name] === undefined) {
throw Error('unexpected arg for expect: ' + name);
}
lib.test_data[name].push(message);
};
lib.check_seen_messages = () => {
for (const name of names) {
for (const message of lib.test_data[name]) {
if (!lib.seen_messages[name].has(message)) {
throw Error('Never saw: ' + message);
}
}
}
};
lib.reset = () => {
lib.check_seen_messages();
for (const name of names) {
lib.test_data[name] = [];
lib.test_logs[name] = [];
lib.seen_messages[name].clear();
}
};
lib.get_test_logs = (name) => {
return lib.test_logs[name];
};
// Create logging functions
for (const name of names) {
if (!opts[name]) {
// should just log the message.
lib[name] = function (message, more_info, stack) {
lib.seen_messages[name].add(message);
lib.test_logs[name].push({message, more_info, stack});
};
continue;
}
lib[name] = function (message, more_info, stack) {
if (typeof message !== 'string') {
// We may catch exceptions in blueslip, and if
// so our stub should include that.
if (message.toString().includes('exception')) {
message = message.toString();
} else {
throw Error('message should be string: ' + message);
}
}
lib.seen_messages[name].add(message);
lib.test_logs[name].push({message, more_info, stack});
js: Convert a.indexOf(…) !== -1 to a.includes(…). Babel polyfills this for us for Internet Explorer. import * as babelParser from "recast/parsers/babel"; import * as recast from "recast"; import * as tsParser from "recast/parsers/typescript"; import { builders as b, namedTypes as n } from "ast-types"; import K from "ast-types/gen/kinds"; import fs from "fs"; import path from "path"; import process from "process"; const checkExpression = (node: n.Node): node is K.ExpressionKind => n.Expression.check(node); for (const file of process.argv.slice(2)) { console.log("Parsing", file); const ast = recast.parse(fs.readFileSync(file, { encoding: "utf8" }), { parser: path.extname(file) === ".ts" ? tsParser : babelParser, }); let changed = false; recast.visit(ast, { visitBinaryExpression(path) { const { operator, left, right } = path.node; if ( n.CallExpression.check(left) && n.MemberExpression.check(left.callee) && !left.callee.computed && n.Identifier.check(left.callee.property) && left.callee.property.name === "indexOf" && left.arguments.length === 1 && checkExpression(left.arguments[0]) && ((["===", "!==", "==", "!=", ">", "<="].includes(operator) && n.UnaryExpression.check(right) && right.operator == "-" && n.Literal.check(right.argument) && right.argument.value === 1) || ([">=", "<"].includes(operator) && n.Literal.check(right) && right.value === 0)) ) { const test = b.callExpression( b.memberExpression(left.callee.object, b.identifier("includes")), [left.arguments[0]] ); path.replace( ["!==", "!=", ">", ">="].includes(operator) ? test : b.unaryExpression("!", test) ); changed = true; } this.traverse(path); }, }); if (changed) { console.log("Writing", file); fs.writeFileSync(file, recast.print(ast).code, { encoding: "utf8" }); } } Signed-off-by: Anders Kaseorg <anders@zulipchat.com>
2020-02-08 04:55:06 +01:00
const exact_match_fail = !lib.test_data[name].includes(message);
if (exact_match_fail) {
const error = Error(`Invalid ${name} message: "${message}".`);
error.blueslip = true;
throw error;
}
};
}
lib.exception_msg = function (ex) {
return ex.message;
};
lib.start_timing = () => {
return () => {};
};
return lib;
};