2018-04-09 10:01:24 +02:00
|
|
|
exports.make_zblueslip = function (opts) {
|
|
|
|
|
2019-11-02 00:06:25 +01:00
|
|
|
const lib = {};
|
2018-04-09 10:01:24 +02:00
|
|
|
|
|
|
|
// Apply defaults
|
|
|
|
opts = Object.assign({
|
|
|
|
// 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,
|
|
|
|
fatal: true,
|
|
|
|
}, opts);
|
|
|
|
|
|
|
|
// Store valid test data for options.
|
|
|
|
lib.test_data = {};
|
|
|
|
lib.test_logs = {};
|
|
|
|
Object.keys(opts).forEach(name => {
|
|
|
|
lib.test_data[name] = [];
|
|
|
|
lib.test_logs[name] = [];
|
|
|
|
});
|
|
|
|
lib.set_test_data = (name, message) => {
|
|
|
|
lib.test_data[name].push(message);
|
|
|
|
};
|
|
|
|
lib.clear_test_data = (name) => {
|
|
|
|
if (!name) {
|
|
|
|
// Clear all data
|
|
|
|
Object.keys(opts).forEach(name => {
|
|
|
|
lib.test_data[name] = [];
|
|
|
|
lib.test_logs[name] = [];
|
|
|
|
});
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
lib.test_data[name] = [];
|
|
|
|
lib.test_logs[name] = [];
|
|
|
|
};
|
|
|
|
|
|
|
|
lib.get_test_logs = (name) => {
|
|
|
|
return lib.test_logs[name];
|
|
|
|
};
|
|
|
|
|
|
|
|
lib.check_error = (isblueslip = false) => {
|
|
|
|
return function (error) {
|
|
|
|
if (isblueslip) {
|
|
|
|
assert(error.blueslip, "Not a blueslip error.");
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
// If an error was thrown by zblueslip, we know that that
|
|
|
|
// error was not in the list of expeccted errors for the test.
|
|
|
|
assert(!error.blueslip, "Error not in expected errors.");
|
|
|
|
return true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
// Create logging functions
|
|
|
|
Object.keys(opts).forEach(name => {
|
|
|
|
if (!opts[name]) {
|
2018-04-24 00:29:46 +02:00
|
|
|
// should just log the message.
|
2018-07-10 09:28:25 +02:00
|
|
|
lib[name] = function (message, more_info, stack) {
|
|
|
|
lib.test_logs[name].push({message, more_info, stack});
|
2018-04-24 00:29:46 +02:00
|
|
|
};
|
2018-04-09 10:01:24 +02:00
|
|
|
return;
|
|
|
|
}
|
2018-07-10 09:28:25 +02:00
|
|
|
lib[name] = function (message, more_info, stack) {
|
|
|
|
lib.test_logs[name].push({message, more_info, stack});
|
2018-05-01 01:05:25 +02:00
|
|
|
const exact_match_fail = lib.test_data[name].indexOf(message) === -1;
|
|
|
|
const string_match_fail = lib.test_data[name].indexOf(message.toString()) === -1;
|
|
|
|
if (exact_match_fail && string_match_fail) {
|
2019-11-02 00:06:25 +01:00
|
|
|
const error = Error(`Invalid ${name} message: "${message}".`);
|
2018-04-09 10:01:24 +02:00
|
|
|
error.blueslip = true;
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
2018-07-09 20:06:32 +02:00
|
|
|
lib.exception_msg = function (ex) {
|
|
|
|
return ex.message;
|
|
|
|
};
|
|
|
|
|
2020-01-15 15:05:44 +01:00
|
|
|
lib.start_timing = () => {
|
|
|
|
return () => {};
|
|
|
|
};
|
|
|
|
|
2018-04-09 10:01:24 +02:00
|
|
|
return lib;
|
|
|
|
};
|