Pulse/internal/updates/adapter_installsh_execute_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

119 lines
2.8 KiB
Go

package updates
import (
"context"
"crypto/sha256"
"encoding/hex"
"os"
"path/filepath"
"strings"
"testing"
)
func setupInstallShCurlStub(t *testing.T, content string) string {
t.Helper()
sum := sha256.Sum256([]byte(content))
checksum := hex.EncodeToString(sum[:])
dir := t.TempDir()
curl := filepath.Join(dir, "curl")
script := strings.Join([]string{
"#!/bin/sh",
`out=""`,
`url=""`,
`while [ "$#" -gt 0 ]; do`,
` if [ "$1" = "-o" ]; then`,
` out="$2"`,
` shift 2`,
` continue`,
` fi`,
` url="$1"`,
` shift`,
`done`,
`if echo "$url" | grep -q ".sha256$"; then`,
` echo "` + checksum + ` install.sh" > "$out"`,
`else`,
` printf '%s' "` + content + `" > "$out"`,
`fi`,
``,
}, "\n")
if err := os.WriteFile(curl, []byte(script), 0755); err != nil {
t.Fatalf("write curl stub: %v", err)
}
return dir
}
func setupBashStub(t *testing.T) string {
t.Helper()
dir := t.TempDir()
bash := filepath.Join(dir, "bash")
script := strings.Join([]string{
"#!/bin/sh",
"cat >/dev/null",
"echo \"Backup: /tmp/backup\"",
"echo \"Installing\"",
"echo \"Success\"",
"exit 0",
"",
}, "\n")
if err := os.WriteFile(bash, []byte(script), 0755); err != nil {
t.Fatalf("write bash stub: %v", err)
}
return dir
}
func TestInstallShAdapterExecuteSuccess(t *testing.T) {
scriptContent := "echo ok"
curlDir := setupInstallShCurlStub(t, scriptContent)
bashDir := setupBashStub(t)
t.Setenv("PATH", strings.Join([]string{curlDir, bashDir, os.Getenv("PATH")}, string(os.PathListSeparator)))
adapter := &InstallShAdapter{
installScriptURL: "http://example/install.sh",
logDir: t.TempDir(),
}
var updates []UpdateProgress
progress := func(p UpdateProgress) {
updates = append(updates, p)
}
err := adapter.Execute(context.Background(), UpdateRequest{Version: "v1.2.3"}, progress)
if err != nil {
t.Fatalf("Execute error: %v", err)
}
if len(updates) == 0 {
t.Fatal("expected progress updates")
}
foundCompleted := false
for _, progress := range updates {
if progress.Stage == "completed" && progress.IsComplete {
foundCompleted = true
break
}
}
if !foundCompleted {
t.Fatalf("expected completed progress, got %+v", updates)
}
}
func TestInstallShAdapterExecuteInvalidVersion(t *testing.T) {
scriptContent := "echo ok"
curlDir := setupInstallShCurlStub(t, scriptContent)
t.Setenv("PATH", curlDir+string(os.PathListSeparator)+os.Getenv("PATH"))
adapter := &InstallShAdapter{
installScriptURL: "http://example/install.sh",
logDir: t.TempDir(),
}
err := adapter.Execute(context.Background(), UpdateRequest{Version: "bad version"}, func(UpdateProgress) {})
if err == nil {
t.Fatal("expected error for invalid version")
}
if !strings.Contains(err.Error(), "invalid version format") {
t.Fatalf("unexpected error: %v", err)
}
}