2015-02-24 11:46:34 +01:00
|
|
|
package migrations
|
2015-01-20 14:15:48 +01:00
|
|
|
|
|
|
|
|
import (
|
2021-11-24 20:56:07 +01:00
|
|
|
"fmt"
|
|
|
|
|
"strings"
|
2015-01-20 14:15:48 +01:00
|
|
|
"testing"
|
|
|
|
|
|
2021-11-24 20:56:07 +01:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
"xorm.io/xorm"
|
|
|
|
|
|
2015-02-05 10:37:13 +01:00
|
|
|
. "github.com/grafana/grafana/pkg/services/sqlstore/migrator"
|
|
|
|
|
"github.com/grafana/grafana/pkg/services/sqlstore/sqlutil"
|
2021-05-11 08:08:39 -04:00
|
|
|
"github.com/grafana/grafana/pkg/setting"
|
2015-01-20 14:15:48 +01:00
|
|
|
)
|
|
|
|
|
|
2015-01-20 14:44:37 +01:00
|
|
|
func TestMigrations(t *testing.T) {
|
2020-12-04 09:05:00 +01:00
|
|
|
testDB := sqlutil.SQLite3TestDB()
|
|
|
|
|
const query = `select count(*) as count from migration_log`
|
|
|
|
|
result := struct{ Count int }{}
|
|
|
|
|
|
|
|
|
|
x, err := xorm.NewEngine(testDB.DriverName, testDB.ConnStr)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
err = NewDialect(x).CleanDB()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
_, err = x.SQL(query).Get(&result)
|
|
|
|
|
require.Error(t, err)
|
|
|
|
|
|
2021-05-11 08:08:39 -04:00
|
|
|
mg := NewMigrator(x, &setting.Cfg{})
|
2021-08-25 15:11:22 +02:00
|
|
|
migrations := &OSSMigrations{}
|
|
|
|
|
migrations.AddMigration(mg)
|
2021-11-24 20:56:07 +01:00
|
|
|
expectedMigrations := mg.GetMigrationIDs(true)
|
2020-12-04 09:05:00 +01:00
|
|
|
|
|
|
|
|
err = mg.Start()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
has, err := x.SQL(query).Get(&result)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
require.True(t, has)
|
|
|
|
|
|
2021-11-24 20:56:07 +01:00
|
|
|
checkStepsAndDatabaseMatch(t, mg, expectedMigrations)
|
2020-12-04 09:05:00 +01:00
|
|
|
|
2021-05-11 08:08:39 -04:00
|
|
|
mg = NewMigrator(x, &setting.Cfg{})
|
2021-08-25 15:11:22 +02:00
|
|
|
migrations.AddMigration(mg)
|
2020-12-04 09:05:00 +01:00
|
|
|
|
|
|
|
|
err = mg.Start()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
|
|
has, err = x.SQL(query).Get(&result)
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
require.True(t, has)
|
2021-11-24 20:56:07 +01:00
|
|
|
checkStepsAndDatabaseMatch(t, mg, expectedMigrations)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func checkStepsAndDatabaseMatch(t *testing.T, mg *Migrator, expected []string) {
|
|
|
|
|
t.Helper()
|
|
|
|
|
log, err := mg.GetMigrationLog()
|
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
missing := make([]string, 0)
|
|
|
|
|
for _, id := range expected {
|
|
|
|
|
_, ok := log[id]
|
|
|
|
|
if !ok {
|
|
|
|
|
missing = append(missing, id)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
notIntended := make([]string, 0)
|
|
|
|
|
for logId := range log {
|
|
|
|
|
found := false
|
|
|
|
|
for _, s := range expected {
|
|
|
|
|
found = s == logId
|
|
|
|
|
if found {
|
|
|
|
|
break
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if !found {
|
|
|
|
|
notIntended = append(notIntended, logId)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if len(missing) == 0 && len(notIntended) == 0 {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var msg string
|
|
|
|
|
if len(missing) > 0 {
|
|
|
|
|
msg = fmt.Sprintf("was not executed [%v], ", strings.Join(missing, ", "))
|
|
|
|
|
}
|
|
|
|
|
if len(notIntended) > 0 {
|
|
|
|
|
msg += fmt.Sprintf("executed but should not [%v]", strings.Join(notIntended, ", "))
|
|
|
|
|
}
|
|
|
|
|
require.Failf(t, "the number of migrations does not match log in database", msg)
|
2015-01-20 14:15:48 +01:00
|
|
|
}
|