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.
		
		
		
		
		
			
		
			
				
					
					
						
							288 lines
						
					
					
						
							8.0 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							288 lines
						
					
					
						
							8.0 KiB
						
					
					
				
								#!/bin/bash
							 | 
						|
								
							 | 
						|
								set -euo pipefail
							 | 
						|
								
							 | 
						|
								# Colors for output
							 | 
						|
								RED='\033[0;31m'
							 | 
						|
								GREEN='\033[0;32m'
							 | 
						|
								BLUE='\033[0;34m'
							 | 
						|
								YELLOW='\033[1;33m'
							 | 
						|
								NC='\033[0m' # No Color
							 | 
						|
								
							 | 
						|
								# Configuration
							 | 
						|
								MOUNT_POINT=${MOUNT_POINT:-"/mnt/seaweedfs"}
							 | 
						|
								FILER_ADDR=${FILER_ADDR:-"seaweedfs-filer:8888"}
							 | 
						|
								RDMA_SIDECAR_ADDR=${RDMA_SIDECAR_ADDR:-"rdma-sidecar:8081"}
							 | 
						|
								TEST_RESULTS_DIR=${TEST_RESULTS_DIR:-"/test-results"}
							 | 
						|
								
							 | 
						|
								# Test counters
							 | 
						|
								TOTAL_TESTS=0
							 | 
						|
								PASSED_TESTS=0
							 | 
						|
								FAILED_TESTS=0
							 | 
						|
								
							 | 
						|
								# Create results directory
							 | 
						|
								mkdir -p "$TEST_RESULTS_DIR"
							 | 
						|
								
							 | 
						|
								# Log file
							 | 
						|
								LOG_FILE="$TEST_RESULTS_DIR/integration-test.log"
							 | 
						|
								exec > >(tee -a "$LOG_FILE")
							 | 
						|
								exec 2>&1
							 | 
						|
								
							 | 
						|
								echo -e "${BLUE}🧪 SEAWEEDFS RDMA MOUNT INTEGRATION TESTS${NC}"
							 | 
						|
								echo "=========================================="
							 | 
						|
								echo "Mount Point: $MOUNT_POINT"
							 | 
						|
								echo "Filer Address: $FILER_ADDR"
							 | 
						|
								echo "RDMA Sidecar: $RDMA_SIDECAR_ADDR"
							 | 
						|
								echo "Results Directory: $TEST_RESULTS_DIR"
							 | 
						|
								echo "Log File: $LOG_FILE"
							 | 
						|
								echo ""
							 | 
						|
								
							 | 
						|
								# Function to run a test
							 | 
						|
								run_test() {
							 | 
						|
								    local test_name=$1
							 | 
						|
								    local test_command=$2
							 | 
						|
								    
							 | 
						|
								    echo -e "${BLUE}🔬 Running test: $test_name${NC}"
							 | 
						|
								    ((TOTAL_TESTS++))
							 | 
						|
								    
							 | 
						|
								    if eval "$test_command"; then
							 | 
						|
								        echo -e "${GREEN}✅ PASSED: $test_name${NC}"
							 | 
						|
								        ((PASSED_TESTS++))
							 | 
						|
								        echo "PASS" > "$TEST_RESULTS_DIR/${test_name}.result"
							 | 
						|
								    else
							 | 
						|
								        echo -e "${RED}❌ FAILED: $test_name${NC}"
							 | 
						|
								        ((FAILED_TESTS++))
							 | 
						|
								        echo "FAIL" > "$TEST_RESULTS_DIR/${test_name}.result"
							 | 
						|
								    fi
							 | 
						|
								    echo ""
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								# Function to wait for mount to be ready
							 | 
						|
								wait_for_mount() {
							 | 
						|
								    local max_attempts=30
							 | 
						|
								    local attempt=1
							 | 
						|
								    
							 | 
						|
								    echo -e "${BLUE}⏳ Waiting for mount to be ready...${NC}"
							 | 
						|
								    
							 | 
						|
								    while [[ $attempt -le $max_attempts ]]; do
							 | 
						|
								        if mountpoint -q "$MOUNT_POINT" 2>/dev/null && ls "$MOUNT_POINT" >/dev/null 2>&1; then
							 | 
						|
								            echo -e "${GREEN}✅ Mount is ready${NC}"
							 | 
						|
								            return 0
							 | 
						|
								        fi
							 | 
						|
								        echo "   Attempt $attempt/$max_attempts..."
							 | 
						|
								        sleep 2
							 | 
						|
								        ((attempt++))
							 | 
						|
								    done
							 | 
						|
								    
							 | 
						|
								    echo -e "${RED}❌ Mount failed to be ready${NC}"
							 | 
						|
								    return 1
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								# Function to check RDMA sidecar
							 | 
						|
								check_rdma_sidecar() {
							 | 
						|
								    echo -e "${BLUE}🔍 Checking RDMA sidecar status...${NC}"
							 | 
						|
								    
							 | 
						|
								    local response
							 | 
						|
								    if response=$(curl -s "http://$RDMA_SIDECAR_ADDR/health" 2>/dev/null); then
							 | 
						|
								        echo "RDMA Sidecar Health: $response"
							 | 
						|
								        return 0
							 | 
						|
								    else
							 | 
						|
								        echo -e "${RED}❌ RDMA sidecar is not responding${NC}"
							 | 
						|
								        return 1
							 | 
						|
								    fi
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								# Test 1: Mount Point Accessibility
							 | 
						|
								test_mount_accessibility() {
							 | 
						|
								    mountpoint -q "$MOUNT_POINT" && ls "$MOUNT_POINT" >/dev/null
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								# Test 2: Basic File Operations
							 | 
						|
								test_basic_file_operations() {
							 | 
						|
								    local test_file="$MOUNT_POINT/test_basic_ops.txt"
							 | 
						|
								    local test_content="Hello, RDMA World! $(date)"
							 | 
						|
								    
							 | 
						|
								    # Write test
							 | 
						|
								    echo "$test_content" > "$test_file" || return 1
							 | 
						|
								    
							 | 
						|
								    # Read test
							 | 
						|
								    local read_content
							 | 
						|
								    read_content=$(cat "$test_file") || return 1
							 | 
						|
								    
							 | 
						|
								    # Verify content
							 | 
						|
								    [[ "$read_content" == "$test_content" ]] || return 1
							 | 
						|
								    
							 | 
						|
								    # Cleanup
							 | 
						|
								    rm -f "$test_file"
							 | 
						|
								    
							 | 
						|
								    return 0
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								# Test 3: Large File Operations
							 | 
						|
								test_large_file_operations() {
							 | 
						|
								    local test_file="$MOUNT_POINT/test_large_file.dat"
							 | 
						|
								    local size_mb=10
							 | 
						|
								    
							 | 
						|
								    # Create large file
							 | 
						|
								    dd if=/dev/zero of="$test_file" bs=1M count=$size_mb 2>/dev/null || return 1
							 | 
						|
								    
							 | 
						|
								    # Verify size
							 | 
						|
								    local actual_size
							 | 
						|
								    actual_size=$(stat -c%s "$test_file" 2>/dev/null) || return 1
							 | 
						|
								    local expected_size=$((size_mb * 1024 * 1024))
							 | 
						|
								    
							 | 
						|
								    [[ "$actual_size" -eq "$expected_size" ]] || return 1
							 | 
						|
								    
							 | 
						|
								    # Read test
							 | 
						|
								    dd if="$test_file" of=/dev/null bs=1M 2>/dev/null || return 1
							 | 
						|
								    
							 | 
						|
								    # Cleanup
							 | 
						|
								    rm -f "$test_file"
							 | 
						|
								    
							 | 
						|
								    return 0
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								# Test 4: Directory Operations
							 | 
						|
								test_directory_operations() {
							 | 
						|
								    local test_dir="$MOUNT_POINT/test_directory"
							 | 
						|
								    local test_file="$test_dir/test_file.txt"
							 | 
						|
								    
							 | 
						|
								    # Create directory
							 | 
						|
								    mkdir -p "$test_dir" || return 1
							 | 
						|
								    
							 | 
						|
								    # Create file in directory
							 | 
						|
								    echo "Directory test" > "$test_file" || return 1
							 | 
						|
								    
							 | 
						|
								    # List directory
							 | 
						|
								    ls "$test_dir" | grep -q "test_file.txt" || return 1
							 | 
						|
								    
							 | 
						|
								    # Read file
							 | 
						|
								    grep -q "Directory test" "$test_file" || return 1
							 | 
						|
								    
							 | 
						|
								    # Cleanup
							 | 
						|
								    rm -rf "$test_dir"
							 | 
						|
								    
							 | 
						|
								    return 0
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								# Test 5: Multiple File Operations
							 | 
						|
								test_multiple_files() {
							 | 
						|
								    local test_dir="$MOUNT_POINT/test_multiple"
							 | 
						|
								    local num_files=20
							 | 
						|
								    
							 | 
						|
								    mkdir -p "$test_dir" || return 1
							 | 
						|
								    
							 | 
						|
								    # Create multiple files
							 | 
						|
								    for i in $(seq 1 $num_files); do
							 | 
						|
								        echo "File $i content" > "$test_dir/file_$i.txt" || return 1
							 | 
						|
								    done
							 | 
						|
								    
							 | 
						|
								    # Verify all files exist and have correct content
							 | 
						|
								    for i in $(seq 1 $num_files); do
							 | 
						|
								        [[ -f "$test_dir/file_$i.txt" ]] || return 1
							 | 
						|
								        grep -q "File $i content" "$test_dir/file_$i.txt" || return 1
							 | 
						|
								    done
							 | 
						|
								    
							 | 
						|
								    # List files
							 | 
						|
								    local file_count
							 | 
						|
								    file_count=$(ls "$test_dir" | wc -l) || return 1
							 | 
						|
								    [[ "$file_count" -eq "$num_files" ]] || return 1
							 | 
						|
								    
							 | 
						|
								    # Cleanup
							 | 
						|
								    rm -rf "$test_dir"
							 | 
						|
								    
							 | 
						|
								    return 0
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								# Test 6: RDMA Statistics
							 | 
						|
								test_rdma_statistics() {
							 | 
						|
								    local stats_response
							 | 
						|
								    stats_response=$(curl -s "http://$RDMA_SIDECAR_ADDR/stats" 2>/dev/null) || return 1
							 | 
						|
								    
							 | 
						|
								    # Check if response contains expected fields
							 | 
						|
								    echo "$stats_response" | jq -e '.rdma_enabled' >/dev/null || return 1
							 | 
						|
								    echo "$stats_response" | jq -e '.total_reads' >/dev/null || return 1
							 | 
						|
								    
							 | 
						|
								    return 0
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								# Test 7: Performance Baseline
							 | 
						|
								test_performance_baseline() {
							 | 
						|
								    local test_file="$MOUNT_POINT/performance_test.dat"
							 | 
						|
								    local size_mb=50
							 | 
						|
								    
							 | 
						|
								    # Write performance test
							 | 
						|
								    local write_start write_end write_time
							 | 
						|
								    write_start=$(date +%s%N)
							 | 
						|
								    dd if=/dev/zero of="$test_file" bs=1M count=$size_mb 2>/dev/null || return 1
							 | 
						|
								    write_end=$(date +%s%N)
							 | 
						|
								    write_time=$(((write_end - write_start) / 1000000)) # Convert to milliseconds
							 | 
						|
								    
							 | 
						|
								    # Read performance test
							 | 
						|
								    local read_start read_end read_time
							 | 
						|
								    read_start=$(date +%s%N)
							 | 
						|
								    dd if="$test_file" of=/dev/null bs=1M 2>/dev/null || return 1
							 | 
						|
								    read_end=$(date +%s%N)
							 | 
						|
								    read_time=$(((read_end - read_start) / 1000000)) # Convert to milliseconds
							 | 
						|
								    
							 | 
						|
								    # Log performance metrics
							 | 
						|
								    echo "Performance Metrics:" > "$TEST_RESULTS_DIR/performance.txt"
							 | 
						|
								    echo "Write Time: ${write_time}ms for ${size_mb}MB" >> "$TEST_RESULTS_DIR/performance.txt"
							 | 
						|
								    echo "Read Time: ${read_time}ms for ${size_mb}MB" >> "$TEST_RESULTS_DIR/performance.txt"
							 | 
						|
								    echo "Write Throughput: $(bc <<< "scale=2; $size_mb * 1000 / $write_time") MB/s" >> "$TEST_RESULTS_DIR/performance.txt"
							 | 
						|
								    echo "Read Throughput: $(bc <<< "scale=2; $size_mb * 1000 / $read_time") MB/s" >> "$TEST_RESULTS_DIR/performance.txt"
							 | 
						|
								    
							 | 
						|
								    # Cleanup
							 | 
						|
								    rm -f "$test_file"
							 | 
						|
								    
							 | 
						|
								    # Performance test always passes (it's just for metrics)
							 | 
						|
								    return 0
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								# Main test execution
							 | 
						|
								main() {
							 | 
						|
								    echo -e "${BLUE}🚀 Starting integration tests...${NC}"
							 | 
						|
								    echo ""
							 | 
						|
								    
							 | 
						|
								    # Wait for mount to be ready
							 | 
						|
								    if ! wait_for_mount; then
							 | 
						|
								        echo -e "${RED}❌ Mount is not ready, aborting tests${NC}"
							 | 
						|
								        exit 1
							 | 
						|
								    fi
							 | 
						|
								    
							 | 
						|
								    # Check RDMA sidecar
							 | 
						|
								    check_rdma_sidecar || echo -e "${YELLOW}⚠️  RDMA sidecar check failed, continuing with tests${NC}"
							 | 
						|
								    
							 | 
						|
								    echo ""
							 | 
						|
								    echo -e "${BLUE}📋 Running test suite...${NC}"
							 | 
						|
								    echo ""
							 | 
						|
								    
							 | 
						|
								    # Run all tests
							 | 
						|
								    run_test "mount_accessibility" "test_mount_accessibility"
							 | 
						|
								    run_test "basic_file_operations" "test_basic_file_operations"
							 | 
						|
								    run_test "large_file_operations" "test_large_file_operations"
							 | 
						|
								    run_test "directory_operations" "test_directory_operations"
							 | 
						|
								    run_test "multiple_files" "test_multiple_files"
							 | 
						|
								    run_test "rdma_statistics" "test_rdma_statistics"
							 | 
						|
								    run_test "performance_baseline" "test_performance_baseline"
							 | 
						|
								    
							 | 
						|
								    # Generate test summary
							 | 
						|
								    echo -e "${BLUE}📊 TEST SUMMARY${NC}"
							 | 
						|
								    echo "==============="
							 | 
						|
								    echo "Total Tests: $TOTAL_TESTS"
							 | 
						|
								    echo -e "Passed: ${GREEN}$PASSED_TESTS${NC}"
							 | 
						|
								    echo -e "Failed: ${RED}$FAILED_TESTS${NC}"
							 | 
						|
								    
							 | 
						|
								    if [[ $FAILED_TESTS -eq 0 ]]; then
							 | 
						|
								        echo -e "${GREEN}🎉 ALL TESTS PASSED!${NC}"
							 | 
						|
								        echo "SUCCESS" > "$TEST_RESULTS_DIR/overall.result"
							 | 
						|
								        exit 0
							 | 
						|
								    else
							 | 
						|
								        echo -e "${RED}💥 SOME TESTS FAILED!${NC}"
							 | 
						|
								        echo "FAILURE" > "$TEST_RESULTS_DIR/overall.result"
							 | 
						|
								        exit 1
							 | 
						|
								    fi
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								# Run main function
							 | 
						|
								main "$@"
							 |