Files
Charon/backend/internal/services/uptime_service_notification_test.go
T
GitHub Actions 3169b05156 fix: skip incomplete system log viewer tests
- Marked 12 tests as skip pending feature implementation
- Features tracked in GitHub issue #686 (system log viewer feature completion)
- Tests cover sorting by timestamp/level/method/URI/status, pagination controls, filtering by text/level, download functionality
- Unblocks Phase 2 at 91.7% pass rate to proceed to Phase 3 security enforcement validation
- TODO comments in code reference GitHub #686 for feature completion tracking
- Tests skipped: Pagination (3), Search/Filter (2), Download (2), Sorting (1), Log Display (4)
2026-02-09 21:55:55 +00:00

36 lines
1.0 KiB
Go

package services
import (
"testing"
"github.com/Wikid82/charon/backend/internal/models"
"github.com/google/uuid"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"gorm.io/driver/sqlite"
"gorm.io/gorm"
)
func TestUptimeService_sendRecoveryNotification(t *testing.T) {
t.Parallel()
db, err := gorm.Open(sqlite.Open("file:"+uuid.NewString()+"?mode=memory&cache=shared"), &gorm.Config{})
require.NoError(t, err)
require.NoError(t, db.AutoMigrate(&models.Notification{}, &models.NotificationProvider{}))
ns := NewNotificationService(db)
svc := NewUptimeService(db, ns)
monitor := models.UptimeMonitor{Name: "API Server", URL: "https://api.example.com"}
svc.sendRecoveryNotification(monitor, "5m")
var notifications []models.Notification
require.NoError(t, db.Find(&notifications).Error)
require.Len(t, notifications, 1)
assert.Contains(t, notifications[0].Title, "API Server")
assert.Contains(t, notifications[0].Message, "Downtime: 5m")
assert.Equal(t, models.NotificationTypeSuccess, notifications[0].Type)
}