mirror of
https://github.com/0rangebananaspy/authelia.git
synced 2024-09-14 22:47:21 +07:00
155 lines
3.5 KiB
Go
155 lines
3.5 KiB
Go
|
package storage
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
|
||
|
"github.com/stretchr/testify/assert"
|
||
|
"github.com/stretchr/testify/require"
|
||
|
)
|
||
|
|
||
|
func TestShouldObtainCorrectUpMigrations(t *testing.T) {
|
||
|
ver, err := latestMigrationVersion(providerSQLite)
|
||
|
require.NoError(t, err)
|
||
|
|
||
|
assert.Equal(t, testLatestVersion, ver)
|
||
|
|
||
|
migrations, err := loadMigrations(providerSQLite, 0, ver)
|
||
|
require.NoError(t, err)
|
||
|
|
||
|
assert.Len(t, migrations, ver)
|
||
|
|
||
|
for i := 0; i < len(migrations); i++ {
|
||
|
assert.Equal(t, i+1, migrations[i].Version)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestShouldObtainCorrectDownMigrations(t *testing.T) {
|
||
|
ver, err := latestMigrationVersion(providerSQLite)
|
||
|
require.NoError(t, err)
|
||
|
|
||
|
assert.Equal(t, testLatestVersion, ver)
|
||
|
|
||
|
migrations, err := loadMigrations(providerSQLite, ver, 0)
|
||
|
require.NoError(t, err)
|
||
|
|
||
|
assert.Len(t, migrations, ver)
|
||
|
|
||
|
for i := 0; i < len(migrations); i++ {
|
||
|
assert.Equal(t, ver-i, migrations[i].Version)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestMigrationsShouldNotBeDuplicatedPostgres(t *testing.T) {
|
||
|
migrations, err := loadMigrations(providerPostgres, 0, SchemaLatest)
|
||
|
require.NoError(t, err)
|
||
|
require.NotEqual(t, 0, len(migrations))
|
||
|
|
||
|
previousUp := make([]int, len(migrations))
|
||
|
|
||
|
for i, migration := range migrations {
|
||
|
assert.True(t, migration.Up)
|
||
|
|
||
|
if i != 0 {
|
||
|
for _, v := range previousUp {
|
||
|
assert.NotEqual(t, v, migration.Version)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
previousUp = append(previousUp, migration.Version)
|
||
|
}
|
||
|
|
||
|
migrations, err = loadMigrations(providerPostgres, SchemaLatest, 0)
|
||
|
require.NoError(t, err)
|
||
|
require.NotEqual(t, 0, len(migrations))
|
||
|
|
||
|
previousDown := make([]int, len(migrations))
|
||
|
|
||
|
for i, migration := range migrations {
|
||
|
assert.False(t, migration.Up)
|
||
|
|
||
|
if i != 0 {
|
||
|
for _, v := range previousDown {
|
||
|
assert.NotEqual(t, v, migration.Version)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
previousDown = append(previousDown, migration.Version)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestMigrationsShouldNotBeDuplicatedMySQL(t *testing.T) {
|
||
|
migrations, err := loadMigrations(providerMySQL, 0, SchemaLatest)
|
||
|
require.NoError(t, err)
|
||
|
require.NotEqual(t, 0, len(migrations))
|
||
|
|
||
|
previousUp := make([]int, len(migrations))
|
||
|
|
||
|
for i, migration := range migrations {
|
||
|
assert.True(t, migration.Up)
|
||
|
|
||
|
if i != 0 {
|
||
|
for _, v := range previousUp {
|
||
|
assert.NotEqual(t, v, migration.Version)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
previousUp = append(previousUp, migration.Version)
|
||
|
}
|
||
|
|
||
|
migrations, err = loadMigrations(providerMySQL, SchemaLatest, 0)
|
||
|
require.NoError(t, err)
|
||
|
require.NotEqual(t, 0, len(migrations))
|
||
|
|
||
|
previousDown := make([]int, len(migrations))
|
||
|
|
||
|
for i, migration := range migrations {
|
||
|
assert.False(t, migration.Up)
|
||
|
|
||
|
if i != 0 {
|
||
|
for _, v := range previousDown {
|
||
|
assert.NotEqual(t, v, migration.Version)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
previousDown = append(previousDown, migration.Version)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestMigrationsShouldNotBeDuplicatedSQLite(t *testing.T) {
|
||
|
migrations, err := loadMigrations(providerSQLite, 0, SchemaLatest)
|
||
|
require.NoError(t, err)
|
||
|
require.NotEqual(t, 0, len(migrations))
|
||
|
|
||
|
previousUp := make([]int, len(migrations))
|
||
|
|
||
|
for i, migration := range migrations {
|
||
|
assert.True(t, migration.Up)
|
||
|
|
||
|
if i != 0 {
|
||
|
for _, v := range previousUp {
|
||
|
assert.NotEqual(t, v, migration.Version)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
previousUp = append(previousUp, migration.Version)
|
||
|
}
|
||
|
|
||
|
migrations, err = loadMigrations(providerSQLite, SchemaLatest, 0)
|
||
|
require.NoError(t, err)
|
||
|
require.NotEqual(t, 0, len(migrations))
|
||
|
|
||
|
previousDown := make([]int, len(migrations))
|
||
|
|
||
|
for i, migration := range migrations {
|
||
|
assert.False(t, migration.Up)
|
||
|
|
||
|
if i != 0 {
|
||
|
for _, v := range previousDown {
|
||
|
assert.NotEqual(t, v, migration.Version)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
previousDown = append(previousDown, migration.Version)
|
||
|
}
|
||
|
}
|