main_test.go 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. package database
  2. import (
  3. "flag"
  4. "fmt"
  5. "os"
  6. "testing"
  7. "gorm.io/gorm"
  8. "gorm.io/gorm/logger"
  9. log "unknwon.dev/clog/v2"
  10. "gogs.io/gogs/internal/conf"
  11. "gogs.io/gogs/internal/dbtest"
  12. "gogs.io/gogs/internal/testutil"
  13. )
  14. func TestMain(m *testing.M) {
  15. flag.Parse()
  16. level := logger.Silent
  17. if !testing.Verbose() {
  18. // Remove the primary logger and register a noop logger.
  19. log.Remove(log.DefaultConsoleName)
  20. err := log.New("noop", testutil.InitNoopLogger)
  21. if err != nil {
  22. fmt.Println(err)
  23. os.Exit(1)
  24. }
  25. } else {
  26. level = logger.Info
  27. }
  28. // NOTE: AutoMigrate does not respect logger passed in gorm.Config.
  29. logger.Default = logger.Default.LogMode(level)
  30. switch os.Getenv("GOGS_DATABASE_TYPE") {
  31. case "mysql":
  32. conf.UseMySQL = true
  33. case "postgres":
  34. conf.UsePostgreSQL = true
  35. default:
  36. conf.UseSQLite3 = true
  37. }
  38. os.Exit(m.Run())
  39. }
  40. func newTestDB(t *testing.T, suite string) *gorm.DB {
  41. return dbtest.NewDB(t, suite, append(Tables, legacyTables...)...)
  42. }
  43. func clearTables(t *testing.T, db *gorm.DB) error {
  44. if t.Failed() {
  45. return nil
  46. }
  47. for _, t := range append(Tables, legacyTables...) {
  48. err := db.Where("TRUE").Delete(t).Error
  49. if err != nil {
  50. return err
  51. }
  52. }
  53. return nil
  54. }