archives: use separate table
Cleaner to separate things from the backups table. * icon, appConfig, appStoreIcon etc are only valid for archives * older version cloudron does not have appConfig in backups table (so it cannot be an archive entry)
This commit is contained in:
@@ -6,7 +6,8 @@
|
||||
|
||||
'use strict';
|
||||
|
||||
const backupCleaner = require('../backupcleaner.js'),
|
||||
const archives = require('../archives.js'),
|
||||
backupCleaner = require('../backupcleaner.js'),
|
||||
backups = require('../backups.js'),
|
||||
common = require('./common.js'),
|
||||
expect = require('expect.js'),
|
||||
@@ -33,7 +34,6 @@ describe('backup cleaner', function () {
|
||||
manifest: null,
|
||||
format: 'tgz',
|
||||
preserveSecs: 0,
|
||||
archive: false
|
||||
};
|
||||
|
||||
describe('retention', function () {
|
||||
@@ -123,12 +123,6 @@ describe('backup cleaner', function () {
|
||||
expect(b[8].keepReason).to.be('keepMonthly');
|
||||
expect(b[9].keepReason).to.be(undefined);
|
||||
});
|
||||
|
||||
it('keeps archive', function () {
|
||||
const backup = Object.assign({}, backupTemplate, { archive: true });
|
||||
backupCleaner._applyBackupRetention([backup], { keepWithinSecs: 0, keepLatest: false }, []);
|
||||
expect(backup.keepReason).to.be('archive');
|
||||
});
|
||||
});
|
||||
|
||||
describe('task', function () {
|
||||
@@ -216,6 +210,22 @@ describe('backup cleaner', function () {
|
||||
preserveSecs: 0
|
||||
};
|
||||
|
||||
const BACKUP_2_APP_2 = { // this is archived and left alone
|
||||
id: null,
|
||||
remotePath: 'backup-app-2',
|
||||
encryptionVersion: null,
|
||||
packageVersion: '2.0.0',
|
||||
type: backups.BACKUP_TYPE_APP,
|
||||
state: backups.BACKUP_STATE_NORMAL,
|
||||
identifier: 'app2',
|
||||
dependsOn: [],
|
||||
manifest: null,
|
||||
format: 'tgz',
|
||||
preserveSecs: 0
|
||||
};
|
||||
|
||||
const app2Config = { loc: 'apploc2' };
|
||||
|
||||
before(async function () {
|
||||
await settings._set(settings.BACKUP_STORAGE_KEY, JSON.stringify({
|
||||
provider: 'filesystem',
|
||||
@@ -231,7 +241,6 @@ describe('backup cleaner', function () {
|
||||
|
||||
console.log('started task', taskId);
|
||||
|
||||
// eslint-disable-next-line no-constant-condition
|
||||
while (true) {
|
||||
await timers.setTimeout(1000);
|
||||
|
||||
@@ -260,6 +269,9 @@ describe('backup cleaner', function () {
|
||||
BACKUP_1_APP_1.id = await backups.add(BACKUP_1_APP_1);
|
||||
BACKUP_1_BOX.dependsOn = [ BACKUP_1_APP_0.id, BACKUP_1_APP_1.id ];
|
||||
BACKUP_1_BOX.id = await backups.add(BACKUP_1_BOX);
|
||||
|
||||
BACKUP_2_APP_2.id = await backups.add(BACKUP_2_APP_2);
|
||||
await archives.add(BACKUP_2_APP_2.id, { appConfig: app2Config });
|
||||
});
|
||||
|
||||
it('succeeds with box backups, keeps latest', async function () {
|
||||
@@ -296,11 +308,12 @@ describe('backup cleaner', function () {
|
||||
await cleanupBackups();
|
||||
|
||||
let result = await backups.getByTypePaged(backups.BACKUP_TYPE_APP, 1, 1000);
|
||||
expect(result.length).to.equal(3);
|
||||
expect(result.length).to.equal(4);
|
||||
result = result.sort((r1, r2) => r1.remotePath.localeCompare(r2.remotePath));
|
||||
expect(result[0].id).to.be(BACKUP_0_APP_0.id); // because app is installed, latest backup is preserved
|
||||
expect(result[1].id).to.be(BACKUP_1_APP_0.id); // referenced by box
|
||||
expect(result[2].id).to.be(BACKUP_1_APP_1.id); // referenced by box
|
||||
expect(result[3].id).to.be(BACKUP_2_APP_2.id); // referenced by archive
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user