2016-12-29 04:03:40 +03:00
// Copyright 2016 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 (
2017-11-30 18:52:15 +03:00
"fmt"
2017-09-21 10:43:26 +03:00
"os"
2017-11-30 18:52:15 +03:00
"path/filepath"
2016-12-29 04:03:40 +03:00
"testing"
2017-09-21 10:43:26 +03:00
"code.gitea.io/gitea/modules/setting"
"github.com/Unknwon/com"
2017-08-03 08:09:16 +03:00
"github.com/go-xorm/core"
2016-12-29 04:03:40 +03:00
"github.com/go-xorm/xorm"
2017-01-08 06:10:53 +03:00
"github.com/stretchr/testify/assert"
2017-08-03 08:09:16 +03:00
"gopkg.in/testfixtures.v2"
2016-12-29 04:03:40 +03:00
)
2017-05-20 11:48:22 +03:00
// NonexistentID an ID that will never exist
2017-01-25 13:37:35 +03:00
const NonexistentID = 9223372036854775807
2017-11-30 18:52:15 +03:00
// giteaRoot a path to the gitea root
var giteaRoot string
// MainTest a reusable TestMain(..) function for unit tests that need to use a
// test database. Creates the test database, and sets necessary settings.
func MainTest ( m * testing . M , pathToGiteaRoot string ) {
giteaRoot = pathToGiteaRoot
fixturesDir := filepath . Join ( pathToGiteaRoot , "models" , "fixtures" )
if err := createTestEngine ( fixturesDir ) ; err != nil {
fmt . Fprintf ( os . Stderr , "Error creating test engine: %v\n" , err )
os . Exit ( 1 )
}
setting . AppURL = "https://try.gitea.io/"
setting . RunUser = "runuser"
setting . SSH . Port = 3000
setting . SSH . Domain = "try.gitea.io"
setting . RepoRootPath = filepath . Join ( os . TempDir ( ) , "repos" )
setting . AppDataPath = filepath . Join ( os . TempDir ( ) , "appdata" )
os . Exit ( m . Run ( ) )
}
func createTestEngine ( fixturesDir string ) error {
2017-08-03 08:09:16 +03:00
var err error
x , err = xorm . NewEngine ( "sqlite3" , "file::memory:?cache=shared" )
if err != nil {
return err
}
x . SetMapper ( core . GonicMapper { } )
if err = x . StoreEngine ( "InnoDB" ) . Sync2 ( tables ... ) ; err != nil {
return err
}
2017-11-27 13:29:48 +03:00
switch os . Getenv ( "GITEA_UNIT_TESTS_VERBOSE" ) {
case "true" , "1" :
x . ShowSQL ( true )
}
2017-08-03 08:09:16 +03:00
return InitFixtures ( & testfixtures . SQLite { } , fixturesDir )
}
2016-12-29 04:03:40 +03:00
// PrepareTestDatabase load test fixtures into test database
func PrepareTestDatabase ( ) error {
2017-04-25 10:24:51 +03:00
return LoadFixtures ( )
2016-12-29 04:03:40 +03:00
}
2017-01-08 06:10:53 +03:00
2017-11-30 18:52:15 +03:00
// PrepareTestEnv prepares the environment for unit tests. Can only be called
// by tests that use the above MainTest(..) function.
func PrepareTestEnv ( t testing . TB ) {
2017-09-21 10:43:26 +03:00
assert . NoError ( t , PrepareTestDatabase ( ) )
assert . NoError ( t , os . RemoveAll ( setting . RepoRootPath ) )
2017-11-30 18:52:15 +03:00
metaPath := filepath . Join ( giteaRoot , "integrations" , "gitea-repositories-meta" )
assert . NoError ( t , com . CopyDir ( metaPath , setting . RepoRootPath ) )
2017-09-21 10:43:26 +03:00
}
2017-06-15 06:09:03 +03:00
type testCond struct {
query interface { }
args [ ] interface { }
}
// Cond create a condition with arguments for a test
func Cond ( query interface { } , args ... interface { } ) interface { } {
return & testCond { query : query , args : args }
}
func whereConditions ( sess * xorm . Session , conditions [ ] interface { } ) {
for _ , condition := range conditions {
switch cond := condition . ( type ) {
case * testCond :
sess . Where ( cond . query , cond . args ... )
default :
sess . Where ( cond )
}
}
}
2017-01-09 06:08:36 +03:00
func loadBeanIfExists ( bean interface { } , conditions ... interface { } ) ( bool , error ) {
2017-01-08 06:10:53 +03:00
sess := x . NewSession ( )
defer sess . Close ( )
2017-06-15 06:09:03 +03:00
whereConditions ( sess , conditions )
2017-01-09 06:08:36 +03:00
return sess . Get ( bean )
}
2017-01-24 19:16:36 +03:00
// BeanExists for testing, check if a bean exists
func BeanExists ( t * testing . T , bean interface { } , conditions ... interface { } ) bool {
exists , err := loadBeanIfExists ( bean , conditions ... )
assert . NoError ( t , err )
return exists
}
2017-01-09 06:08:36 +03:00
// AssertExistsAndLoadBean assert that a bean exists and load it from the test
// database
2017-01-25 05:49:51 +03:00
func AssertExistsAndLoadBean ( t * testing . T , bean interface { } , conditions ... interface { } ) interface { } {
2017-01-09 06:08:36 +03:00
exists , err := loadBeanIfExists ( bean , conditions ... )
assert . NoError ( t , err )
2017-02-04 15:37:26 +03:00
assert . True ( t , exists ,
2017-02-07 14:47:55 +03:00
"Expected to find %+v (of type %T, with conditions %+v), but did not" ,
bean , bean , conditions )
2017-01-25 05:49:51 +03:00
return bean
2017-01-09 06:08:36 +03:00
}
2017-06-15 06:09:03 +03:00
// GetCount get the count of a bean
func GetCount ( t * testing . T , bean interface { } , conditions ... interface { } ) int {
sess := x . NewSession ( )
defer sess . Close ( )
whereConditions ( sess , conditions )
count , err := sess . Count ( bean )
assert . NoError ( t , err )
return int ( count )
}
2017-01-09 06:08:36 +03:00
// AssertNotExistsBean assert that a bean does not exist in the test database
func AssertNotExistsBean ( t * testing . T , bean interface { } , conditions ... interface { } ) {
exists , err := loadBeanIfExists ( bean , conditions ... )
2017-01-08 06:10:53 +03:00
assert . NoError ( t , err )
2017-01-09 06:08:36 +03:00
assert . False ( t , exists )
2017-01-08 06:10:53 +03:00
}
2017-02-04 15:37:26 +03:00
// AssertSuccessfulInsert assert that beans is successfully inserted
func AssertSuccessfulInsert ( t * testing . T , beans ... interface { } ) {
_ , err := x . Insert ( beans ... )
assert . NoError ( t , err )
}
2017-02-28 04:35:55 +03:00
// AssertCount assert the count of a bean
func AssertCount ( t * testing . T , bean interface { } , expected interface { } ) {
2017-06-15 06:09:03 +03:00
assert . EqualValues ( t , expected , GetCount ( t , bean ) )
2017-02-04 15:37:26 +03:00
}
2017-07-27 04:20:38 +03:00
// AssertInt64InRange assert value is in range [low, high]
func AssertInt64InRange ( t * testing . T , low , high , value int64 ) {
assert . True ( t , value >= low && value <= high ,
"Expected value in range [%d, %d], found %d" , low , high , value )
}