| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- package database
- import (
- "testing"
- "github.com/mhsanaei/3x-ui/v3/internal/database/model"
- "gorm.io/driver/sqlite"
- "gorm.io/gorm"
- "gorm.io/gorm/logger"
- )
- func TestNormalizeApiTokenCreatedAtSeconds(t *testing.T) {
- originalDB := db
- t.Cleanup(func() { db = originalDB })
- var err error
- db, err = gorm.Open(sqlite.Open(":memory:"), &gorm.Config{Logger: logger.Discard})
- if err != nil {
- t.Fatalf("open sqlite: %v", err)
- }
- if err := db.AutoMigrate(&model.ApiToken{}); err != nil {
- t.Fatalf("migrate api_tokens: %v", err)
- }
- rows := []model.ApiToken{
- {Name: "seconds", Token: "a", CreatedAt: 1_782_485_394},
- {Name: "milliseconds", Token: "b", CreatedAt: 1_782_485_394_270},
- }
- if err := db.Create(&rows).Error; err != nil {
- t.Fatalf("seed api tokens: %v", err)
- }
- if err := normalizeApiTokenCreatedAtSeconds(); err != nil {
- t.Fatalf("normalize timestamps: %v", err)
- }
- if err := normalizeApiTokenCreatedAtSeconds(); err != nil {
- t.Fatalf("normalize timestamps again: %v", err)
- }
- var got []model.ApiToken
- if err := db.Order("id asc").Find(&got).Error; err != nil {
- t.Fatalf("read api tokens: %v", err)
- }
- for _, row := range got {
- if row.CreatedAt != 1_782_485_394 {
- t.Fatalf("%s created_at = %d, want seconds", row.Name, row.CreatedAt)
- }
- }
- }
|