Skip to content

Latest commit

 

History

History
 
 

bunmigrator

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 

bunmigrator

go get github.com/peterldowns/pgtestdb/migrators/bunmigrator@latest

bunmigrator provides a migrator that can be used with projects that make use of uptrace/bun for migrations.

Because Hash() requires calculating a unique hash based on the contents of migrations, this implementation only supports reading migration files from disk or an embedded filesystem. This migrator does not support go-based migrations.

You can configure the migrations directory and the filesystem being used. Here's an example:

import (
	// Initialize the "pgdriver" sql.DB driver
	// Use this by setting `config.DriverName` to "pg".
	// For more information, see https://bun.uptrace.dev/postgres/#pgdriver
	_ "github.com/uptrace/bun/driver/pgdriver"
)

//go:embed migrations/*.sql
var exampleFS embed.FS

func TestMigrateFromEmbeddedFS(t *testing.T) {
	t.Parallel()
	ctx := context.Background()
	bm := bunmigrator.New("migrations", bunmigrator.WithFS(exampleFS))
	db := pgtestdb.New(t, pgtestdb.Config{
		// Use bun's "pgdriver" to connect.
		DriverName: "pg",
		Host:       "localhost",
		User:       "postgres",
		Password:   "password",
		Port:       "5433",
		Options:    "sslmode=disable",
	}, bm)

	assert.NotEqual(t, nil, db)
}

func TestMigrateFromDisk(t *testing.T) {
	t.Parallel()
	ctx := context.Background()
	bm := bunmigrator.New("migrations")
	db := pgtestdb.New(t, pgtestdb.Config{
        // Use bun's "pgdriver" to connect.
		DriverName: "pg",
		Host:       "localhost",
		User:       "postgres",
		Password:   "password",
		Port:       "5433",
		Options:    "sslmode=disable",
	}, bm)

	assert.NotEqual(t, nil, db)
}