2020-02-06 03:04:43 +00:00
|
|
|
const db = require('../../src/persistence/sqlite');
|
|
|
|
const fs = require('fs');
|
2021-05-08 05:20:38 +00:00
|
|
|
const location = process.env.SQLITE_DB_LOCATION || '/etc/todos/todo.db';
|
2020-02-06 03:04:43 +00:00
|
|
|
|
|
|
|
const ITEM = {
|
|
|
|
id: '7aef3d7c-d301-4846-8358-2a91ec9d6be3',
|
|
|
|
name: 'Test',
|
|
|
|
completed: false,
|
|
|
|
};
|
|
|
|
|
|
|
|
beforeEach(() => {
|
2021-05-08 05:20:38 +00:00
|
|
|
if (fs.existsSync(location)) {
|
|
|
|
fs.unlinkSync(location);
|
2020-02-06 03:04:43 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
test('it initializes correctly', async () => {
|
|
|
|
await db.init();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('it can store and retrieve items', async () => {
|
|
|
|
await db.init();
|
|
|
|
|
|
|
|
await db.storeItem(ITEM);
|
|
|
|
|
|
|
|
const items = await db.getItems();
|
|
|
|
expect(items.length).toBe(1);
|
|
|
|
expect(items[0]).toEqual(ITEM);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('it can update an existing item', async () => {
|
|
|
|
await db.init();
|
|
|
|
|
|
|
|
const initialItems = await db.getItems();
|
|
|
|
expect(initialItems.length).toBe(0);
|
|
|
|
|
|
|
|
await db.storeItem(ITEM);
|
|
|
|
|
|
|
|
await db.updateItem(
|
|
|
|
ITEM.id,
|
|
|
|
Object.assign({}, ITEM, { completed: !ITEM.completed }),
|
|
|
|
);
|
|
|
|
|
|
|
|
const items = await db.getItems();
|
|
|
|
expect(items.length).toBe(1);
|
|
|
|
expect(items[0].completed).toBe(!ITEM.completed);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('it can remove an existing item', async () => {
|
|
|
|
await db.init();
|
|
|
|
await db.storeItem(ITEM);
|
|
|
|
|
|
|
|
await db.removeItem(ITEM.id);
|
|
|
|
|
|
|
|
const items = await db.getItems();
|
|
|
|
expect(items.length).toBe(0);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('it can get a single item', async () => {
|
|
|
|
await db.init();
|
|
|
|
await db.storeItem(ITEM);
|
|
|
|
|
|
|
|
const item = await db.getItem(ITEM.id);
|
|
|
|
expect(item).toEqual(ITEM);
|
|
|
|
});
|