mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-08 20:11:21 +00:00
41 lines
999 B
Go
41 lines
999 B
Go
|
package sql_migrations
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"database/sql"
|
||
|
"testing"
|
||
|
|
||
|
_ "github.com/mattn/go-sqlite3"
|
||
|
)
|
||
|
|
||
|
func TestApplyMigrations(t *testing.T) {
|
||
|
// Open an in-memory SQLite database for testing
|
||
|
db, err := sql.Open("sqlite3", ":memory:")
|
||
|
if err != nil {
|
||
|
t.Fatalf("Failed to open database: %v", err)
|
||
|
}
|
||
|
defer db.Close()
|
||
|
|
||
|
// Start a transaction for testing
|
||
|
tx, err := db.Begin()
|
||
|
if err != nil {
|
||
|
t.Fatalf("Failed to start transaction: %v", err)
|
||
|
}
|
||
|
defer tx.Rollback()
|
||
|
|
||
|
// Call ApplyMigrations with the test transaction
|
||
|
err = ApplyMigrations(context.Background(), tx)
|
||
|
if err != nil {
|
||
|
t.Fatalf("ApplyMigrations failed: %v", err)
|
||
|
}
|
||
|
|
||
|
// You can add more tests here, such as verifying if the schema_version table is created and populated correctly,
|
||
|
// or checking if the beacon_indices table and index are created correctly.
|
||
|
|
||
|
// Commit the transaction (or rollback, if you're just testing)
|
||
|
err = tx.Commit()
|
||
|
if err != nil {
|
||
|
t.Fatalf("Failed to commit transaction: %v", err)
|
||
|
}
|
||
|
}
|