mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-24 13:53:42 +09:00 
			
		
		
		
	Improve testing and try to fix MySQL hanging (#32515)
By some CI fine tunes (`run tests`), SQLite & MSSQL could complete in about 12~13 minutes (before > 14), MySQL could complete in 18 minutes (before: about 23 or even > 30) Major changes: 1. use tmpfs for MySQL storage 1. run `make test-mysql` instead of `make integration-test-coverage` because the code coverage is not really used at the moment. 1. refactor testlogger to make it more reliable and be able to report stuck stacktrace 1. do not requeue failed items when a queue is being flushed (failed items would keep failing and make flush uncompleted) 1. reduce the file sizes for testing 1. use math ChaCha20 random data instead of crypot/rand (for testing purpose only) 1. no need to `DeleteRepository` in `TestLinguist` 1. other related refactoring to make code easier to maintain
This commit is contained in:
		| @@ -29,17 +29,12 @@ import ( | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| ) | ||||
|  | ||||
| func exitf(format string, args ...any) { | ||||
| 	fmt.Printf(format+"\n", args...) | ||||
| 	os.Exit(1) | ||||
| } | ||||
|  | ||||
| func InitTest(requireGitea bool) { | ||||
| 	log.RegisterEventWriter("test", testlogger.NewTestLoggerWriter) | ||||
| 	testlogger.Init() | ||||
|  | ||||
| 	giteaRoot := base.SetupGiteaRoot() | ||||
| 	if giteaRoot == "" { | ||||
| 		exitf("Environment variable $GITEA_ROOT not set") | ||||
| 		testlogger.Fatalf("Environment variable $GITEA_ROOT not set\n") | ||||
| 	} | ||||
|  | ||||
| 	// TODO: Speedup tests that rely on the event source ticker, confirm whether there is any bug or failure. | ||||
| @@ -54,7 +49,7 @@ func InitTest(requireGitea bool) { | ||||
| 		} | ||||
| 		setting.AppPath = filepath.Join(giteaRoot, giteaBinary) | ||||
| 		if _, err := os.Stat(setting.AppPath); err != nil { | ||||
| 			exitf("Could not find gitea binary at %s", setting.AppPath) | ||||
| 			testlogger.Fatalf("Could not find gitea binary at %s\n", setting.AppPath) | ||||
| 		} | ||||
| 	} | ||||
| 	giteaConf := os.Getenv("GITEA_CONF") | ||||
| @@ -66,7 +61,7 @@ func InitTest(requireGitea bool) { | ||||
| 		_ = os.Setenv("GITEA_CONF", giteaConf) | ||||
| 		fmt.Printf("Environment variable $GITEA_CONF not set, use default: %s\n", giteaConf) | ||||
| 		if !setting.EnableSQLite3 { | ||||
| 			exitf(`sqlite3 requires: import _ "github.com/mattn/go-sqlite3" or -tags sqlite,sqlite_unlock_notify`) | ||||
| 			testlogger.Fatalf(`sqlite3 requires: import _ "github.com/mattn/go-sqlite3" or -tags sqlite,sqlite_unlock_notify` + "\n") | ||||
| 		} | ||||
| 	} | ||||
| 	if !filepath.IsAbs(giteaConf) { | ||||
| @@ -85,7 +80,7 @@ func InitTest(requireGitea bool) { | ||||
|  | ||||
| 	setting.LoadDBSetting() | ||||
| 	if err := storage.Init(); err != nil { | ||||
| 		exitf("Init storage failed: %v", err) | ||||
| 		testlogger.Fatalf("Init storage failed: %v\n", err) | ||||
| 	} | ||||
|  | ||||
| 	switch { | ||||
| @@ -258,8 +253,3 @@ func PrintCurrentTest(t testing.TB, skip ...int) func() { | ||||
| 	t.Helper() | ||||
| 	return testlogger.PrintCurrentTest(t, util.OptionalArg(skip)+1) | ||||
| } | ||||
|  | ||||
| // Printf takes a format and args and prints the string to os.Stdout | ||||
| func Printf(format string, args ...any) { | ||||
| 	testlogger.Printf(format, args...) | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user