mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 12:01:08 +00:00 
			
		
		
		
	[TESTS] tests.AddFixtures helper loads additional per-test fixtures
(cherry picked from commit93a844dd13) (cherry picked from commit6d6d1a121c) (cherry picked from commit34646f9886) (cherry picked from commit83801a64cf) (cherry picked from commitc9a1e55a80) (cherry picked from commit6c7292419c)
This commit is contained in:
		
					parent
					
						
							
								a448744b7b
							
						
					
				
			
			
				commit
				
					
						5439218f1a
					
				
			
		
					 3 changed files with 30 additions and 0 deletions
				
			
		|  | @ -7,6 +7,7 @@ package unittest | |||
| import ( | ||||
| 	"fmt" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"code.gitea.io/gitea/models/db" | ||||
|  | @ -28,6 +29,16 @@ func GetXORMEngine(engine ...*xorm.Engine) (x *xorm.Engine) { | |||
| 	return db.DefaultContext.(*db.Context).Engine().(*xorm.Engine) | ||||
| } | ||||
| 
 | ||||
| func OverrideFixtures(opts FixturesOptions, engine ...*xorm.Engine) func() { | ||||
| 	old := fixturesLoader | ||||
| 	if err := InitFixtures(opts, engine...); err != nil { | ||||
| 		panic(err) | ||||
| 	} | ||||
| 	return func() { | ||||
| 		fixturesLoader = old | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // InitFixtures initialize test fixtures for a test database | ||||
| func InitFixtures(opts FixturesOptions, engine ...*xorm.Engine) (err error) { | ||||
| 	e := GetXORMEngine(engine...) | ||||
|  | @ -37,6 +48,12 @@ func InitFixtures(opts FixturesOptions, engine ...*xorm.Engine) (err error) { | |||
| 	} else { | ||||
| 		fixtureOptionFiles = testfixtures.Files(opts.Files...) | ||||
| 	} | ||||
| 	var fixtureOptionDirs []func(*testfixtures.Loader) error | ||||
| 	if opts.Dirs != nil { | ||||
| 		for _, dir := range opts.Dirs { | ||||
| 			fixtureOptionDirs = append(fixtureOptionDirs, testfixtures.Directory(filepath.Join(opts.Base, dir))) | ||||
| 		} | ||||
| 	} | ||||
| 	dialect := "unknown" | ||||
| 	switch e.Dialect().URI().DBType { | ||||
| 	case schemas.POSTGRES: | ||||
|  | @ -57,6 +74,7 @@ func InitFixtures(opts FixturesOptions, engine ...*xorm.Engine) (err error) { | |||
| 		testfixtures.DangerousSkipTestDatabaseCheck(), | ||||
| 		fixtureOptionFiles, | ||||
| 	} | ||||
| 	loaderOptions = append(loaderOptions, fixtureOptionDirs...) | ||||
| 
 | ||||
| 	if e.Dialect().URI().DBType == schemas.POSTGRES { | ||||
| 		loaderOptions = append(loaderOptions, testfixtures.SkipResetSequences()) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue