2015-11-25 10:57:58 -08:00
|
|
|
package main_test
|
|
|
|
|
|
|
|
|
|
import (
|
2015-11-28 23:45:23 -07:00
|
|
|
"database/sql"
|
2015-11-25 11:32:13 -08:00
|
|
|
"flag"
|
2015-11-25 10:57:58 -08:00
|
|
|
"github.com/adrianmacneil/dbmate"
|
2015-11-25 11:32:13 -08:00
|
|
|
"github.com/codegangsta/cli"
|
2015-11-25 10:57:58 -08:00
|
|
|
"github.com/stretchr/testify/require"
|
2015-11-28 23:45:23 -07:00
|
|
|
"io"
|
|
|
|
|
"net/url"
|
2015-11-25 10:57:58 -08:00
|
|
|
"os"
|
2015-11-28 23:45:23 -07:00
|
|
|
"path/filepath"
|
2015-11-25 10:57:58 -08:00
|
|
|
"testing"
|
|
|
|
|
)
|
|
|
|
|
|
2015-11-28 23:45:23 -07:00
|
|
|
var stubsDir string
|
|
|
|
|
|
2015-11-30 22:06:12 -08:00
|
|
|
func testContext(t *testing.T, u *url.URL) *cli.Context {
|
2015-11-28 23:45:23 -07:00
|
|
|
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-11-25 11:32:13 -08:00
|
|
|
app := main.NewApp()
|
|
|
|
|
flagset := flag.NewFlagSet(app.Name, flag.ContinueOnError)
|
|
|
|
|
for _, f := range app.Flags {
|
|
|
|
|
f.Apply(flagset)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return cli.NewContext(app, flagset, nil)
|
|
|
|
|
}
|
|
|
|
|
|
2015-11-30 22:06:12 -08:00
|
|
|
func postgresTestURL(t *testing.T) *url.URL {
|
2015-11-28 23:45:23 -07:00
|
|
|
str := os.Getenv("POSTGRES_PORT")
|
|
|
|
|
require.NotEmpty(t, str, "missing POSTGRES_PORT environment variable")
|
|
|
|
|
|
|
|
|
|
u, err := url.Parse(str)
|
|
|
|
|
require.Nil(t, err)
|
|
|
|
|
|
|
|
|
|
u.Scheme = "postgres"
|
|
|
|
|
u.User = url.User("postgres")
|
|
|
|
|
u.Path = "/dbmate"
|
|
|
|
|
u.RawQuery = "sslmode=disable"
|
|
|
|
|
|
|
|
|
|
return u
|
|
|
|
|
}
|
|
|
|
|
|
2015-11-30 22:06:12 -08:00
|
|
|
func testURLs(t *testing.T) []*url.URL {
|
|
|
|
|
return []*url.URL{
|
|
|
|
|
postgresTestURL(t),
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2015-11-28 23:45:23 -07:00
|
|
|
func mustClose(c io.Closer) {
|
|
|
|
|
if err := c.Close(); err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestGetDatabaseUrl(t *testing.T) {
|
2015-11-30 22:06:12 -08:00
|
|
|
envURL, err := url.Parse("foo://example.org/db")
|
2015-11-27 14:27:44 -08:00
|
|
|
require.Nil(t, err)
|
2015-11-30 22:06:12 -08:00
|
|
|
ctx := testContext(t, envURL)
|
2015-11-25 10:57:58 -08:00
|
|
|
|
2015-11-25 11:32:13 -08:00
|
|
|
u, err := main.GetDatabaseURL(ctx)
|
2015-11-25 10:57:58 -08:00
|
|
|
require.Nil(t, err)
|
|
|
|
|
|
2015-11-30 22:06:12 -08:00
|
|
|
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)
|
|
|
|
|
}
|
2015-11-28 23:45:23 -07:00
|
|
|
|
2015-11-30 22:06:12 -08:00
|
|
|
func testMigrateCommandURL(t *testing.T, u *url.URL) {
|
|
|
|
|
ctx := testContext(t, u)
|
2015-11-28 23:45:23 -07:00
|
|
|
|
|
|
|
|
// drop and recreate database
|
|
|
|
|
err := main.DropCommand(ctx)
|
|
|
|
|
require.Nil(t, err)
|
|
|
|
|
err = main.CreateCommand(ctx)
|
|
|
|
|
require.Nil(t, err)
|
|
|
|
|
|
|
|
|
|
// migrate
|
|
|
|
|
err = main.MigrateCommand(ctx)
|
|
|
|
|
require.Nil(t, err)
|
|
|
|
|
|
|
|
|
|
// verify results
|
2015-11-30 22:06:12 -08:00
|
|
|
db, err := sql.Open(u.Scheme, u.String())
|
2015-11-28 23:45:23 -07:00
|
|
|
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)
|
|
|
|
|
}
|
|
|
|
|
|
2015-11-30 22:06:12 -08:00
|
|
|
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)
|
2015-11-28 23:45:23 -07:00
|
|
|
|
|
|
|
|
// drop database
|
|
|
|
|
err := main.DropCommand(ctx)
|
|
|
|
|
require.Nil(t, err)
|
|
|
|
|
|
|
|
|
|
// create and migrate
|
|
|
|
|
err = main.UpCommand(ctx)
|
|
|
|
|
require.Nil(t, err)
|
|
|
|
|
|
|
|
|
|
// verify results
|
2015-11-30 22:06:12 -08:00
|
|
|
db, err := sql.Open(u.Scheme, u.String())
|
2015-11-28 23:45:23 -07:00
|
|
|
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)
|
|
|
|
|
}
|
|
|
|
|
|
2015-11-30 22:06:12 -08:00
|
|
|
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)
|
2015-11-28 23:45:23 -07:00
|
|
|
|
|
|
|
|
// drop, recreate, and migrate database
|
|
|
|
|
err := main.DropCommand(ctx)
|
|
|
|
|
require.Nil(t, err)
|
|
|
|
|
err = main.CreateCommand(ctx)
|
|
|
|
|
require.Nil(t, err)
|
|
|
|
|
err = main.MigrateCommand(ctx)
|
|
|
|
|
require.Nil(t, err)
|
|
|
|
|
|
|
|
|
|
// verify migration
|
2015-11-30 22:06:12 -08:00
|
|
|
db, err := sql.Open(u.Scheme, u.String())
|
2015-11-28 23:45:23 -07:00
|
|
|
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
|
|
|
|
|
err = main.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)
|
|
|
|
|
require.Equal(t, "pq: relation \"users\" does not exist", err.Error())
|
|
|
|
|
}
|
2015-11-30 22:06:12 -08:00
|
|
|
|
|
|
|
|
func TestRollbackCommand(t *testing.T) {
|
|
|
|
|
for _, u := range testURLs(t) {
|
|
|
|
|
testRollbackCommandURL(t, u)
|
|
|
|
|
}
|
|
|
|
|
}
|