package database import ( "database/sql" "fmt" _ "github.com/jackc/pgx/v5/stdlib" "github.com/pressly/goose/v3" ) func RunMigrations(databaseURL string) error { db, err := sql.Open("pgx", databaseURL) if err != nil { return fmt.Errorf("failed to open database connection for migrations: %w", err) } defer db.Close() if err := db.Ping(); err != nil { return fmt.Errorf("failed to ping database before migrations: %w", err) } if err := goose.SetDialect("postgres"); err != nil { return fmt.Errorf("failed to set goose dialect: %w", err) } if err := goose.Up(db, "migrations"); err != nil { return fmt.Errorf("failed to run migrations: %w", err) } return nil }