Files
Charon/backend/internal/services/remoteserver_service_test.go
T
akanealw eec8c28fb3
Go Benchmark / Performance Regression Check (push) Has been cancelled
Cerberus Integration / Cerberus Security Stack Integration (push) Has been cancelled
Upload Coverage to Codecov / Backend Codecov Upload (push) Has been cancelled
Upload Coverage to Codecov / Frontend Codecov Upload (push) Has been cancelled
CodeQL - Analyze / CodeQL analysis (go) (push) Has been cancelled
CodeQL - Analyze / CodeQL analysis (javascript-typescript) (push) Has been cancelled
CrowdSec Integration / CrowdSec Bouncer Integration (push) Has been cancelled
Docker Build, Publish & Test / build-and-push (push) Has been cancelled
Quality Checks / Auth Route Protection Contract (push) Has been cancelled
Quality Checks / Codecov Trigger/Comment Parity Guard (push) Has been cancelled
Quality Checks / Backend (Go) (push) Has been cancelled
Quality Checks / Frontend (React) (push) Has been cancelled
Rate Limit integration / Rate Limiting Integration (push) Has been cancelled
Security Scan (PR) / Trivy Binary Scan (push) Has been cancelled
Supply Chain Verification (PR) / Verify Supply Chain (push) Has been cancelled
WAF integration / Coraza WAF Integration (push) Has been cancelled
Docker Build, Publish & Test / Security Scan PR Image (push) Has been cancelled
Repo Health Check / Repo health (push) Has been cancelled
History Rewrite Dry-Run / Dry-run preview for history rewrite (push) Has been cancelled
Prune Renovate Branches / prune (push) Has been cancelled
Renovate / renovate (push) Has been cancelled
Nightly Build & Package / sync-development-to-nightly (push) Has been cancelled
Nightly Build & Package / Trigger Nightly Validation Workflows (push) Has been cancelled
Nightly Build & Package / build-and-push-nightly (push) Has been cancelled
Nightly Build & Package / test-nightly-image (push) Has been cancelled
Nightly Build & Package / verify-nightly-supply-chain (push) Has been cancelled
Update GeoLite2 Checksum / update-checksum (push) Has been cancelled
Container Registry Prune / prune-ghcr (push) Has been cancelled
Container Registry Prune / prune-dockerhub (push) Has been cancelled
Container Registry Prune / summarize (push) Has been cancelled
Supply Chain Verification / Verify SBOM (push) Has been cancelled
Supply Chain Verification / Verify Release Artifacts (push) Has been cancelled
Supply Chain Verification / Verify Docker Image Supply Chain (push) Has been cancelled
Monitor Caddy Major Release / check-caddy-major (push) Has been cancelled
Weekly Nightly to Main Promotion / Verify Nightly Branch Health (push) Has been cancelled
Weekly Nightly to Main Promotion / Create Promotion PR (push) Has been cancelled
Weekly Nightly to Main Promotion / Trigger Missing Required Checks (push) Has been cancelled
Weekly Nightly to Main Promotion / Notify on Failure (push) Has been cancelled
Weekly Nightly to Main Promotion / Workflow Summary (push) Has been cancelled
Weekly Security Rebuild / Security Rebuild & Scan (push) Has been cancelled
changed perms
2026-04-22 18:19:14 +00:00

136 lines
3.4 KiB
Go
Executable File

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 setupRemoteServerTestDB(t *testing.T) *gorm.DB {
db, err := gorm.Open(sqlite.Open("file::memory:?cache=shared&mode=memory"), &gorm.Config{})
require.NoError(t, err)
require.NoError(t, db.AutoMigrate(&models.RemoteServer{}))
// Clear table
db.Exec("DELETE FROM remote_servers")
return db
}
func TestRemoteServerService_ValidateUniqueServer(t *testing.T) {
db := setupRemoteServerTestDB(t)
service := NewRemoteServerService(db)
// Create existing server
existing := &models.RemoteServer{
Name: "Existing Server",
Host: "192.168.1.100",
Port: 8080,
}
require.NoError(t, db.Create(existing).Error)
// Test 1: Duplicate Name
err := service.ValidateUniqueServer("Existing Server", "192.168.1.101", 9090, 0)
assert.Error(t, err)
assert.Contains(t, err.Error(), "already exists")
// Test 2: Duplicate Host:Port
err = service.ValidateUniqueServer("New Name", "192.168.1.100", 8080, 0)
assert.Error(t, err)
assert.Contains(t, err.Error(), "already exists")
// Test 3: New Server
err = service.ValidateUniqueServer("New Server", "192.168.1.101", 8080, 0)
assert.NoError(t, err)
// Test 4: Update existing (exclude self)
err = service.ValidateUniqueServer("Existing Server", "192.168.1.100", 8080, existing.ID)
assert.NoError(t, err)
}
func TestRemoteServerService_CRUD(t *testing.T) {
db := setupRemoteServerTestDB(t)
service := NewRemoteServerService(db)
// Create
rs := &models.RemoteServer{
UUID: uuid.NewString(),
Name: "Test Server",
Host: "192.168.1.100",
Port: 22,
Provider: "manual",
}
err := service.Create(rs)
require.NoError(t, err)
assert.NotZero(t, rs.ID)
assert.NotEmpty(t, rs.UUID)
// Test Create with duplicate name (should fail)
rs2 := &models.RemoteServer{
UUID: uuid.NewString(),
Name: "Test Server", // Duplicate name
Host: "192.168.1.101",
Port: 22,
Provider: "manual",
}
err = service.Create(rs2)
assert.Error(t, err)
assert.Contains(t, err.Error(), "already exists")
// GetByID
fetched, err := service.GetByID(rs.ID)
require.NoError(t, err)
assert.Equal(t, rs.Name, fetched.Name)
// GetByUUID
fetchedUUID, err := service.GetByUUID(rs.UUID)
require.NoError(t, err)
assert.Equal(t, rs.ID, fetchedUUID.ID)
// Update
rs.Name = "Updated Server"
err = service.Update(rs)
require.NoError(t, err)
fetchedUpdated, err := service.GetByID(rs.ID)
require.NoError(t, err)
assert.Equal(t, "Updated Server", fetchedUpdated.Name)
// Test Update with conflicting name
rs3 := &models.RemoteServer{
UUID: uuid.NewString(),
Name: "Another Server",
Host: "192.168.1.102",
Port: 22,
Provider: "manual",
}
require.NoError(t, service.Create(rs3))
// Try to update rs3 to have the same name as rs
rs3.Name = "Updated Server"
err = service.Update(rs3)
assert.Error(t, err)
assert.Contains(t, err.Error(), "already exists")
// List
list, err := service.List(false)
require.NoError(t, err)
assert.GreaterOrEqual(t, len(list), 2)
// List with inactive
list, err = service.List(true)
require.NoError(t, err)
assert.GreaterOrEqual(t, len(list), 2)
// Delete
err = service.Delete(rs.ID)
require.NoError(t, err)
// Verify Delete
_, err = service.GetByID(rs.ID)
assert.Error(t, err)
}