mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Refactor the setting to make unit test easier (#22405)
Some bugs caused by less unit tests in fundamental packages. This PR refactor `setting` package so that create a unit test will be easier than before. - All `LoadFromXXX` files has been splited as two functions, one is `InitProviderFromXXX` and `LoadCommonSettings`. The first functions will only include the code to create or new a ini file. The second function will load common settings. - It also renames all functions in setting from `newXXXService` to `loadXXXSetting` or `loadXXXFrom` to make the function name less confusing. - Move `XORMLog` to `SQLLog` because it's a better name for that. Maybe we should finally move these `loadXXXSetting` into the `XXXInit` function? Any idea? --------- Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: delvh <dev.lh@web.de>
This commit is contained in:
		
							
								
								
									
										20
									
								
								cmd/dump.go
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								cmd/dump.go
									
									
									
									
									
								
							| @@ -181,20 +181,22 @@ func runDump(ctx *cli.Context) error { | ||||
| 		} | ||||
| 		fileName += "." + outType | ||||
| 	} | ||||
| 	setting.LoadFromExisting() | ||||
| 	setting.InitProviderFromExistingFile() | ||||
| 	setting.LoadCommonSettings() | ||||
|  | ||||
| 	// make sure we are logging to the console no matter what the configuration tells us do to | ||||
| 	if _, err := setting.Cfg.Section("log").NewKey("MODE", "console"); err != nil { | ||||
| 	// FIXME: don't use CfgProvider directly | ||||
| 	if _, err := setting.CfgProvider.Section("log").NewKey("MODE", "console"); err != nil { | ||||
| 		fatal("Setting logging mode to console failed: %v", err) | ||||
| 	} | ||||
| 	if _, err := setting.Cfg.Section("log.console").NewKey("STDERR", "true"); err != nil { | ||||
| 	if _, err := setting.CfgProvider.Section("log.console").NewKey("STDERR", "true"); err != nil { | ||||
| 		fatal("Setting console logger to stderr failed: %v", err) | ||||
| 	} | ||||
| 	if !setting.InstallLock { | ||||
| 		log.Error("Is '%s' really the right config path?\n", setting.CustomConf) | ||||
| 		return fmt.Errorf("gitea is not initialized") | ||||
| 	} | ||||
| 	setting.NewServices() // cannot access session settings otherwise | ||||
| 	setting.LoadSettings() // cannot access session settings otherwise | ||||
|  | ||||
| 	stdCtx, cancel := installSignals() | ||||
| 	defer cancel() | ||||
| @@ -322,7 +324,7 @@ func runDump(ctx *cli.Context) error { | ||||
| 		log.Info("Packing data directory...%s", setting.AppDataPath) | ||||
|  | ||||
| 		var excludes []string | ||||
| 		if setting.Cfg.Section("session").Key("PROVIDER").Value() == "file" { | ||||
| 		if setting.SessionConfig.OriginalProvider == "file" { | ||||
| 			var opts session.Options | ||||
| 			if err = json.Unmarshal([]byte(setting.SessionConfig.ProviderConfig), &opts); err != nil { | ||||
| 				return err | ||||
| @@ -339,7 +341,7 @@ func runDump(ctx *cli.Context) error { | ||||
| 		excludes = append(excludes, setting.LFS.Path) | ||||
| 		excludes = append(excludes, setting.Attachment.Path) | ||||
| 		excludes = append(excludes, setting.Packages.Path) | ||||
| 		excludes = append(excludes, setting.LogRootPath) | ||||
| 		excludes = append(excludes, setting.Log.RootPath) | ||||
| 		excludes = append(excludes, absFileName) | ||||
| 		if err := addRecursiveExclude(w, "data", setting.AppDataPath, excludes, verbose); err != nil { | ||||
| 			fatal("Failed to include data directory: %v", err) | ||||
| @@ -378,12 +380,12 @@ func runDump(ctx *cli.Context) error { | ||||
| 	if ctx.IsSet("skip-log") && ctx.Bool("skip-log") { | ||||
| 		log.Info("Skip dumping log files") | ||||
| 	} else { | ||||
| 		isExist, err := util.IsExist(setting.LogRootPath) | ||||
| 		isExist, err := util.IsExist(setting.Log.RootPath) | ||||
| 		if err != nil { | ||||
| 			log.Error("Unable to check if %s exists. Error: %v", setting.LogRootPath, err) | ||||
| 			log.Error("Unable to check if %s exists. Error: %v", setting.Log.RootPath, err) | ||||
| 		} | ||||
| 		if isExist { | ||||
| 			if err := addRecursiveExclude(w, "log", setting.LogRootPath, []string{absFileName}, verbose); err != nil { | ||||
| 			if err := addRecursiveExclude(w, "log", setting.Log.RootPath, []string{absFileName}, verbose); err != nil { | ||||
| 				fatal("Failed to include log: %v", err) | ||||
| 			} | ||||
| 		} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user