f16725e 3 months ago History
1 contributor
79 lines | 2.503kb
#!/bin/bash

# Test script pentru debugging autoSMART collector
# Acest script permite testarea manualelor cu debugging activ

SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
PROJECT_ROOT="$(dirname "$SCRIPT_DIR")"

echo "🔍 Testing autoSMART collector debugging..."
echo "Project root: $PROJECT_ROOT"

# Verifică dacă există configurația de debug
if [[ -f "/etc/default/autosmart" ]]; then
    echo "✓ Found configuration file: /etc/default/autosmart"
    echo "Current configuration:"
    cat /etc/default/autosmart
    echo ""
else
    echo "❌ Configuration file /etc/default/autosmart not found"
    echo "Creating test configuration..."
    sudo mkdir -p /etc/default
    sudo tee /etc/default/autosmart > /dev/null << 'EOF'
# AutoSMART Configuration - Test Debug Mode
AUTOSMART_DEBUG="true"
EOF
    echo "✓ Test configuration created"
fi

# Verifică dacă există fișierul de configurare pentru daemon
CONFIG_FILE="$PROJECT_ROOT/test-config.yaml"
if [[ ! -f "$CONFIG_FILE" ]]; then
    echo "Creating test configuration file: $CONFIG_FILE"
    cat > "$CONFIG_FILE" << 'EOF'
node:
  id: test-node
  scan_interval: 30
  store_unchanged: false
  
collection:
  full_scan_interval: 300
  
database:
  host: 192.168.2.102
  database: autosmart
  user: autosmart
  password: autosmart123
EOF
    echo "✓ Test config created: $CONFIG_FILE"
fi

echo ""
echo "🔧 Available devices for testing:"
ls -la /dev/sd* /dev/nvme* 2>/dev/null | head -10

echo ""
echo "💾 Testing database connectivity..."
if command -v psql >/dev/null; then
    echo "Testing connection to database..."
    psql -h 192.168.2.102 -U autosmart -d autosmart -c "SELECT 'Database connection OK' as status;" 2>/dev/null || echo "❌ Database connection failed"
else
    echo "❌ psql not available for testing"
fi

echo ""
echo "🚀 To run collector in debug mode:"
echo "export AUTOSMART_DEBUG=true"
echo "sudo -E perl $SCRIPT_DIR/smart-collector-daemon.pl --config $CONFIG_FILE --debug --foreground"

echo ""
echo "📊 To check hdd_presence table:"
echo "psql -h 192.168.2.102 -U autosmart -d autosmart -c \"SELECT * FROM hdd_presence;\""

echo ""
echo "📋 To check hdd_inventory table:"
echo "psql -h 192.168.2.102 -U autosmart -d autosmart -c \"SELECT id, serial_number, model_name, current_node_id, last_seen FROM hdd_inventory;\""

echo ""
echo "🔍 To check SMART readings:"
echo "psql -h 192.168.2.102 -U autosmart -d autosmart -c \"SELECT COUNT(*) as total_readings FROM smart_readings;\""