mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2025-01-05 10:20:36 +02:00
071bd7418a
* fix pipeline * use EqualStringSlice to compare slices in tests * full test coverage * tests: wait for mysql/postgres to sync ...
80 lines
2.0 KiB
Go
80 lines
2.0 KiB
Go
// Copyright 2021 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.
|
|
|
|
package datastore
|
|
|
|
import (
|
|
"os"
|
|
"testing"
|
|
"time"
|
|
|
|
"xorm.io/xorm"
|
|
"xorm.io/xorm/schemas"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func testDriverConfig() (driver, config string) {
|
|
driver = "sqlite3"
|
|
config = ":memory:"
|
|
|
|
if os.Getenv("WOODPECKER_DATABASE_DRIVER") != "" {
|
|
driver = os.Getenv("WOODPECKER_DATABASE_DRIVER")
|
|
config = os.Getenv("WOODPECKER_DATABASE_DATASOURCE")
|
|
}
|
|
return
|
|
}
|
|
|
|
// newTestStore creates a new database connection for testing purposes.
|
|
// The database driver and connection string are provided by
|
|
// environment variables, with fallback to in-memory sqlite.
|
|
func newTestStore(t *testing.T, tables ...interface{}) (*storage, func()) {
|
|
engine, err := xorm.NewEngine(testDriverConfig())
|
|
if !assert.NoError(t, err) {
|
|
t.FailNow()
|
|
}
|
|
|
|
for _, table := range tables {
|
|
if err := engine.Sync2(table); err != nil {
|
|
t.Error(err)
|
|
t.FailNow()
|
|
}
|
|
}
|
|
|
|
return &storage{
|
|
engine: engine,
|
|
}, func() {
|
|
for _, bean := range tables {
|
|
if err := engine.DropIndexes(bean); err != nil {
|
|
t.Error(err)
|
|
t.FailNow()
|
|
}
|
|
}
|
|
if err := engine.DropTables(tables...); err != nil {
|
|
t.Error(err)
|
|
t.FailNow()
|
|
}
|
|
if err := engine.Close(); err != nil {
|
|
t.Error(err)
|
|
t.FailNow()
|
|
}
|
|
|
|
dbType := engine.Dialect().URI().DBType
|
|
if dbType == schemas.MYSQL || dbType == schemas.POSTGRES {
|
|
// wait for mysql/postgres to sync ...
|
|
time.Sleep(10 * time.Millisecond)
|
|
}
|
|
}
|
|
}
|