Skip to content

modified plan to have a single worker pool #56

modified plan to have a single worker pool

modified plan to have a single worker pool #56

name: Test Basic Functionality - Redis Vector Sets
on:
push:
pull_request:
jobs:
test-basic-functionality:
runs-on: ubuntu-latest
strategy:
matrix:
python-version: ['3.10', '3.11', '3.12', '3.13']
services:
redis:
image: redis:8.2-rc1-bookworm
ports:
- 6379:6379
options: >-
--health-cmd "redis-cli ping"
--health-interval 10s
--health-timeout 5s
--health-retries 5
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
- name: Install Poetry
uses: snok/install-poetry@v1
with:
version: latest
virtualenvs-create: true
virtualenvs-in-project: true
- name: Install dependencies
run: |
poetry install --no-root
- name: Install Redis CLI
run: |
sudo apt-get update
sudo apt-get install -y redis-tools
- name: Wait for Redis to be ready
run: |
echo "Waiting for Redis to be ready..."
timeout 30 bash -c 'until redis-cli -h localhost -p 6379 ping; do sleep 1; done'
echo "Redis is ready!"
- name: Test describe functionality
run: |
echo "Testing --describe commands..."
poetry run python run.py --describe datasets | head -10
poetry run python run.py --describe engines | head -10
echo "✅ Describe functionality works"
- name: Test basic benchmark functionality
run: |
echo "Testing basic benchmark with Redis..."
echo "Running: python run.py --host localhost --engines redis-default-simple --datasets glove-25-angular --queries 10"
# Run with limited queries for faster testing
poetry run python run.py \
--host localhost \
--engines vectorsets-fp32-default \
--datasets random-100 \
--queries 10 \
--timeout 300
- name: Verify results were generated
run: |
echo "Checking if results were generated..."
if [ -d "results" ] && [ "$(ls -A results)" ]; then
echo "✅ Results directory contains files:"
ls -la results/
# Check for summary file
if ls results/*summary.json 1> /dev/null 2>&1; then
echo "✅ Summary file found"
echo "Sample summary content:"
head -20 results/*summary.json
else
echo "⚠️ No summary file found"
fi
# Check for experiment files
if ls results/*redis-default-simple*.json 1> /dev/null 2>&1; then
echo "✅ Experiment result files found"
else
echo "⚠️ No experiment result files found"
fi
else
echo "❌ No results generated"
exit 1
fi
- name: Test with skip options
run: |
echo "Testing with --skip-upload (search only)..."
poetry run python run.py \
--host localhost \
--engines vectorsets-fp32-default \
--datasets random-100 \
--queries 50 \
--skip-upload \
--timeout 180
echo "✅ Skip upload test completed"
- name: Cleanup
run: |
echo "Cleaning up test files..."
rm -rf datasets/random-100/
rm -rf results/
echo "✅ Cleanup completed"