- Created `qa-test-output-after-fix.txt` and `qa-test-output.txt` to log results of certificate page authentication tests. - Added `build.sh` for deterministic backend builds in CI, utilizing `go list` for efficiency. - Introduced `codeql_scan.sh` for CodeQL database creation and analysis for Go and JavaScript/TypeScript. - Implemented `dockerfile_check.sh` to validate Dockerfiles for base image and package manager mismatches. - Added `sourcery_precommit_wrapper.sh` to facilitate Sourcery CLI usage in pre-commit hooks.
136 lines
3.4 KiB
Go
136 lines
3.4 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 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)
|
|
}
|