e3bb8b19dd
Also improves migrations and updates the db schema docs. Signed-off-by: Michael Mayer <michael@photoprism.app>
89 lines
1.7 KiB
Go
89 lines
1.7 KiB
Go
package entity
|
|
|
|
import (
|
|
"os"
|
|
"time"
|
|
|
|
"github.com/photoprism/photoprism/internal/migrate"
|
|
"github.com/photoprism/photoprism/pkg/clean"
|
|
)
|
|
|
|
// onReady contains init functions to be called when the
|
|
// initialization of the database is complete.
|
|
var onReady []func()
|
|
|
|
// ready executes init callbacks when the initialization of the
|
|
// database is complete.
|
|
func ready() {
|
|
for _, init := range onReady {
|
|
init()
|
|
}
|
|
}
|
|
|
|
// InitDb creates database tables and inserts default fixtures as needed.
|
|
func InitDb(opt migrate.Options) {
|
|
if !HasDbProvider() {
|
|
log.Error("migrate: no database provider")
|
|
return
|
|
}
|
|
|
|
start := time.Now()
|
|
|
|
if opt.DropDeprecated {
|
|
DeprecatedTables.Drop(Db())
|
|
}
|
|
|
|
Entities.Migrate(Db(), opt)
|
|
Entities.WaitForMigration(Db())
|
|
|
|
CreateDefaultFixtures()
|
|
|
|
ready()
|
|
|
|
log.Debugf("migrate: completed in %s", time.Since(start))
|
|
}
|
|
|
|
// InitTestDb connects to and completely initializes the test database incl fixtures.
|
|
func InitTestDb(driver, dsn string) *DbConn {
|
|
if HasDbProvider() {
|
|
return nil
|
|
}
|
|
|
|
start := time.Now()
|
|
|
|
// Set default test database driver.
|
|
if driver == "test" || driver == "sqlite" || driver == "" || dsn == "" {
|
|
driver = SQLite3
|
|
}
|
|
|
|
// Set default database DSN.
|
|
if driver == SQLite3 {
|
|
if dsn == "" {
|
|
dsn = SQLiteMemoryDSN
|
|
} else if dsn != SQLiteTestDB {
|
|
// Continue.
|
|
} else if err := os.Remove(dsn); err == nil {
|
|
log.Debugf("sqlite: test file %s removed", clean.Log(dsn))
|
|
}
|
|
}
|
|
|
|
log.Infof("initializing %s test db in %s", driver, dsn)
|
|
|
|
// Create gorm.DB connection provider.
|
|
db := &DbConn{
|
|
Driver: driver,
|
|
Dsn: dsn,
|
|
}
|
|
|
|
// Insert test fixtures into the database.
|
|
SetDbProvider(db)
|
|
ResetTestFixtures()
|
|
File{}.RegenerateIndex()
|
|
|
|
ready()
|
|
|
|
log.Debugf("migrate: completed in %s", time.Since(start))
|
|
|
|
return db
|
|
}
|