main_test.go 1.2 KB

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