Small cleanup of messageStorage/sqlite.

* Extend test coverage to the `search` function.
* Test sort order of messages from `getMessages` and `search`
* Move reversal of `search` results from Vue to messageStorage.
* Remove unnecessary uses of `sqlite.serialize` in tests.
* Return promises from test functions where possible.
This commit is contained in:
itsjohncs 2021-10-28 00:48:11 -07:00
parent 97f3800785
commit 044cd2403b
3 changed files with 110 additions and 68 deletions

View File

@ -124,7 +124,7 @@ export default {
return []; return [];
} }
return this.search.results.slice().reverse(); return this.search.results;
}, },
chan() { chan() {
const chanId = parseInt(this.$route.params.id, 10); const chanId = parseInt(this.$route.params.id, 10);

View File

@ -236,7 +236,7 @@ class MessageStorage {
target: query.channelName, target: query.channelName,
networkUuid: query.networkUuid, networkUuid: query.networkUuid,
offset: query.offset, offset: query.offset,
results: parseSearchRowsToMessages(query.offset, rows), results: parseSearchRowsToMessages(query.offset, rows).reverse(),
}; };
resolve(response); resolve(response);
} }

View File

@ -37,10 +37,9 @@ describe("SQLite Message Storage", function () {
fs.rmdir(path.join(Helper.getHomePath(), "logs"), done); fs.rmdir(path.join(Helper.getHomePath(), "logs"), done);
}); });
it("should resolve an empty array when disabled", function (done) { it("should resolve an empty array when disabled", function () {
store.getMessages(null, null).then((messages) => { return store.getMessages(null, null).then((messages) => {
expect(messages).to.be.empty; expect(messages).to.be.empty;
done();
}); });
}); });
@ -54,7 +53,6 @@ describe("SQLite Message Storage", function () {
}); });
it("should create tables", function (done) { it("should create tables", function (done) {
store.database.serialize(() =>
store.database.all( store.database.all(
"SELECT name, tbl_name, sql FROM sqlite_master WHERE type = 'table'", "SELECT name, tbl_name, sql FROM sqlite_master WHERE type = 'table'",
(err, row) => { (err, row) => {
@ -76,12 +74,10 @@ describe("SQLite Message Storage", function () {
done(); done();
} }
)
); );
}); });
it("should insert schema version to options table", function (done) { it("should insert schema version to options table", function (done) {
store.database.serialize(() =>
store.database.get( store.database.get(
"SELECT value FROM options WHERE name = 'schema_version'", "SELECT value FROM options WHERE name = 'schema_version'",
(err, row) => { (err, row) => {
@ -93,12 +89,10 @@ describe("SQLite Message Storage", function () {
done(); done();
} }
)
); );
}); });
it("should store a message", function (done) { it("should store a message", function () {
store.database.serialize(() => {
store.index( store.index(
{ {
uuid: "this-is-a-network-guid", uuid: "this-is-a-network-guid",
@ -111,14 +105,10 @@ describe("SQLite Message Storage", function () {
text: "Hello from sqlite world!", text: "Hello from sqlite world!",
}) })
); );
done();
});
}); });
it("should retrieve previously stored message", function (done) { it("should retrieve previously stored message", function () {
store.database.serialize(() => return store
store
.getMessages( .getMessages(
{ {
uuid: "this-is-a-network-guid", uuid: "this-is-a-network-guid",
@ -135,10 +125,62 @@ describe("SQLite Message Storage", function () {
expect(msg.text).to.equal("Hello from sqlite world!"); expect(msg.text).to.equal("Hello from sqlite world!");
expect(msg.type).to.equal(Msg.Type.MESSAGE); expect(msg.type).to.equal(Msg.Type.MESSAGE);
expect(msg.time.getTime()).to.equal(123456789); expect(msg.time.getTime()).to.equal(123456789);
});
});
done(); it("should retrieve latest LIMIT messages in order", function () {
const originalMaxHistory = Helper.config.maxHistory;
try {
Helper.config.maxHistory = 2;
for (let i = 0; i < 200; ++i) {
store.index(
{uuid: "retrieval-order-test-network"},
{name: "#channel"},
new Msg({
time: 123456789 + i,
text: `msg ${i}`,
}) })
); );
}
return store
.getMessages({uuid: "retrieval-order-test-network"}, {name: "#channel"})
.then((messages) => {
expect(messages).to.have.lengthOf(2);
expect(messages.map((i) => i.text)).to.deep.equal(["msg 198", "msg 199"]);
});
} finally {
Helper.config.maxHistory = originalMaxHistory;
}
});
it("should search messages", function () {
const originalMaxHistory = Helper.config.maxHistory;
try {
Helper.config.maxHistory = 2;
return store
.search({
searchTerm: "msg",
networkUuid: "retrieval-order-test-network",
})
.then((messages) => {
expect(messages.results).to.have.lengthOf(100);
const expectedMessages = [];
for (let i = 100; i < 200; ++i) {
expectedMessages.push(`msg ${i}`);
}
expect(messages.results.map((i) => i.text)).to.deep.equal(expectedMessages);
});
} finally {
Helper.config.maxHistory = originalMaxHistory;
}
}); });
it("should close database", function (done) { it("should close database", function (done) {