2021-05-21 15:17:21 +02:00
|
|
|
const { revisionService, setupDatabaseAndSynchronizer, db, switchClient } = require('../testing/test-utils.js');
|
|
|
|
const SearchEngine = require('../services/searchengine/SearchEngine').default;
|
|
|
|
const ResourceService = require('../services/ResourceService').default;
|
|
|
|
const ItemChangeUtils = require('../services/ItemChangeUtils').default;
|
|
|
|
const Note = require('../models/Note').default;
|
|
|
|
const ItemChange = require('../models/ItemChange').default;
|
2019-01-14 19:11:54 +00:00
|
|
|
|
|
|
|
let searchEngine = null;
|
|
|
|
|
|
|
|
describe('models_ItemChange', function() {
|
|
|
|
|
|
|
|
beforeEach(async (done) => {
|
|
|
|
await setupDatabaseAndSynchronizer(1);
|
2019-11-12 16:16:39 +00:00
|
|
|
await switchClient(1);
|
2019-01-14 19:11:54 +00:00
|
|
|
searchEngine = new SearchEngine();
|
|
|
|
searchEngine.setDb(db());
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
2020-12-01 18:05:24 +00:00
|
|
|
it('should delete old changes that have been processed', (async () => {
|
2021-05-21 15:17:21 +02:00
|
|
|
await Note.save({ title: 'abcd efgh' });
|
2019-01-14 19:11:54 +00:00
|
|
|
|
|
|
|
await ItemChange.waitForAllSaved();
|
|
|
|
|
|
|
|
expect(await ItemChange.lastChangeId()).toBe(1);
|
|
|
|
|
|
|
|
const resourceService = new ResourceService();
|
|
|
|
|
|
|
|
await searchEngine.syncTables();
|
|
|
|
// If we run this now, it should not delete any change because
|
|
|
|
// the resource service has not yet processed the change
|
|
|
|
await ItemChangeUtils.deleteProcessedChanges();
|
|
|
|
expect(await ItemChange.lastChangeId()).toBe(1);
|
|
|
|
|
|
|
|
await resourceService.indexNoteResources();
|
|
|
|
await ItemChangeUtils.deleteProcessedChanges();
|
2019-05-06 21:35:29 +01:00
|
|
|
expect(await ItemChange.lastChangeId()).toBe(1);
|
2019-01-14 19:11:54 +00:00
|
|
|
|
2019-05-06 21:35:29 +01:00
|
|
|
await revisionService().collectRevisions();
|
|
|
|
await ItemChangeUtils.deleteProcessedChanges();
|
2019-01-14 19:11:54 +00:00
|
|
|
expect(await ItemChange.lastChangeId()).toBe(0);
|
|
|
|
}));
|
|
|
|
|
2019-07-30 09:35:42 +02:00
|
|
|
});
|