graphql-engine/cli/migrate/source/parse_test.go
Aravind Shankar bb63d7e60e
cli: allow managing actions (#3859)
Co-authored-by: Rishichandra Wawhal <rishichandra.wawhal@gmail.com>
Co-authored-by: Rikin Kachhia <54616969+rikinsk@users.noreply.github.com>
Co-authored-by: Aravind <aravindkp@outlook.in>
Co-authored-by: Anon Ray <ecthiender@users.noreply.github.com>
Co-authored-by: Shahidh K Muhammed <muhammedshahid.k@gmail.com>
2020-02-24 21:44:46 +05:30

120 lines
2.2 KiB
Go

package source
import (
"testing"
)
func TestParse(t *testing.T) {
tt := []struct {
name string
expectErr error
expectMigration *Migration
}{
{
name: "1_foobar.up.sql",
expectErr: nil,
expectMigration: &Migration{
Version: 1,
Identifier: "foobar",
Direction: Up,
},
},
{
name: "1_foobar.up.yaml",
expectErr: nil,
expectMigration: &Migration{
Version: 1,
Identifier: "foobar",
Direction: MetaUp,
},
},
{
name: "1_foobar.down.sql",
expectErr: nil,
expectMigration: &Migration{
Version: 1,
Identifier: "foobar",
Direction: Down,
},
},
{
name: "1_foobar.down.yaml",
expectErr: nil,
expectMigration: &Migration{
Version: 1,
Identifier: "foobar",
Direction: MetaDown,
},
},
{
name: "1_f-o_ob+ar.up.sql",
expectErr: nil,
expectMigration: &Migration{
Version: 1,
Identifier: "f-o_ob+ar",
Direction: Up,
},
},
{
name: "1485385885_foobar.up.sql",
expectErr: nil,
expectMigration: &Migration{
Version: 1485385885,
Identifier: "foobar",
Direction: Up,
},
},
{
name: "20170412214116_date_foobar.up.sql",
expectErr: nil,
expectMigration: &Migration{
Version: 20170412214116,
Identifier: "date_foobar",
Direction: Up,
},
},
{
name: "-1_foobar.up.sql",
expectErr: ErrParse,
expectMigration: nil,
},
{
name: "foobar.up.sql",
expectErr: ErrParse,
expectMigration: nil,
},
{
name: "1.up.sql",
expectErr: ErrParse,
expectMigration: nil,
},
{
name: "1_foobar.sql",
expectErr: ErrParse,
expectMigration: nil,
},
{
name: "1_foobar.up",
expectErr: ErrParse,
expectMigration: nil,
},
{
name: "1_foobar.down",
expectErr: ErrParse,
expectMigration: nil,
},
}
for i, v := range tt {
f, err := Parse(v.name)
if err != v.expectErr {
t.Errorf("expected %v, got %v, in %v", v.expectErr, err, i)
}
if v.expectMigration != nil && *f != *v.expectMigration {
t.Errorf("expected %+v, got %+v, in %v", *v.expectMigration, *f, i)
}
}
}