2023-08-10 09:06:00 +00:00
|
|
|
// Copyright 2023 Woodpecker Authors
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2021-12-20 15:15:21 +00:00
|
|
|
package migration
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"testing"
|
2022-01-31 13:39:53 +00:00
|
|
|
"time"
|
2021-12-20 15:15:21 +00:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"xorm.io/xorm"
|
2022-01-31 13:39:53 +00:00
|
|
|
"xorm.io/xorm/schemas"
|
2021-12-20 15:15:21 +00:00
|
|
|
|
|
|
|
// blank imports to register the sql drivers
|
|
|
|
_ "github.com/go-sql-driver/mysql"
|
|
|
|
_ "github.com/lib/pq"
|
|
|
|
_ "github.com/mattn/go-sqlite3"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
sqliteDB = "./testfiles/sqlite.db"
|
|
|
|
)
|
|
|
|
|
|
|
|
func testDriver() string {
|
|
|
|
driver := os.Getenv("WOODPECKER_DATABASE_DRIVER")
|
|
|
|
if len(driver) == 0 {
|
|
|
|
return "sqlite3"
|
|
|
|
}
|
|
|
|
return driver
|
|
|
|
}
|
|
|
|
|
|
|
|
func createSQLiteDB(t *testing.T) string {
|
2022-08-29 23:14:07 +00:00
|
|
|
tmpF, err := os.CreateTemp("./testfiles", "tmp_")
|
2021-12-20 15:15:21 +00:00
|
|
|
if !assert.NoError(t, err) {
|
|
|
|
t.FailNow()
|
|
|
|
}
|
2022-08-29 23:14:07 +00:00
|
|
|
dbF, err := os.ReadFile(sqliteDB)
|
2021-12-20 15:15:21 +00:00
|
|
|
if !assert.NoError(t, err) {
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
|
2022-08-29 23:14:07 +00:00
|
|
|
if !assert.NoError(t, os.WriteFile(tmpF.Name(), dbF, 0o644)) {
|
2021-12-20 15:15:21 +00:00
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
return tmpF.Name()
|
|
|
|
}
|
|
|
|
|
2023-03-18 19:35:27 +00:00
|
|
|
func testDB(t *testing.T, new bool) (engine *xorm.Engine, closeDB func()) {
|
2021-12-20 15:15:21 +00:00
|
|
|
driver := testDriver()
|
|
|
|
var err error
|
2023-03-18 19:35:27 +00:00
|
|
|
closeDB = func() {}
|
2021-12-20 15:15:21 +00:00
|
|
|
switch driver {
|
|
|
|
case "sqlite3":
|
|
|
|
config := ":memory:"
|
|
|
|
if !new {
|
|
|
|
config = createSQLiteDB(t)
|
2023-03-18 19:35:27 +00:00
|
|
|
closeDB = func() {
|
2021-12-20 15:15:21 +00:00
|
|
|
_ = os.Remove(config)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
engine, err = xorm.NewEngine(driver, config)
|
|
|
|
if !assert.NoError(t, err) {
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
return
|
|
|
|
case "mysql", "postgres":
|
|
|
|
config := os.Getenv("WOODPECKER_DATABASE_DATASOURCE")
|
|
|
|
if !new {
|
|
|
|
t.Logf("do not have dump to test against")
|
|
|
|
t.SkipNow()
|
|
|
|
}
|
|
|
|
engine, err = xorm.NewEngine(driver, config)
|
|
|
|
if !assert.NoError(t, err) {
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
return
|
|
|
|
default:
|
|
|
|
t.Errorf("unsupported driver: %s", driver)
|
|
|
|
t.FailNow()
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestMigrate(t *testing.T) {
|
2022-01-31 14:50:10 +00:00
|
|
|
// make all tasks required for tests
|
|
|
|
for _, task := range migrationTasks {
|
|
|
|
task.required = true
|
|
|
|
}
|
|
|
|
|
2021-12-20 15:15:21 +00:00
|
|
|
// init new db
|
2023-03-18 19:35:27 +00:00
|
|
|
engine, closeDB := testDB(t, true)
|
2021-12-20 15:15:21 +00:00
|
|
|
assert.NoError(t, Migrate(engine))
|
2023-03-18 19:35:27 +00:00
|
|
|
closeDB()
|
2021-12-20 15:15:21 +00:00
|
|
|
|
2022-01-31 13:39:53 +00:00
|
|
|
dbType := engine.Dialect().URI().DBType
|
|
|
|
if dbType == schemas.MYSQL || dbType == schemas.POSTGRES {
|
|
|
|
// wait for mysql/postgres to sync ...
|
|
|
|
time.Sleep(100 * time.Millisecond)
|
|
|
|
}
|
|
|
|
|
2021-12-20 15:15:21 +00:00
|
|
|
// migrate old db
|
2023-03-18 19:35:27 +00:00
|
|
|
engine, closeDB = testDB(t, false)
|
2021-12-20 15:15:21 +00:00
|
|
|
assert.NoError(t, Migrate(engine))
|
2023-03-18 19:35:27 +00:00
|
|
|
closeDB()
|
2021-12-20 15:15:21 +00:00
|
|
|
}
|