Files
breakpilot-compliance/ai-compliance-sdk/internal/maximizer/dimensions_test.go
Benjamin Admin 1ac716261c
Some checks failed
Build + Deploy / build-admin-compliance (push) Successful in 1m45s
Build + Deploy / build-backend-compliance (push) Successful in 4m42s
Build + Deploy / build-ai-sdk (push) Successful in 46s
Build + Deploy / build-developer-portal (push) Successful in 1m6s
Build + Deploy / build-tts (push) Successful in 1m14s
Build + Deploy / build-document-crawler (push) Successful in 31s
Build + Deploy / build-dsms-gateway (push) Successful in 24s
CI / branch-name (push) Has been skipped
CI / guardrail-integrity (push) Has been skipped
CI / loc-budget (push) Failing after 15s
CI / secret-scan (push) Has been skipped
CI / go-lint (push) Has been skipped
CI / python-lint (push) Has been skipped
CI / nodejs-lint (push) Has been skipped
CI / nodejs-build (push) Successful in 2m27s
CI / dep-audit (push) Has been skipped
CI / sbom-scan (push) Has been skipped
CI / test-go (push) Failing after 37s
CI / test-python-backend (push) Successful in 42s
CI / test-python-document-crawler (push) Successful in 25s
CI / test-python-dsms-gateway (push) Successful in 23s
CI / validate-canonical-controls (push) Successful in 18s
Build + Deploy / trigger-orca (push) Successful in 4m35s
feat: Compliance Maximizer — Regulatory Optimization Engine
Neues Modul das den regulatorischen Spielraum fuer KI-Use-Cases
deterministisch berechnet und optimale Konfigurationen vorschlaegt.

