7.3 KiB
7.3 KiB
Testing Guide - Claude v2 Subdomain Resolver
🧪 Umfassende Test-Szenarien
Vorbereitung
# Test-UserShop in Datenbank erstellen (falls nicht vorhanden)
php artisan tinker
// In Tinker:
$user = App\User::first(); // Oder einen bestimmten User
$shop = new App\Models\UserShop();
$shop->slug = 'testuser';
$shop->name = 'Test User Shop';
$shop->user_id = $user->id;
$shop->active = 1;
$shop->save();
🌐 Domain-spezifische Tests
1. User-Shop Subdomain Tests
Test 1.1: Gültiger User-Shop
# Request simulieren
curl -v -H "Host: testuser.mivita.care" http://localhost/
# Erwartete Ergebnisse:
# ✅ HTTP 200 Response
# ✅ Shop-spezifische Inhalte werden geladen
# ✅ Session enthält user_shop-Daten
Test 1.2: Ungültiger User-Shop
curl -v -H "Host: nonexistent.mivita.care" http://localhost/
# Erwartete Ergebnisse:
# ✅ HTTP 301 Redirect zu mivita.care
Test 1.3: Inaktiver User-Shop
# Shop deaktivieren in DB
php artisan tinker
# UserShop::where('slug', 'testuser')->update(['active' => 0]);
curl -v -H "Host: testuser.mivita.care" http://localhost/
# Erwartete Ergebnisse:
# ✅ HTTP 503 Service Unavailable
2. Main-Shop Domain Tests
Test 2.1: Main-Shop (mivita.shop)
curl -v -H "Host: mivita.shop" http://localhost/
# Erwartete Ergebnisse:
# ✅ HTTP 200 Response
# ✅ Default-Shop (aloevera) wird geladen
# ✅ Session enthält user_shop mit aloevera-Daten
3. Main-Care Domain Tests
Test 3.1: Main-Care (mivita.care)
curl -v -H "Host: mivita.care" http://localhost/
# Erwartete Ergebnisse:
# ✅ HTTP 200 Response
# ✅ Keine user_shop-Daten in Session
# ✅ Corporate/Info-Seiten werden geladen
4. Unknown Domain Tests
Test 4.1: Unbekannte Domain
curl -v -H "Host: unknown.example.com" http://localhost/
# Erwartete Ergebnisse:
# ✅ HTTP 301 Redirect zu mivita.care
🛒 Warenkorb-Tests
Test 5.1: Warenkorb auf User-Shop
# 1. User-Shop aufrufen
curl -c cookies.txt -H "Host: testuser.mivita.care" http://localhost/
# 2. Produkt zum Warenkorb hinzufügen
curl -b cookies.txt -H "Host: testuser.mivita.care" \
-d "product_id=1&quantity=1" \
http://localhost/cart/add
# 3. Warenkorb anzeigen
curl -b cookies.txt -H "Host: testuser.mivita.care" http://localhost/cart
# Erwartete Ergebnisse:
# ✅ Produkt wird erfolgreich hinzugefügt
# ✅ Warenkorb zeigt Produkt an
# ✅ Session-Daten bleiben erhalten
Test 5.2: Warenkorb auf Main-Shop
# Gleiche Tests wie 5.1, aber mit "Host: mivita.shop"
📱 Session-Tests
Test 6.1: Session-Persistenz bei User-Shop
# Browser-Session simulieren mit Cookie-Handling
session_file=$(mktemp)
# 1. Erste Anfrage - Session erstellen
curl -c "$session_file" -H "Host: testuser.mivita.care" http://localhost/
# 2. Zweite Anfrage - Session verwenden
curl -b "$session_file" -H "Host: testuser.mivita.care" http://localhost/profile
# Erwartete Ergebnisse:
# ✅ Session-ID bleibt gleich
# ✅ user_shop-Daten bleiben erhalten
Test 6.2: Session-Domain-Konfiguration
// In Browser-Entwicklertools oder via Code:
// Session-Cookies sollten die richtige Domain haben:
// Für testuser.mivita.care:
// Session-Cookie-Domain: .mivita.care
// Für mivita.shop:
// Session-Cookie-Domain: .mivita.shop
🔗 URL-Generation Tests
Test 7.1: URL-Helper auf User-Shop
// Test in Blade-Template oder Controller:
// Auf testuser.mivita.care sollte route('home') zurückgeben:
// https://testuser.mivita.care/
// config('app.url') sollte sein:
// https://testuser.mivita.care
Test 7.2: URL-Helper auf Main-Shop
// Auf mivita.shop sollte route('home') zurückgeben:
// https://mivita.shop/
⚡ Performance Tests
Test 8.1: Asset-Request-Filtering
# CSS/JS/Image requests sollten übersprungen werden
curl -H "Host: testuser.mivita.care" http://localhost/css/app.css
# Erwartete Ergebnisse:
# ✅ Middleware wird NICHT ausgeführt (Performance)
# ✅ Datei wird direkt serviert
Test 8.2: API-Request-Filtering
# API requests sollten übersprungen werden
curl -H "Host: testuser.mivita.care" http://localhost/api/products
# Erwartete Ergebnisse:
# ✅ Middleware wird NICHT ausgeführt
# ✅ API funktioniert normal
🚨 Error-Handling Tests
Test 9.1: Database Connection Error
# Datenbank temporär deaktivieren und testen
# (Simuliere DB-Ausfall)
curl -H "Host: testuser.mivita.care" http://localhost/
# Erwartete Ergebnisse:
# ✅ Graceful Error-Handling
# ✅ Redirect zu Hauptdomain oder 503 Error
📋 Automatisierte Test-Suite
Test-Script erstellen
#!/bin/bash
# test-subdomain-resolver.sh
echo "=== Testing Claude v2 Subdomain Resolver ==="
# Test 1: User Shop
echo "Test 1: User Shop (testuser.mivita.care)"
response=$(curl -s -o /dev/null -w "%{http_code}" -H "Host: testuser.mivita.care" http://localhost/)
if [ "$response" = "200" ]; then
echo "✅ User Shop: PASS"
else
echo "❌ User Shop: FAIL ($response)"
fi
# Test 2: Main Shop
echo "Test 2: Main Shop (mivita.shop)"
response=$(curl -s -o /dev/null -w "%{http_code}" -H "Host: mivita.shop" http://localhost/)
if [ "$response" = "200" ]; then
echo "✅ Main Shop: PASS"
else
echo "❌ Main Shop: FAIL ($response)"
fi
# Test 3: Main Care
echo "Test 3: Main Care (mivita.care)"
response=$(curl -s -o /dev/null -w "%{http_code}" -H "Host: mivita.care" http://localhost/)
if [ "$response" = "200" ]; then
echo "✅ Main Care: PASS"
else
echo "❌ Main Care: FAIL ($response)"
fi
# Test 4: Unknown Domain (should redirect)
echo "Test 4: Unknown Domain (should redirect)"
response=$(curl -s -o /dev/null -w "%{http_code}" -H "Host: unknown.example.com" http://localhost/)
if [ "$response" = "301" ]; then
echo "✅ Unknown Domain: PASS"
else
echo "❌ Unknown Domain: FAIL ($response)"
fi
echo "=== Testing Complete ==="
🔍 Debug-Tests
Test 10.1: Session-Debug
// In Controller oder Route:
Route::get('/debug-session', function() {
return [
'host' => request()->getHost(),
'session_domain' => config('session.domain'),
'app_url' => config('app.url'),
'user_shop' => session('user_shop'),
'user_shop_domain' => session('user_shop_domain'),
'session_id' => session()->getId(),
];
});
Test 10.2: Domain-Parsing-Debug
// Temporärer Debug-Route:
Route::get('/debug-domain/{host}', function($host) {
$resolver = new \App\Http\Middleware\SubdomainResolver();
$reflection = new ReflectionClass($resolver);
$method = $reflection->getMethod('parseDomain');
$method->setAccessible(true);
return $method->invoke($resolver, $host);
});
✅ Erfolgs-Checkliste
Nach allen Tests sollten folgende Punkte erfüllt sein:
- User-Shop Subdomains laden korrekt
- Main-Shop Domain funktioniert
- Main-Care Domain funktioniert
- Unbekannte Domains werden umgeleitet
- Warenkorb funktioniert auf allen Domains
- Sessions bleiben bestehen
- URLs werden korrekt generiert
- Asset-Requests werden übersprungen
- API-Requests werden übersprungen
- Fehlerbehandlung funktioniert graceful
- Performance ist akzeptabel
- Keine Session-Timing-Issues
- Checkout-Prozess funktioniert