dbmate/commands_test.go

167 lines
3.4 KiB
Go
Raw Normal View History

2015-12-01 09:10:49 -08:00
package main
2015-11-25 10:57:58 -08:00
import (
"flag"
"github.com/codegangsta/cli"
2015-11-25 10:57:58 -08:00
"github.com/stretchr/testify/require"
"net/url"
2015-11-25 10:57:58 -08:00
"os"
"path/filepath"
2015-11-25 10:57:58 -08:00
"testing"
)
var stubsDir string
func testContext(t *testing.T, u *url.URL) *cli.Context {
var err error
if stubsDir == "" {
stubsDir, err = filepath.Abs("./stubs")
require.Nil(t, err)
}
err = os.Chdir(stubsDir)
require.Nil(t, err)
err = os.Setenv("DATABASE_URL", u.String())
require.Nil(t, err)
2015-12-01 09:10:49 -08:00
app := NewApp()
flagset := flag.NewFlagSet(app.Name, flag.ContinueOnError)
for _, f := range app.Flags {
f.Apply(flagset)
}
return cli.NewContext(app, flagset, nil)
}
func testURLs(t *testing.T) []*url.URL {
return []*url.URL{
postgresTestURL(t),
2015-12-01 09:43:35 -08:00
mySQLTestURL(t),
2015-12-01 11:38:31 -08:00
sqliteTestURL(t),
}
}
func TestGetDatabaseUrl(t *testing.T) {
envURL, err := url.Parse("foo://example.org/db")
2015-11-27 14:27:44 -08:00
require.Nil(t, err)
ctx := testContext(t, envURL)
2015-11-25 10:57:58 -08:00
2015-12-01 09:10:49 -08:00
u, err := GetDatabaseURL(ctx)
2015-11-25 10:57:58 -08:00
require.Nil(t, err)
require.Equal(t, "foo", u.Scheme)
2015-11-25 10:57:58 -08:00
require.Equal(t, "example.org", u.Host)
require.Equal(t, "/db", u.Path)
}
func testMigrateCommandURL(t *testing.T, u *url.URL) {
ctx := testContext(t, u)
// drop and recreate database
2015-12-01 09:10:49 -08:00
err := DropCommand(ctx)
require.Nil(t, err)
2015-12-01 09:10:49 -08:00
err = CreateCommand(ctx)
require.Nil(t, err)
// migrate
2015-12-01 09:10:49 -08:00
err = MigrateCommand(ctx)
require.Nil(t, err)
// verify results
2015-12-01 09:43:35 -08:00
db, err := GetDriverOpen(u)
require.Nil(t, err)
defer mustClose(db)
count := 0
err = db.QueryRow(`select count(*) from schema_migrations
where version = '20151129054053'`).Scan(&count)
require.Nil(t, err)
require.Equal(t, 1, count)
err = db.QueryRow("select count(*) from users").Scan(&count)
require.Nil(t, err)
require.Equal(t, 1, count)
}
func TestMigrateCommand(t *testing.T) {
for _, u := range testURLs(t) {
testMigrateCommandURL(t, u)
}
}
func testUpCommandURL(t *testing.T, u *url.URL) {
ctx := testContext(t, u)
// drop database
2015-12-01 09:10:49 -08:00
err := DropCommand(ctx)
require.Nil(t, err)
// create and migrate
2015-12-01 09:10:49 -08:00
err = UpCommand(ctx)
require.Nil(t, err)
// verify results
2015-12-01 09:43:35 -08:00
db, err := GetDriverOpen(u)
require.Nil(t, err)
defer mustClose(db)
count := 0
err = db.QueryRow(`select count(*) from schema_migrations
where version = '20151129054053'`).Scan(&count)
require.Nil(t, err)
require.Equal(t, 1, count)
err = db.QueryRow("select count(*) from users").Scan(&count)
require.Nil(t, err)
require.Equal(t, 1, count)
}
func TestUpCommand(t *testing.T) {
for _, u := range testURLs(t) {
testUpCommandURL(t, u)
}
}
func testRollbackCommandURL(t *testing.T, u *url.URL) {
ctx := testContext(t, u)
// drop, recreate, and migrate database
2015-12-01 09:10:49 -08:00
err := DropCommand(ctx)
require.Nil(t, err)
2015-12-01 09:10:49 -08:00
err = CreateCommand(ctx)
require.Nil(t, err)
2015-12-01 09:10:49 -08:00
err = MigrateCommand(ctx)
require.Nil(t, err)
// verify migration
2015-12-01 09:43:35 -08:00
db, err := GetDriverOpen(u)
require.Nil(t, err)
defer mustClose(db)
count := 0
err = db.QueryRow(`select count(*) from schema_migrations
where version = '20151129054053'`).Scan(&count)
require.Nil(t, err)
require.Equal(t, 1, count)
// rollback
2015-12-01 09:10:49 -08:00
err = RollbackCommand(ctx)
require.Nil(t, err)
// verify rollback
err = db.QueryRow("select count(*) from schema_migrations").Scan(&count)
require.Nil(t, err)
require.Equal(t, 0, count)
err = db.QueryRow("select count(*) from users").Scan(&count)
2015-11-30 22:05:23 -08:00
require.NotNil(t, err)
2015-12-01 11:38:31 -08:00
require.Regexp(t, "(does not exist|doesn't exist|no such table)", err.Error())
}
func TestRollbackCommand(t *testing.T) {
for _, u := range testURLs(t) {
testRollbackCommandURL(t, u)
}
}