73e5c36f25
* Upgrade xorm to v1.2.2 (#16663) Backport #16663 Fix #16683 * Upgrade xorm to v1.2.2 * Change the Engine interface to match xorm v1.2.2 * Add test to ensure that dumping of login sources remains correct (#16847) #16831 has occurred because of a missed regression. This PR adds a simple test to try to prevent this occuring again. Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
60 lines
1.4 KiB
Go
60 lines
1.4 KiB
Go
// Copyright 2019 The Gitea Authors. All rights reserved.
|
|
// Use of this source code is governed by a MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package models
|
|
|
|
import (
|
|
"io/ioutil"
|
|
"os"
|
|
"path/filepath"
|
|
"strings"
|
|
"testing"
|
|
|
|
"code.gitea.io/gitea/modules/auth/oauth2"
|
|
"code.gitea.io/gitea/modules/setting"
|
|
"xorm.io/xorm/schemas"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestDumpDatabase(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
|
|
dir, err := ioutil.TempDir(os.TempDir(), "dump")
|
|
assert.NoError(t, err)
|
|
|
|
type Version struct {
|
|
ID int64 `xorm:"pk autoincr"`
|
|
Version int64
|
|
}
|
|
assert.NoError(t, x.Sync2(new(Version)))
|
|
|
|
for _, dbName := range setting.SupportedDatabases {
|
|
dbType := setting.GetDBTypeByName(dbName)
|
|
assert.NoError(t, DumpDatabase(filepath.Join(dir, dbType+".sql"), dbType))
|
|
}
|
|
}
|
|
|
|
func TestDumpLoginSource(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
|
|
loginSourceSchema, err := x.TableInfo(new(LoginSource))
|
|
assert.NoError(t, err)
|
|
|
|
CreateLoginSource(&LoginSource{
|
|
Type: LoginOAuth2,
|
|
Name: "TestSource",
|
|
IsActived: false,
|
|
Cfg: &OAuth2Config{
|
|
Provider: "TestSourceProvider",
|
|
CustomURLMapping: &oauth2.CustomURLMapping{},
|
|
},
|
|
})
|
|
|
|
sb := new(strings.Builder)
|
|
|
|
x.DumpTables([]*schemas.Table{loginSourceSchema}, sb)
|
|
|
|
assert.Contains(t, sb.String(), `"Provider":"TestSourceProvider"`)
|
|
}
|