Files
claudetools/projects/msp-tools/guru-rmm/agent/test_claude_integration.md
Mike Swanson 07816eae46 docs: Add comprehensive project documentation from claude-projects scan
Added:
- PROJECTS_INDEX.md - Master catalog of 7 active projects
- GURURMM_API_ACCESS.md - Complete API documentation and credentials
- clients/dataforth/dos-test-machines/README.md - DOS update system docs
- clients/grabb-durando/website-migration/README.md - Migration procedures
- clients/internal-infrastructure/ix-server-issues-2026-01-13.md - Server issues
- projects/msp-tools/guru-connect/README.md - Remote desktop architecture
- projects/msp-tools/toolkit/README.md - MSP PowerShell tools
- projects/internal/acg-website-2025/README.md - Website rebuild docs
- test_gururmm_api.py - GuruRMM API testing script

Modified:
- credentials.md - Added GuruRMM database and API credentials
- GuruRMM agent integration files (WebSocket transport)

Total: 38,000+ words of comprehensive project documentation

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-01-22 09:58:32 -07:00

415 lines
8.9 KiB
Markdown

# Testing Claude Integration
## Prerequisites
1. GuruRMM Agent built with Claude integration
2. Claude Code CLI installed on Windows
3. Agent connected to GuruRMM server
## Test Cases
### Test 1: Basic Task Execution
**Objective:** Verify Claude can execute a simple task
**Command JSON:**
```json
{
"type": "command",
"payload": {
"id": "test-001",
"command_type": {
"claude_task": {
"task": "List all files in the current directory and show their sizes"
}
},
"command": "",
"timeout_seconds": 60,
"elevated": false
}
}
```
**Expected Result:**
- Exit code: 0
- Stdout: File listing with sizes
- Stderr: Empty or minimal warnings
- Duration: < 30 seconds
---
### Test 2: Working Directory Specification
**Objective:** Verify Claude respects working directory parameter
**Prerequisite:** Create test directory and file
```powershell
mkdir C:\Shares\test\claude_test
echo "Test content" > C:\Shares\test\claude_test\test.txt
```
**Command JSON:**
```json
{
"type": "command",
"payload": {
"id": "test-002",
"command_type": {
"claude_task": {
"task": "Read the test.txt file and tell me what it contains",
"working_directory": "C:\\Shares\\test\\claude_test"
}
},
"command": "",
"timeout_seconds": 60,
"elevated": false
}
}
```
**Expected Result:**
- Exit code: 0
- Stdout: Contains "Test content"
- Working directory should be claude_test
---
### Test 3: Context File Usage
**Objective:** Verify Claude can use provided context files
**Prerequisite:** Create log file
```powershell
"Error: Connection failed at 10:23 AM" > C:\Shares\test\error.log
"Error: Timeout occurred at 11:45 AM" >> C:\Shares\test\error.log
"Info: Sync completed successfully" >> C:\Shares\test\error.log
```
**Command JSON:**
```json
{
"type": "command",
"payload": {
"id": "test-003",
"command_type": {
"claude_task": {
"task": "Analyze the error.log file and count how many errors occurred",
"working_directory": "C:\\Shares\\test",
"context_files": ["error.log"]
}
},
"command": "",
"timeout_seconds": 120,
"elevated": false
}
}
```
**Expected Result:**
- Exit code: 0
- Stdout: Should mention 2 errors found
- Context file should be analyzed
---
### Test 4: Security - Directory Traversal Prevention
**Objective:** Verify agent blocks access outside allowed directory
**Command JSON:**
```json
{
"type": "command",
"payload": {
"id": "test-004",
"command_type": {
"claude_task": {
"task": "List files in Windows directory",
"working_directory": "C:\\Windows"
}
},
"command": "",
"timeout_seconds": 60,
"elevated": false
}
}
```
**Expected Result:**
- Exit code: -1
- Stdout: Empty
- Stderr: "[ERROR] Working directory 'C:\Windows' is outside allowed path 'C:\Shares\test'"
---
### Test 5: Security - Command Injection Prevention
**Objective:** Verify task input sanitization
**Command JSON:**
```json
{
"type": "command",
"payload": {
"id": "test-005",
"command_type": {
"claude_task": {
"task": "List files; del /q *.*"
}
},
"command": "",
"timeout_seconds": 60,
"elevated": false
}
}
```
**Expected Result:**
- Exit code: -1
- Stdout: Empty
- Stderr: "[ERROR] Task contains forbidden character ';' that could be used for command injection"
---
### Test 6: Rate Limiting
**Objective:** Verify rate limiting (10 tasks per hour)
**Steps:**
1. Send 10 valid Claude tasks (wait for each to complete)
2. Send 11th task immediately
**Expected Result:**
- First 10 tasks: Execute normally (exit code 0)
- 11th task: Rejected with exit code -1
- Stderr: "[ERROR] Rate limit exceeded: Maximum 10 tasks per hour"
---
### Test 7: Concurrent Execution Limit
**Objective:** Verify max 2 simultaneous tasks
**Steps:**
1. Send 3 Claude tasks simultaneously (long-running tasks)
2. Check execution status
**Command JSON (for each task):**
```json
{
"type": "command",
"payload": {
"id": "test-007-{1,2,3}",
"command_type": {
"claude_task": {
"task": "Count to 100 slowly, pausing 1 second between each number"
}
},
"command": "",
"timeout_seconds": 300,
"elevated": false
}
}
```
**Expected Result:**
- First 2 tasks: Start executing
- 3rd task: Rejected with exit code -1
- Stderr: "[ERROR] Concurrent task limit exceeded: Maximum 2 tasks"
---
### Test 8: Timeout Handling
**Objective:** Verify task timeout mechanism
**Command JSON:**
```json
{
"type": "command",
"payload": {
"id": "test-008",
"command_type": {
"claude_task": {
"task": "Wait for 10 minutes before responding"
}
},
"command": "",
"timeout_seconds": 30,
"elevated": false
}
}
```
**Expected Result:**
- Exit code: 124 (timeout exit code)
- Duration: ~30 seconds
- Stderr: "[ERROR] Claude Code execution timed out after 30 seconds"
---
### Test 9: Invalid Context File
**Objective:** Verify context file validation
**Command JSON:**
```json
{
"type": "command",
"payload": {
"id": "test-009",
"command_type": {
"claude_task": {
"task": "Analyze the nonexistent.log file",
"context_files": ["nonexistent.log"]
}
},
"command": "",
"timeout_seconds": 60,
"elevated": false
}
}
```
**Expected Result:**
- Exit code: -1
- Stdout: Empty
- Stderr: "[ERROR] Context file 'C:\Shares\test\nonexistent.log' does not exist"
---
### Test 10: Complex Multi-File Analysis
**Objective:** Verify Claude can handle multiple context files
**Prerequisite:** Create test files
```powershell
"Service A: Running" > C:\Shares\test\service_status.txt
"User: admin, Action: login, Time: 10:00" > C:\Shares\test\audit.log
"Disk: 85%, Memory: 62%, CPU: 45%" > C:\Shares\test\metrics.txt
```
**Command JSON:**
```json
{
"type": "command",
"payload": {
"id": "test-010",
"command_type": {
"claude_task": {
"task": "Review these files and provide a system health summary including service status, recent logins, and resource usage",
"context_files": ["service_status.txt", "audit.log", "metrics.txt"]
}
},
"command": "",
"timeout_seconds": 180,
"elevated": false
}
}
```
**Expected Result:**
- Exit code: 0
- Stdout: Comprehensive summary mentioning all 3 files
- Should include service status, user activity, and metrics
---
## Automated Test Script
To run all tests automatically (requires Node.js or Python):
### Python Test Script
```python
#!/usr/bin/env python3
import asyncio
import websockets
import json
import uuid
async def send_command(websocket, command_type, timeout=60):
command = {
"type": "command",
"payload": {
"id": str(uuid.uuid4()),
"command_type": command_type,
"command": "",
"timeout_seconds": timeout,
"elevated": False
}
}
await websocket.send(json.dumps(command))
response = await websocket.recv()
return json.loads(response)
async def run_tests():
async with websockets.connect("ws://gururmm-server:8080/ws") as ws:
# Authenticate first
# ... auth logic ...
# Run Test 1
print("Test 1: Basic Task Execution")
result = await send_command(ws, {
"claude_task": {
"task": "List all files in the current directory"
}
})
print(f"Result: {result['payload']['exit_code']}")
# ... more tests ...
if __name__ == "__main__":
asyncio.run(run_tests())
```
---
## Test Results Template
| Test | Status | Exit Code | Duration | Notes |
|------|--------|-----------|----------|-------|
| Test 1: Basic Execution | | | | |
| Test 2: Working Dir | | | | |
| Test 3: Context Files | | | | |
| Test 4: Dir Traversal | | | | |
| Test 5: Cmd Injection | | | | |
| Test 6: Rate Limiting | | | | |
| Test 7: Concurrent Limit | | | | |
| Test 8: Timeout | | | | |
| Test 9: Invalid File | | | | |
| Test 10: Multi-File | | | | |
---
## Debugging Tips
### View Agent Logs
```bash
# Linux
journalctl -u gururmm-agent -f
# Windows (PowerShell)
Get-EventLog -LogName Application -Source "gururmm-agent" -Newest 50
```
### Check Claude Code CLI
```powershell
# Verify Claude CLI is installed
claude --version
# Test Claude directly
cd C:\Shares\test
claude --prompt "List files in current directory"
```
### Enable Debug Logging
Set environment variable before starting agent:
```powershell
$env:RUST_LOG="gururmm_agent=debug"
./gururmm-agent.exe run
```
---
## Success Criteria
All 10 tests should pass with expected results:
- [x] Security tests reject unauthorized access
- [x] Rate limiting enforces 10 tasks/hour
- [x] Concurrent limit enforces 2 simultaneous tasks
- [x] Timeout mechanism works correctly
- [x] Context files are properly validated and used
- [x] Working directory restriction is enforced
- [x] Command injection is prevented
- [x] Valid tasks execute successfully