#!/bin/bash

# Build script for ProofBench mathematical evaluation container

set -e  # Exit on any error

# Check for Docker
if ! command -v docker &> /dev/null; then
    echo "❌ Error: Docker not found!"
    echo "Install Docker: https://docs.docker.com/engine/install/"
    exit 1
fi

echo "🔨 Building ProofBench container with Docker..."
docker --version

# Build the image
docker build -t proofbench-math:latest .

echo "✅ Container built successfully!"

# Test the container as mathuser (since that's who will run evaluations)
echo "🧪 Testing container as mathuser..."

# Test regular Python packages
docker run --rm --user mathuser proofbench-math:latest python -c "
import sys
print(f'Python version: {sys.version}')

try:
    import sage
    print('✅ SageMath: Available')
except ImportError as e:
    print(f'❌ SageMath: {e}')

try:
    import numpy, scipy, sympy, matplotlib, pandas
    print('✅ Core math libraries: Available')
except ImportError as e:
    print(f'❌ Core math libraries: {e}')

try:
    import pickle, json, ast
    print('✅ Standard tools (pickle, json, ast): Available')
except ImportError as e:
    print(f'❌ Standard tools: {e}')
"

# Test Sage-specific packages (installed via system Python, as Arch's Sage uses system Python)
docker run --rm --user mathuser proofbench-math:latest python -c "
try:
    import admcycles
    print('✅ admcycles: Available')
except ImportError as e:
    print(f'❌ admcycles: {e}')

try:
    import ore_algebra
    print('✅ ore_algebra: Available')
except ImportError as e:
    print(f'❌ ore_algebra: {e}')
"

echo "🎉 Container ready for use!"
echo "📋 To use with Inspect AI, the image name is: proofbench-math:latest"