thelounge/test/tests/customhighlights.ts
Val Lorentz a049a01aeb Client: move socket connection out of the constructor
It will make it easier to write tests for what used to be in
the connect() method
2023-03-15 08:40:53 +01:00

150 lines
3.1 KiB
TypeScript

import {expect} from "chai";
import log from "../../server/log";
import Client from "../../server/client";
import TestUtil from "../util";
import sinon from "ts-sinon";
describe("Custom highlights", function () {
let userLoadedLog = "";
const logInfoStub = sinon.stub(log, "info");
logInfoStub.callsFake(TestUtil.sanitizeLog((str) => (userLoadedLog += str)));
const client = new Client(
{
clients: [],
getDataToSave() {
return {
newUser: "",
newHash: "",
};
},
} as any,
"test",
{
clientSettings: {
highlights: "foo, @all, sp ace , 고",
highlightExceptions: "foo bar, bar @all, test sp ace test",
},
} as any
);
client.connect();
logInfoStub.restore();
expect(userLoadedLog).to.equal("User test loaded\n");
it("should NOT highlight", function () {
const teststrings = [
"and foos stuff",
"test foobar",
"testfoo bar",
"fooö",
"wtf@all",
"foo고",
"test고",
"space",
"sp:ace",
];
for (const teststring of teststrings) {
expect(teststring).to.not.match(client.highlightRegex!);
}
});
it("should highlight", function () {
const teststrings = [
"Hey foo hello",
"hey Foo: hi",
"hey Foo, hi",
"<foo> testing",
"foo",
"hey @all test",
"testing foo's stuff",
'"foo"',
'"@all"',
"foo!",
"www.foo.bar",
"www.bar.foo/page",
"고",
"test 고",
"고!",
"www.고.com",
"hey @Foo",
"hey ~Foo",
"hey +Foo",
"hello &foo",
"@all",
"@all wtf",
"wtf @all",
"@@all",
"@고",
"f00 sp ace: bar",
];
for (const teststring of teststrings) {
expect(teststring).to.match(client.highlightRegex!);
}
});
it("should trim custom highlights in the compiled regex", function () {
expect(client.highlightRegex).to.match(/\(\?:foo\|@all\|sp ace\|고\)/);
});
it("should NOT compile a regex", function () {
// test updating the regex and invalid custom hl inputs
client.config.clientSettings.highlights = ",,";
client.compileCustomHighlights();
expect(client.highlightRegex).to.be.null;
client.config.clientSettings.highlights = " ";
client.compileCustomHighlights();
expect(client.highlightRegex).to.be.null;
});
// tests for highlight exceptions
it("should NOT highlight due to highlight exceptions", function () {
const teststrings = [
"foo bar baz",
"test foo bar",
"foo bar @all test",
"with a test sp ace test",
];
for (const teststring of teststrings) {
expect(teststring).to.match(client.highlightExceptionRegex!);
}
});
it("should highlight regardless of highlight exceptions", function () {
const teststrings = [
"Hey foo hello",
"hey Foo: hi",
"hey Foo, hi",
"<foo> testing",
"foo",
"hey @all test",
"testing foo's stuff",
'"foo"',
'"@all"',
"foo!",
"www.foo.bar",
"www.bar.foo/page",
"고",
"test 고",
"고!",
"www.고.com",
"hey @Foo",
"hey ~Foo",
"hey +Foo",
"hello &foo",
"@all",
"@all wtf",
"wtfbar @all",
"@@all",
"@고",
"f00 sp ace: bar",
];
for (const teststring of teststrings) {
expect(teststring).to.not.match(client.highlightExceptionRegex!);
}
});
});