graphql-engine/cli/internal/scripts/multisourceupgrade_test.go

210 lines
4.6 KiB
Go
Raw Normal View History

package scripts
import (
"os"
"testing"
"github.com/spf13/afero"
"github.com/stretchr/testify/assert"
)
func Test_checkIfDirectoryIsMigration(t *testing.T) {
type args struct {
dirPath string
}
tests := []struct {
name string
args args
want bool
wantErr bool
}{
{
"can check if a directory name is a valid migration",
args{
dirPath: "testdata/1604855964903_test",
},
true,
false,
},
{
"can check if a directory name is a valid migration",
args{
dirPath: "1604855964903_test",
},
true,
false,
},
{
"can check if a directory name is a valid migration",
args{
dirPath: "testdata/160855964903_test",
},
false,
false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
got, err := isHasuraCLIGeneratedMigration(tt.args.dirPath)
if (err != nil) != tt.wantErr {
t.Errorf("getMigrationDirectoryNames() error = %v, wantErr %v", err, tt.wantErr)
return
}
assert.Equal(t, tt.want, got)
})
}
}
func Test_getMigrationDirectoryNames(t *testing.T) {
type args struct {
fs afero.Fs
rootMigrationsDir string
}
tests := []struct {
name string
args args
want []string
wantErr bool
}{
{
"can get list of migration directories",
args{
fs: func() afero.Fs {
fs := afero.NewMemMapFs()
if err := fs.MkdirAll("migrations/1604855964903_test2", os.ModePerm); err != nil {
t.Fatal(err)
}
if err := fs.MkdirAll("migrations/1604255964903_test", os.ModePerm); err != nil {
t.Fatal(err)
}
if err := fs.MkdirAll("migrations/randomdir", os.ModePerm); err != nil {
t.Fatal(err)
}
file, err := fs.Create("migrations/somefile.yaml")
if err != nil {
t.Fatal(err)
}
file.Close()
return fs
}(),
rootMigrationsDir: "migrations",
},
[]string{
"1604255964903_test",
"1604855964903_test2",
},
false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
got, err := getMigrationDirectoryNames(tt.args.fs, tt.args.rootMigrationsDir)
if (err != nil) != tt.wantErr {
t.Errorf("getMigrationDirectoryNames() error = %v, wantErr %v", err, tt.wantErr)
return
}
assert.Equal(t, tt.want, got)
})
}
}
func Test_moveMigrationsToDatasourceDirectory(t *testing.T) {
type args struct {
fs afero.Fs
dirs []string
parentMigrationsDirectory string
target string
}
tests := []struct {
name string
args args
wantErr bool
want []string
}{
{
"can move directories to directory",
args{
fs: func() afero.Fs {
fs := afero.NewMemMapFs()
if err := fs.MkdirAll("1", 0755); err != nil {
t.Fatal(err)
}
if err := fs.MkdirAll("2", 0755); err != nil {
t.Fatal(err)
}
if err := fs.MkdirAll("3", 0755); err != nil {
t.Fatal(err)
}
if err := fs.MkdirAll("moved", 0755); err != nil {
t.Fatal(err)
}
return fs
}(),
dirs: []string{"1", "2", "3"},
parentMigrationsDirectory: ".",
target: "moved",
},
false,
[]string{"moved/1", "moved/2", "moved/3"},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if err := copyMigrations(tt.args.fs, tt.args.dirs, tt.args.parentMigrationsDirectory, tt.args.target); (err != nil) != tt.wantErr {
assert.NoError(t, err)
}
for _, want := range tt.want {
_, err := tt.args.fs.Stat(want)
assert.NoError(t, err)
}
})
}
}
func Test_removeDirectories(t *testing.T) {
type args struct {
fs afero.Fs
parentDirectory string
dirs []string
}
tests := []struct {
name string
args args
wantErr bool
}{
{
"can delete directories",
args{
fs: func() afero.Fs {
fs := afero.NewMemMapFs()
if err := fs.MkdirAll("1/x/y", 0755); err != nil {
t.Fatal(err)
}
if err := fs.MkdirAll("2", 0755); err != nil {
t.Fatal(err)
}
if err := fs.MkdirAll("3", 0755); err != nil {
t.Fatal(err)
}
return fs
}(),
dirs: []string{"1", "2", "4"},
parentDirectory: ".",
},
false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if err := removeDirectories(tt.args.fs, tt.args.parentDirectory, tt.args.dirs); (err != nil) != tt.wantErr {
t.Errorf("removeDirectories() error = %v, wantErr %v", err, tt.wantErr)
}
for _, d := range tt.args.dirs {
_, err := tt.args.fs.Stat(d)
assert.Error(t, err)
}
})
}
}