api_token_timestamp_test.go 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. package database
  2. import (
  3. "testing"
  4. "github.com/mhsanaei/3x-ui/v3/internal/database/model"
  5. "gorm.io/driver/sqlite"
  6. "gorm.io/gorm"
  7. "gorm.io/gorm/logger"
  8. )
  9. func TestNormalizeApiTokenCreatedAtSeconds(t *testing.T) {
  10. originalDB := db
  11. t.Cleanup(func() { db = originalDB })
  12. var err error
  13. db, err = gorm.Open(sqlite.Open(":memory:"), &gorm.Config{Logger: logger.Discard})
  14. if err != nil {
  15. t.Fatalf("open sqlite: %v", err)
  16. }
  17. if err := db.AutoMigrate(&model.ApiToken{}); err != nil {
  18. t.Fatalf("migrate api_tokens: %v", err)
  19. }
  20. rows := []model.ApiToken{
  21. {Name: "seconds", Token: "a", CreatedAt: 1_782_485_394},
  22. {Name: "milliseconds", Token: "b", CreatedAt: 1_782_485_394_270},
  23. }
  24. if err := db.Create(&rows).Error; err != nil {
  25. t.Fatalf("seed api tokens: %v", err)
  26. }
  27. if err := normalizeApiTokenCreatedAtSeconds(); err != nil {
  28. t.Fatalf("normalize timestamps: %v", err)
  29. }
  30. if err := normalizeApiTokenCreatedAtSeconds(); err != nil {
  31. t.Fatalf("normalize timestamps again: %v", err)
  32. }
  33. var got []model.ApiToken
  34. if err := db.Order("id asc").Find(&got).Error; err != nil {
  35. t.Fatalf("read api tokens: %v", err)
  36. }
  37. for _, row := range got {
  38. if row.CreatedAt != 1_782_485_394 {
  39. t.Fatalf("%s created_at = %d, want seconds", row.Name, row.CreatedAt)
  40. }
  41. }
  42. }