mirror of
https://github.com/YspCoder/clawgo.git
synced 2026-04-13 04:27:28 +08:00
55 lines
2.0 KiB
Go
55 lines
2.0 KiB
Go
package agent
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
)
|
|
|
|
func TestEnsureToolAllowedByContext(t *testing.T) {
|
|
ctx := context.Background()
|
|
|
|
if err := ensureToolAllowedByContext(ctx, "write_file", map[string]interface{}{}); err != nil {
|
|
t.Fatalf("expected unrestricted context to allow tool, got: %v", err)
|
|
}
|
|
|
|
restricted := withToolAllowlistContext(ctx, []string{"read_file", "memory_search"})
|
|
if err := ensureToolAllowedByContext(restricted, "read_file", map[string]interface{}{}); err != nil {
|
|
t.Fatalf("expected allowed tool to pass, got: %v", err)
|
|
}
|
|
if err := ensureToolAllowedByContext(restricted, "write_file", map[string]interface{}{}); err == nil {
|
|
t.Fatalf("expected disallowed tool to fail")
|
|
}
|
|
}
|
|
|
|
func TestEnsureToolAllowedByContextParallelNested(t *testing.T) {
|
|
restricted := withToolAllowlistContext(context.Background(), []string{"parallel", "read_file"})
|
|
|
|
okArgs := map[string]interface{}{
|
|
"calls": []interface{}{
|
|
map[string]interface{}{"tool": "read_file", "arguments": map[string]interface{}{"path": "README.md"}},
|
|
},
|
|
}
|
|
if err := ensureToolAllowedByContext(restricted, "parallel", okArgs); err != nil {
|
|
t.Fatalf("expected parallel with allowed nested tool to pass, got: %v", err)
|
|
}
|
|
|
|
badArgs := map[string]interface{}{
|
|
"calls": []interface{}{
|
|
map[string]interface{}{"tool": "write_file", "arguments": map[string]interface{}{"path": "README.md", "content": "x"}},
|
|
},
|
|
}
|
|
if err := ensureToolAllowedByContext(restricted, "parallel", badArgs); err == nil {
|
|
t.Fatalf("expected parallel with disallowed nested tool to fail")
|
|
}
|
|
}
|
|
|
|
func TestEnsureToolAllowedByContext_GroupAllowlist(t *testing.T) {
|
|
ctx := withToolAllowlistContext(context.Background(), []string{"group:files_read"})
|
|
if err := ensureToolAllowedByContext(ctx, "read_file", map[string]interface{}{}); err != nil {
|
|
t.Fatalf("expected files_read group to allow read_file, got: %v", err)
|
|
}
|
|
if err := ensureToolAllowedByContext(ctx, "write_file", map[string]interface{}{}); err == nil {
|
|
t.Fatalf("expected files_read group to block write_file")
|
|
}
|
|
}
|