2015-02-24 04:46:34 -06:00
|
|
|
package migrations
|
2015-01-20 07:15:48 -06:00
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2015-02-05 03:37:13 -06:00
|
|
|
. "github.com/grafana/grafana/pkg/services/sqlstore/migrator"
|
|
|
|
"github.com/grafana/grafana/pkg/services/sqlstore/sqlutil"
|
2021-05-11 07:08:39 -05:00
|
|
|
"github.com/grafana/grafana/pkg/setting"
|
2020-12-04 02:05:00 -06:00
|
|
|
"github.com/stretchr/testify/require"
|
2020-04-01 08:57:21 -05:00
|
|
|
"xorm.io/xorm"
|
2015-01-20 07:15:48 -06:00
|
|
|
)
|
|
|
|
|
2015-01-20 07:44:37 -06:00
|
|
|
func TestMigrations(t *testing.T) {
|
2020-12-04 02:05:00 -06: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 07:08:39 -05:00
|
|
|
mg := NewMigrator(x, &setting.Cfg{})
|
2021-08-25 08:11:22 -05:00
|
|
|
migrations := &OSSMigrations{}
|
|
|
|
migrations.AddMigration(mg)
|
2020-12-04 02:05:00 -06:00
|
|
|
expectedMigrations := mg.MigrationsCount()
|
|
|
|
|
|
|
|
err = mg.Start()
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
has, err := x.SQL(query).Get(&result)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.True(t, has)
|
|
|
|
|
|
|
|
require.Equal(t, expectedMigrations, result.Count)
|
|
|
|
|
2021-05-11 07:08:39 -05:00
|
|
|
mg = NewMigrator(x, &setting.Cfg{})
|
2021-08-25 08:11:22 -05:00
|
|
|
migrations.AddMigration(mg)
|
2020-12-04 02:05:00 -06:00
|
|
|
|
|
|
|
err = mg.Start()
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
has, err = x.SQL(query).Get(&result)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.True(t, has)
|
|
|
|
require.Equal(t, expectedMigrations, result.Count)
|
2015-01-20 07:15:48 -06:00
|
|
|
}
|