mirror of
https://github.com/portainer/portainer.git
synced 2025-07-19 13:29:41 +02:00
* backport migration EE code structure * filesystem copy function * set db status to updating before migration - reset on completion * support for auto-backup on version upgrade * - rollback cli flag support (with confirmation) - rollback implementation backport from EE * removed edition as it is not required in CE * migrated test datastore from bolttest to bolt package to make it usable for testing * backported failsafe migration * - backported tests from EE - refactored tests to use test datastore * test store implementing datastore interface * addressed PR issues/improvements * refactor test * added backup file removal error logging * resolved conflicts, updated code * fixed missing bolttest package - migrated to bolt * feat(migration): wrap migration errors to provide context for failure EE-1742 (#5711) * feat(migrator): wrap errors to provide more context to failures EE-1742 * add overall failure back in. diff log file * updated helm tests pointing to correct teststore Co-authored-by: Matt Hook <hookenz@gmail.com>
116 lines
2.9 KiB
Go
116 lines
2.9 KiB
Go
package bolt
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"path"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
portainer "github.com/portainer/portainer/api"
|
|
)
|
|
|
|
// isFileExist is helper function to check for file existence
|
|
func isFileExist(path string) bool {
|
|
matches, err := filepath.Glob(path)
|
|
if err != nil {
|
|
return false
|
|
}
|
|
return len(matches) > 0
|
|
}
|
|
|
|
func TestCreateBackupFolders(t *testing.T) {
|
|
store, teardown := MustNewTestStore(false)
|
|
defer teardown()
|
|
|
|
backupPath := path.Join(store.path, backupDefaults.backupDir)
|
|
|
|
if isFileExist(backupPath) {
|
|
t.Error("Expect backups folder to not exist")
|
|
}
|
|
|
|
store.createBackupFolders()
|
|
if !isFileExist(backupPath) {
|
|
t.Error("Expect backups folder to exist")
|
|
}
|
|
}
|
|
|
|
func TestStoreCreation(t *testing.T) {
|
|
store, teardown := MustNewTestStore(true)
|
|
defer teardown()
|
|
|
|
if store == nil {
|
|
t.Error("Expect to create a store")
|
|
}
|
|
|
|
if store.edition() != portainer.PortainerCE {
|
|
t.Error("Expect to get CE Edition")
|
|
}
|
|
}
|
|
|
|
func TestBackup(t *testing.T) {
|
|
store, teardown := MustNewTestStore(true)
|
|
defer teardown()
|
|
|
|
t.Run("Backup should create default db backup", func(t *testing.T) {
|
|
store.VersionService.StoreDBVersion(portainer.DBVersion)
|
|
store.BackupWithOptions(nil)
|
|
|
|
backupFileName := path.Join(store.path, "backups", "common", fmt.Sprintf("portainer.db.%03d.*", portainer.DBVersion))
|
|
if !isFileExist(backupFileName) {
|
|
t.Errorf("Expect backup file to be created %s", backupFileName)
|
|
}
|
|
})
|
|
|
|
t.Run("BackupWithOption should create a name specific backup at common path", func(t *testing.T) {
|
|
store.BackupWithOptions(&BackupOptions{
|
|
BackupFileName: beforePortainerVersionUpgradeBackup,
|
|
BackupDir: store.commonBackupDir(),
|
|
})
|
|
backupFileName := path.Join(store.path, "backups", "common", beforePortainerVersionUpgradeBackup)
|
|
if !isFileExist(backupFileName) {
|
|
t.Errorf("Expect backup file to be created %s", backupFileName)
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestRemoveWithOptions(t *testing.T) {
|
|
store, teardown := MustNewTestStore(true)
|
|
defer teardown()
|
|
|
|
t.Run("successfully removes file if existent", func(t *testing.T) {
|
|
store.createBackupFolders()
|
|
options := &BackupOptions{
|
|
BackupDir: store.commonBackupDir(),
|
|
BackupFileName: "test.txt",
|
|
}
|
|
|
|
filePath := path.Join(options.BackupDir, options.BackupFileName)
|
|
f, err := os.Create(filePath)
|
|
if err != nil {
|
|
t.Fatalf("file should be created; err=%s", err)
|
|
}
|
|
f.Close()
|
|
|
|
err = store.RemoveWithOptions(options)
|
|
if err != nil {
|
|
t.Errorf("RemoveWithOptions should successfully remove file; err=%w", err)
|
|
}
|
|
|
|
if isFileExist(f.Name()) {
|
|
t.Errorf("RemoveWithOptions should successfully remove file; file=%s", f.Name())
|
|
}
|
|
})
|
|
|
|
t.Run("fails to removes file if non-existent", func(t *testing.T) {
|
|
options := &BackupOptions{
|
|
BackupDir: store.commonBackupDir(),
|
|
BackupFileName: "test.txt",
|
|
}
|
|
|
|
err := store.RemoveWithOptions(options)
|
|
if err == nil {
|
|
t.Error("RemoveWithOptions should fail for non-existent file")
|
|
}
|
|
})
|
|
}
|