Files
Charon/backend/internal/services/uptime_service_unit_test.go
T

83 lines
2.4 KiB
Go

package services
import (
"testing"
"time"
"github.com/google/uuid"
"github.com/stretchr/testify/require"
"gorm.io/driver/sqlite"
"gorm.io/gorm"
"github.com/Wikid82/charon/backend/internal/models"
)
func setupUnitTestDB(t *testing.T) *gorm.DB {
t.Helper()
db, err := gorm.Open(sqlite.Open("file::memory:?cache=shared"), &gorm.Config{})
require.NoError(t, err)
require.NoError(t, db.AutoMigrate(&models.UptimeMonitor{}, &models.UptimeHeartbeat{}, &models.UptimeHost{}))
return db
}
func TestExtractPort(t *testing.T) {
tests := []struct {
name string
input string
expected string
}{
{"http url default", "http://example.com", "80"},
{"https url default", "https://example.com", "443"},
{"http with port", "http://example.com:8080", "8080"},
{"https with port", "https://example.com:8443", "8443"},
{"host:port", "example.com:3000", "3000"},
{"plain host", "example.com", ""},
{"localhost with port", "localhost:5000", "5000"},
{"ip with port", "192.168.1.1:9090", "9090"},
{"ipv6 with port", "[::1]:8080", "8080"},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
got := extractPort(tt.input)
require.Equal(t, tt.expected, got)
})
}
}
func TestUpdateMonitorEnabled_Unit(t *testing.T) {
db := setupUnitTestDB(t)
svc := NewUptimeService(db, nil)
monitor := models.UptimeMonitor{ID: uuid.New().String(), Name: "unit-test", URL: "http://example.com", Interval: 60, Enabled: true}
require.NoError(t, db.Create(&monitor).Error)
r, err := svc.UpdateMonitor(monitor.ID, map[string]interface{}{"enabled": false})
require.NoError(t, err)
require.False(t, r.Enabled)
var m models.UptimeMonitor
require.NoError(t, db.First(&m, "id = ?", monitor.ID).Error)
require.False(t, m.Enabled)
}
func TestDeleteMonitorDeletesHeartbeats_Unit(t *testing.T) {
db := setupUnitTestDB(t)
svc := NewUptimeService(db, nil)
monitor := models.UptimeMonitor{ID: uuid.New().String(), Name: "unit-delete", URL: "http://example.com", Interval: 60, Enabled: true}
require.NoError(t, db.Create(&monitor).Error)
hb := models.UptimeHeartbeat{MonitorID: monitor.ID, Status: "up", Latency: 10, CreatedAt: time.Now()}
require.NoError(t, db.Create(&hb).Error)
require.NoError(t, svc.DeleteMonitor(monitor.ID))
var m models.UptimeMonitor
require.Error(t, db.First(&m, "id = ?", monitor.ID).Error)
var count int64
db.Model(&models.UptimeHeartbeat{}).Where("monitor_id = ?", monitor.ID).Count(&count)
require.Equal(t, int64(0), count)
}