You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

75 lines
2.2 KiB

#!/bin/bash
# Test script for SMQ schema bypass functionality
# This script tests publishing to topics with "_" prefix which should bypass schema validation
set -e
echo "🧪 Testing SMQ Schema Bypass for Topics with '_' Prefix"
echo "========================================================="
# Check if Kafka gateway is running
echo "Checking if Kafka gateway is running on localhost:9093..."
if ! nc -z localhost 9093 2>/dev/null; then
echo "[FAIL] Kafka gateway is not running on localhost:9093"
echo "Please start SeaweedMQ with Kafka gateway enabled first"
exit 1
fi
echo "[OK] Kafka gateway is running"
# Test with schema-required topic (should require schema)
echo
echo "Testing schema-required topic (should require schema validation)..."
SCHEMA_TOPIC="user-events"
echo "Topic: $SCHEMA_TOPIC (regular topic, requires schema)"
# Test with underscore prefix topic (should bypass schema)
echo
echo "Testing schema-bypass topic (should skip schema validation)..."
BYPASS_TOPIC="_raw_messages"
echo "Topic: $BYPASS_TOPIC (underscore prefix, bypasses schema)"
# Build and test the publisher
echo
echo "Building publisher..."
cd simple-publisher
go mod tidy
echo "[OK] Publisher dependencies ready"
echo
echo "Running publisher test..."
timeout 30s go run main.go || {
echo "[FAIL] Publisher test failed or timed out"
exit 1
}
echo "[OK] Publisher test completed"
# Build consumer
echo
echo "Building consumer..."
cd ../simple-consumer
go mod tidy
echo "[OK] Consumer dependencies ready"
echo
echo "Testing consumer (will run for 10 seconds)..."
timeout 10s go run main.go || {
if [ $? -eq 124 ]; then
echo "[OK] Consumer test completed (timed out as expected)"
else
echo "[FAIL] Consumer test failed"
exit 1
fi
}
echo
echo "All tests completed successfully!"
echo
echo "Summary:"
echo "- [OK] Topics with '_' prefix bypass schema validation"
echo "- [OK] Raw messages are stored as bytes in the 'value' field"
echo "- [OK] kafka-go client works with SeaweedMQ"
echo "- [OK] No schema validation errors for '_raw_messages' topic"
echo
echo "The SMQ schema bypass functionality is working correctly!"
echo "Topics with '_' prefix are treated as system topics and bypass all schema processing."