Files
Pulse/internal/api/profile_suggestions_test.go
rcourtman a6a8efaa65 test: Add comprehensive test coverage across packages
New test files with expanded coverage:

API tests:
- ai_handler_test.go: AI handler unit tests with mocking
- agent_profiles_tools_test.go: Profile management tests
- alerts_endpoints_test.go: Alert API endpoint tests
- alerts_test.go: Updated for interface changes
- audit_handlers_test.go: Audit handler tests
- frontend_embed_test.go: Frontend embedding tests
- metadata_handlers_test.go, metadata_provider_test.go: Metadata tests
- notifications_test.go: Updated for interface changes
- profile_suggestions_test.go: Profile suggestion tests
- saml_service_test.go: SAML authentication tests
- sensor_proxy_gate_test.go: Sensor proxy tests
- updates_test.go: Updated for interface changes

Agent tests:
- dockeragent/signature_test.go: Docker agent signature tests
- hostagent/agent_metrics_test.go: Host agent metrics tests
- hostagent/commands_test.go: Command execution tests
- hostagent/network_helpers_test.go: Network helper tests
- hostagent/proxmox_setup_test.go: Updated setup tests
- kubernetesagent/*_test.go: Kubernetes agent tests

Core package tests:
- monitoring/kubernetes_agents_test.go, reload_test.go
- remoteconfig/client_test.go, signature_test.go
- sensors/collector_test.go
- updates/adapter_installsh_*_test.go: Install adapter tests
- updates/manager_*_test.go: Update manager tests
- websocket/hub_*_test.go: WebSocket hub tests

Library tests:
- pkg/audit/export_test.go: Audit export tests
- pkg/metrics/store_test.go: Metrics store tests
- pkg/proxmox/*_test.go: Proxmox client tests
- pkg/reporting/reporting_test.go: Reporting tests
- pkg/server/*_test.go: Server tests
- pkg/tlsutil/extra_test.go: TLS utility tests

Total: ~8000 lines of new test code
2026-01-19 19:26:18 +00:00

59 lines
1.6 KiB
Go

package api
import (
"strings"
"testing"
)
func TestParseAISuggestion(t *testing.T) {
payload := "Here is your suggestion:\n```json\n" +
`{"name":"Media Server","config":{"enable_docker":true},"rationale":["Uses Docker"]}` +
"\n```\nThanks!"
suggestion, err := parseAISuggestion(payload)
if err != nil {
t.Fatalf("parseAISuggestion error: %v", err)
}
if suggestion.Name != "Media Server" {
t.Fatalf("unexpected name: %s", suggestion.Name)
}
if suggestion.Description == "" {
t.Fatal("expected default description")
}
if suggestion.Config["enable_docker"] != true {
t.Fatalf("unexpected config: %+v", suggestion.Config)
}
if len(suggestion.Rationale) != 1 {
t.Fatalf("unexpected rationale: %+v", suggestion.Rationale)
}
payload = `{"name":"Test","description":"Has braces { in text"}`
suggestion, err = parseAISuggestion(payload)
if err != nil {
t.Fatalf("parseAISuggestion error: %v", err)
}
if suggestion.Name != "Test" || suggestion.Description != "Has braces { in text" {
t.Fatalf("unexpected suggestion: %+v", suggestion)
}
if _, err := parseAISuggestion("no json here"); err == nil {
t.Fatal("expected error without JSON")
}
if _, err := parseAISuggestion("{\"name\":"); err == nil {
t.Fatal("expected error for incomplete JSON")
}
}
func TestBuildConfigSchemaDoc(t *testing.T) {
doc := buildConfigSchemaDoc()
if doc == "" {
t.Fatal("expected schema doc")
}
if !strings.Contains(doc, "- interval (duration string") {
t.Fatalf("expected interval key in doc:\n%s", doc)
}
if !strings.Contains(doc, "enable_docker") {
t.Fatalf("expected enable_docker key in doc:\n%s", doc)
}
}