Update tests

This commit is contained in:
Nachtalb 2021-05-23 00:55:47 +02:00
parent ef651e3e46
commit 1fd1df29da
No known key found for this signature in database
GPG key ID: E48DF13C07055D92
2 changed files with 50 additions and 76 deletions

View file

@ -54,12 +54,11 @@ describe("SQLite Message Storage", function () {
}); });
it("should create tables", function (done) { it("should create tables", function (done) {
store.database.serialize(() => const rows = store.database
store.database.all( .prepare("SELECT name, tbl_name, sql FROM sqlite_master WHERE type = 'table'")
"SELECT name, tbl_name, sql FROM sqlite_master WHERE type = 'table'", .all();
(err, row) => {
expect(err).to.be.null; expect(rows).to.deep.equal([
expect(row).to.deep.equal([
{ {
name: "options", name: "options",
tbl_name: "options", tbl_name: "options",
@ -75,37 +74,20 @@ 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(() => const row = store.database
store.database.get( .prepare("SELECT value FROM options WHERE name = 'schema_version'")
"SELECT value FROM options WHERE name = 'schema_version'", .get();
(err, row) => {
expect(err).to.be.null;
// Should be sqlite.currentSchemaVersion,
// compared as string because it's returned as such from the database
expect(row.value).to.equal("1520239200"); expect(row.value).to.equal("1520239200");
done(); done();
}
)
);
}); });
it("should store a message", function (done) { it("should store a message", function (done) {
store.database.serialize(() => {
store.index( store.index(
{ {uuid: "this-is-a-network-guid"},
uuid: "this-is-a-network-guid", {name: "#thisISaCHANNEL"},
},
{
name: "#thisISaCHANNEL",
},
new Msg({ new Msg({
time: 123456789, time: 123456789,
text: "Hello from sqlite world!", text: "Hello from sqlite world!",
@ -114,19 +96,10 @@ describe("SQLite Message Storage", function () {
done(); done();
}); });
});
it("should retrieve previously stored message", function (done) { it("should retrieve previously stored message", function (done) {
store.database.serialize(() =>
store store
.getMessages( .getMessages({uuid: "this-is-a-network-guid"}, {name: "#thisisaCHANNEL"})
{
uuid: "this-is-a-network-guid",
},
{
name: "#thisisaCHANNEL",
}
)
.then((messages) => { .then((messages) => {
expect(messages).to.have.lengthOf(1); expect(messages).to.have.lengthOf(1);
@ -137,13 +110,12 @@ describe("SQLite Message Storage", function () {
expect(msg.time.getTime()).to.equal(123456789); expect(msg.time.getTime()).to.equal(123456789);
done(); done();
}) });
);
}); });
it("should close database", function (done) { it("should close database", function (done) {
store.close((err) => { store.close((err) => {
expect(err).to.be.null; expect(err).to.be.undefined;
expect(fs.existsSync(expectedPath)).to.be.true; expect(fs.existsSync(expectedPath)).to.be.true;
done(); done();
}); });

View file

@ -4,9 +4,11 @@ const expect = require("chai").expect;
const TextFileMessageStorage = require("../../src/plugins/messageStorage/text"); const TextFileMessageStorage = require("../../src/plugins/messageStorage/text");
describe("TextFileMessageStorage", function () { describe("TextFileMessageStorage", function () {
const store = new TextFileMessageStorage();
it("should combine network name and uuid into a safe name", function () { it("should combine network name and uuid into a safe name", function () {
expect( expect(
TextFileMessageStorage.getNetworkFolderName({ store._getNetworkFolderName({
name: "Freenode", name: "Freenode",
uuid: "f9042ec9-4016-45e0-a8a8-d378fb252628", uuid: "f9042ec9-4016-45e0-a8a8-d378fb252628",
}) })
@ -15,7 +17,7 @@ describe("TextFileMessageStorage", function () {
it("network name should be cleaned up and lowercased", function () { it("network name should be cleaned up and lowercased", function () {
expect( expect(
TextFileMessageStorage.getNetworkFolderName({ store._getNetworkFolderName({
name: '@ TeSt ../..\\<>:"/\\|?*', name: '@ TeSt ../..\\<>:"/\\|?*',
uuid: "f9042ec9-4016-45e0-a8a8-d378fb252628", uuid: "f9042ec9-4016-45e0-a8a8-d378fb252628",
}) })
@ -24,7 +26,7 @@ describe("TextFileMessageStorage", function () {
it("folder name may contain two dashes if on boundary", function () { it("folder name may contain two dashes if on boundary", function () {
expect( expect(
TextFileMessageStorage.getNetworkFolderName({ store._getNetworkFolderName({
name: "Freenod", name: "Freenod",
uuid: "f9042ec9-4016-45e0-a8a8-d378fb252628", uuid: "f9042ec9-4016-45e0-a8a8-d378fb252628",
}) })
@ -33,7 +35,7 @@ describe("TextFileMessageStorage", function () {
it("should limit network name length", function () { it("should limit network name length", function () {
expect( expect(
TextFileMessageStorage.getNetworkFolderName({ store._getNetworkFolderName({
name: "This network name is longer than the uuid itself but it should be limited", name: "This network name is longer than the uuid itself but it should be limited",
uuid: "f9042ec9-4016-45e0-a8a8-d378fb252628", uuid: "f9042ec9-4016-45e0-a8a8-d378fb252628",
}) })