Add a Makefile again #807
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Test Suite | |
on: | |
pull_request: | |
push: | |
branches: | |
- main | |
jobs: | |
test: | |
name: Python ${{ matrix.python-version }} - ${{ matrix.connection }} [redis-stack ${{matrix.redis-stack-version}}] | |
runs-on: ubuntu-latest | |
strategy: | |
fail-fast: false | |
matrix: | |
python-version: [3.9, '3.10', 3.11] | |
connection: ['hiredis', 'plain'] | |
redis-stack-version: ['6.2.6-v9', 'latest', 'edge'] | |
services: | |
redis: | |
image: redis/redis-stack-server:${{matrix.redis-stack-version}} | |
ports: | |
- 6379:6379 | |
steps: | |
- uses: actions/checkout@v2 | |
- name: Set up Python ${{ matrix.python-version }} | |
uses: actions/setup-python@v4 | |
with: | |
python-version: ${{ matrix.python-version }} | |
cache: 'pip' | |
- name: Install Poetry | |
uses: snok/install-poetry@v1 | |
with: | |
version: 1.8.3 | |
- name: Install dependencies | |
run: | | |
poetry install --all-extras | |
- name: Install hiredis if needed | |
if: matrix.connection == 'hiredis' | |
run: | | |
poetry add hiredis | |
- name: Set Redis version | |
run: | | |
echo "REDIS_VERSION=${{ matrix.redis-stack-version }}" >> $GITHUB_ENV | |
- name: Authenticate to Google Cloud | |
uses: google-github-actions/auth@v1 | |
with: | |
credentials_json: ${{ secrets.GOOGLE_CREDENTIALS }} | |
- name: Run tests | |
if: matrix.connection == 'plain' && matrix.redis-stack-version == 'latest' | |
env: | |
OPENAI_API_KEY: ${{ secrets.OPENAI_KEY }} | |
GCP_LOCATION: ${{ secrets.GCP_LOCATION }} | |
GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} | |
COHERE_API_KEY: ${{ secrets.COHERE_API_KEY }} | |
MISTRAL_API_KEY: ${{ secrets.MISTRAL_API_KEY }} | |
VOYAGE_API_KEY: ${{ secrets.VOYAGE_API_KEY }} | |
AZURE_OPENAI_API_KEY: ${{secrets.AZURE_OPENAI_API_KEY}} | |
AZURE_OPENAI_ENDPOINT: ${{secrets.AZURE_OPENAI_ENDPOINT}} | |
AZURE_OPENAI_DEPLOYMENT_NAME: ${{secrets.AZURE_OPENAI_DEPLOYMENT_NAME}} | |
OPENAI_API_VERSION: ${{secrets.OPENAI_API_VERSION}} | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
run: | | |
poetry run test-cov | |
- name: Run tests | |
if: matrix.connection != 'plain' || matrix.redis-stack-version != 'latest' | |
run: | | |
SKIP_VECTORIZERS=True SKIP_RERANKERS=True poetry run test-cov | |
- name: Run notebooks | |
if: matrix.connection == 'plain' && matrix.redis-stack-version == 'latest' | |
env: | |
OPENAI_API_KEY: ${{ secrets.OPENAI_KEY }} | |
GCP_LOCATION: ${{ secrets.GCP_LOCATION }} | |
GCP_PROJECT_ID: ${{ secrets.GCP_PROJECT_ID }} | |
COHERE_API_KEY: ${{ secrets.COHERE_API_KEY }} | |
MISTRAL_API_KEY: ${{ secrets.MISTRAL_API_KEY }} | |
VOYAGE_API_KEY: ${{ secrets.VOYAGE_API_KEY }} | |
AZURE_OPENAI_API_KEY: ${{secrets.AZURE_OPENAI_API_KEY}} | |
AZURE_OPENAI_ENDPOINT: ${{secrets.AZURE_OPENAI_ENDPOINT}} | |
AZURE_OPENAI_DEPLOYMENT_NAME: ${{secrets.AZURE_OPENAI_DEPLOYMENT_NAME}} | |
OPENAI_API_VERSION: ${{secrets.OPENAI_API_VERSION}} | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
run: | | |
cd docs/ && poetry run treon -v | |
- name: Publish coverage results | |
uses: codecov/codecov-action@v4 | |
with: | |
token: ${{ secrets.CODECOV_TOKEN }} | |
files: ./coverage.xml | |
fail_ci_if_error: false |