MakeTestdataFromLive umgeschrieben vereinfacht

This commit is contained in:
2025-07-29 08:38:29 +02:00
parent 39d5b69cb4
commit bb5be29b57
5 changed files with 269 additions and 402 deletions
+22 -4
View File
@@ -2,13 +2,13 @@ package maintenance
import (
"bamort/database"
"bamort/importer"
"bamort/models"
"bamort/user"
"fmt"
"net/http"
"os"
"path/filepath"
"strings"
"github.com/gin-gonic/gin"
"gorm.io/driver/sqlite"
@@ -47,9 +47,9 @@ func migrateAllStructures(db *gorm.DB) error {
return fmt.Errorf("failed to migrate gsmaster structures: %w", err)
}
if err := importer.MigrateStructure(db); err != nil {
/*if err := importer.MigrateStructure(db); err != nil {
return fmt.Errorf("failed to migrate importer structures: %w", err)
}
}*/
return nil
}
@@ -74,6 +74,11 @@ func MakeTestdataFromLive(c *gin.Context) {
})
}
// CopyLiveDatabaseToFile kopiert die MariaDB-Datenbank in eine SQLite-Datei (exported for testing)
func CopyLiveDatabaseToFile(liveDB *gorm.DB, targetFile string) error {
return copyLiveDatabaseToFile(liveDB, targetFile)
}
// copyLiveDatabaseToFile kopiert die MariaDB-Datenbank in eine SQLite-Datei
func copyLiveDatabaseToFile(liveDB *gorm.DB, targetFile string) error {
// Verzeichnis erstellen falls es nicht existiert
@@ -189,7 +194,12 @@ func copyMariaDBToSQLite(mariaDB, sqliteDB *gorm.DB) error {
func copyTableData(sourceDB, targetDB *gorm.DB, model interface{}) error {
// Anzahl der Datensätze prüfen
var count int64
if err := sourceDB.Model(model).Count(&count).Error; err != nil {
err := sourceDB.Model(model).Count(&count).Error
if err != nil {
// If table doesn't exist, skip silently (useful for testing with partial schemas)
if isTableNotExistError(err) {
return nil
}
return err
}
@@ -220,6 +230,14 @@ func copyTableData(sourceDB, targetDB *gorm.DB, model interface{}) error {
return nil
}
// isTableNotExistError checks if the error indicates a table doesn't exist
func isTableNotExistError(err error) bool {
errorMsg := err.Error()
return strings.Contains(errorMsg, "no such table") ||
strings.Contains(errorMsg, "doesn't exist") ||
strings.Contains(errorMsg, "Table") && strings.Contains(errorMsg, "doesn't exist")
}
// LoadPredefinedTestDataFromFile loads predefined test data from a specific file into the provided database
func LoadPredefinedTestDataFromFile(targetDB *gorm.DB, dataFile string) error {
// Check if file exists