Kernfeatures:
- 13-Dimensionen Constraint-Space (DSGVO + AI Act)
- 3-Zonen-Analyse: Verboten / Eingeschraenkt / Erlaubt
- Deterministische Optimizer-Engine (kein LLM im Kern)
- 28 Constraint-Regeln aus DSGVO, AI Act, EDPB Guidelines
- 28 Tests (Golden Suite + Meta-Tests)
- REST API: /sdk/v1/maximizer/* (9 Endpoints)
- Frontend: 3-Zonen-Visualisierung, Dimension-Form, Score-Gauges

[migration-approved]

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-23 09:10:20 +02:00

202 lines
4.9 KiB
Go

package maximizer
import (
"testing"
"github.com/breakpilot/ai-compliance-sdk/internal/ucca"
)
func TestGetValueSetValueRoundtrip(t *testing.T) {
config := DimensionConfig{
AutomationLevel: AutoFull,
DecisionBinding: BindingFullyBinding,
DecisionImpact: ImpactHigh,
Domain: DomainHR,
DataType: DataPersonal,
HumanInLoop: HILNone,
Explainability: ExplainNone,
RiskClassification: RiskHigh,
LegalBasis: LegalContract,
TransparencyRequired: true,
LoggingRequired: false,
ModelType: ModelBlackboxLLM,
DeploymentScope: ScopeExternal,
}
for _, dim := range allDimensions {
val := config.GetValue(dim)
if val == "" {
t.Errorf("GetValue(%q) returned empty", dim)
}
clone := DimensionConfig{}
ok := clone.SetValue(dim, val)
if !ok {
t.Errorf("SetValue(%q, %q) returned false", dim, val)
}
if clone.GetValue(dim) != val {
t.Errorf("SetValue roundtrip failed for %q: got %q, want %q", dim, clone.GetValue(dim), val)
}
}
}
func TestGetValueUnknownDimension(t *testing.T) {
config := DimensionConfig{}
if v := config.GetValue("nonexistent"); v != "" {
t.Errorf("expected empty for unknown dimension, got %q", v)
}
if ok := config.SetValue("nonexistent", "x"); ok {
t.Error("expected false for unknown dimension")
}
}
func TestDiffIdentical(t *testing.T) {
config := DimensionConfig{
AutomationLevel: AutoAssistive,
DecisionImpact: ImpactLow,
Domain: DomainGeneral,
}
deltas := config.Diff(&config)
if len(deltas) != 0 {
t.Errorf("expected 0 deltas for identical configs, got %d", len(deltas))
}
}
func TestDiffDetectsChanges(t *testing.T) {
a := DimensionConfig{
AutomationLevel: AutoFull,
HumanInLoop: HILNone,
DecisionBinding: BindingFullyBinding,
}
b := DimensionConfig{
AutomationLevel: AutoAssistive,
HumanInLoop: HILRequired,
DecisionBinding: BindingHumanReview,
}
deltas := a.Diff(&b)
changed := make(map[string]bool)
for _, d := range deltas {
changed[d.Dimension] = true
}
for _, dim := range []string{"automation_level", "human_in_loop", "decision_binding"} {
if !changed[dim] {
t.Errorf("expected %q in deltas", dim)
}
}
}
func TestClone(t *testing.T) {
orig := DimensionConfig{
AutomationLevel: AutoFull,
Domain: DomainHR,
}
clone := orig.Clone()
clone.AutomationLevel = AutoAssistive
if orig.AutomationLevel != AutoFull {
t.Error("clone modified original")
}
}
func TestMapIntakeToDimensions(t *testing.T) {
intake := &ucca.UseCaseIntake{
Domain: "hr",
Automation: ucca.AutomationFullyAutomated,
DataTypes: ucca.DataTypes{
PersonalData: true,
Article9Data: true,
},
Purpose: ucca.Purpose{
DecisionMaking: true,
},
Outputs: ucca.Outputs{
LegalEffects: true,
},
ModelUsage: ucca.ModelUsage{
Training: true,
},
}
config := MapIntakeToDimensions(intake)
tests := []struct {
dimension string
expected string
}{
{"automation_level", "full"},
{"domain", "hr"},
{"data_type", "sensitive"},
{"decision_impact", "high"},
{"model_type", "blackbox_llm"},
{"human_in_loop", "none"},
{"decision_binding", "fully_binding"},
}
for _, tc := range tests {
got := config.GetValue(tc.dimension)
if got != tc.expected {
t.Errorf("MapIntakeToDimensions: %s = %q, want %q", tc.dimension, got, tc.expected)
}
}
}
func TestMapIntakeToDimensionsBiometricWins(t *testing.T) {
intake := &ucca.UseCaseIntake{
DataTypes: ucca.DataTypes{
PersonalData: true,
Article9Data: true,
BiometricData: true,
},
}
config := MapIntakeToDimensions(intake)
if config.DataType != DataBiometric {
t.Errorf("expected biometric (highest sensitivity), got %s", config.DataType)
}
}
func TestMapDimensionsToIntakePreservesOriginal(t *testing.T) {
original := &ucca.UseCaseIntake{
UseCaseText: "Test use case",
Domain: "hr",
Title: "My Assessment",
Automation: ucca.AutomationFullyAutomated,
DataTypes: ucca.DataTypes{
PersonalData: true,
},
Hosting: ucca.Hosting{
Region: "eu",
},
}
config := &DimensionConfig{
AutomationLevel: AutoAssistive,
DataType: DataPersonal,
Domain: DomainHR,
}
result := MapDimensionsToIntake(config, original)
if result.UseCaseText != "Test use case" {
t.Error("MapDimensionsToIntake did not preserve UseCaseText")
}
if result.Title != "My Assessment" {
t.Error("MapDimensionsToIntake did not preserve Title")
}
if result.Hosting.Region != "eu" {
t.Error("MapDimensionsToIntake did not preserve Hosting")
}
if result.Automation != ucca.AutomationAssistive {
t.Errorf("expected assistive automation, got %s", result.Automation)
}
}
func TestAllValuesComplete(t *testing.T) {
for _, dim := range allDimensions {
vals, ok := AllValues[dim]
if !ok {
t.Errorf("AllValues missing dimension %q", dim)
}
if len(vals) == 0 {
t.Errorf("AllValues[%q] is empty", dim)
}
}
}