feat(flags): Add integration for custom tracking of flag evaluations #2316
Workflow file for this run
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
# Do not edit this file. This file is generated automatically by executing | |
# python scripts/split-tox-gh-actions/split-tox-gh-actions.py | |
name: Test AI | |
on: | |
push: | |
branches: | |
- master | |
- release/** | |
- sentry-sdk-2.0 | |
pull_request: | |
# Cancel in progress workflows on pull_requests. | |
# https://docs.github.com/en/actions/using-jobs/using-concurrency#example-using-a-fallback-value | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | |
cancel-in-progress: true | |
permissions: | |
contents: read | |
env: | |
BUILD_CACHE_KEY: ${{ github.sha }} | |
CACHED_BUILD_PATHS: | | |
${{ github.workspace }}/dist-serverless | |
jobs: | |
test-ai-latest: | |
name: AI (latest) | |
timeout-minutes: 30 | |
runs-on: ${{ matrix.os }} | |
strategy: | |
fail-fast: false | |
matrix: | |
python-version: ["3.7","3.9","3.11","3.12","3.13"] | |
# python3.6 reached EOL and is no longer being supported on | |
# new versions of hosted runners on Github Actions | |
# ubuntu-20.04 is the last version that supported python3.6 | |
# see https://github.com/actions/setup-python/issues/544#issuecomment-1332535877 | |
os: [ubuntu-20.04] | |
steps: | |
- uses: actions/[email protected] | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
allow-prereleases: true | |
- name: Setup Test Env | |
run: | | |
pip install "coverage[toml]" tox | |
- name: Erase coverage | |
run: | | |
coverage erase | |
- name: Test anthropic latest | |
run: | | |
set -x # print commands that are executed | |
./scripts/runtox.sh "py${{ matrix.python-version }}-anthropic-latest" | |
- name: Test cohere latest | |
run: | | |
set -x # print commands that are executed | |
./scripts/runtox.sh "py${{ matrix.python-version }}-cohere-latest" | |
- name: Test langchain latest | |
run: | | |
set -x # print commands that are executed | |
./scripts/runtox.sh "py${{ matrix.python-version }}-langchain-latest" | |
- name: Test openai latest | |
run: | | |
set -x # print commands that are executed | |
./scripts/runtox.sh "py${{ matrix.python-version }}-openai-latest" | |
- name: Test huggingface_hub latest | |
run: | | |
set -x # print commands that are executed | |
./scripts/runtox.sh "py${{ matrix.python-version }}-huggingface_hub-latest" | |
- name: Generate coverage XML (Python 3.6) | |
if: ${{ !cancelled() && matrix.python-version == '3.6' }} | |
run: | | |
export COVERAGE_RCFILE=.coveragerc36 | |
coverage combine .coverage-sentry-* | |
coverage xml --ignore-errors | |
- name: Generate coverage XML | |
if: ${{ !cancelled() && matrix.python-version != '3.6' }} | |
run: | | |
coverage combine .coverage-sentry-* | |
coverage xml | |
- name: Upload coverage to Codecov | |
if: ${{ !cancelled() }} | |
uses: codecov/[email protected] | |
with: | |
token: ${{ secrets.CODECOV_TOKEN }} | |
files: coverage.xml | |
# make sure no plugins alter our coverage reports | |
plugin: noop | |
verbose: true | |
- name: Upload test results to Codecov | |
if: ${{ !cancelled() }} | |
uses: codecov/test-results-action@v1 | |
with: | |
token: ${{ secrets.CODECOV_TOKEN }} | |
files: .junitxml | |
verbose: true | |
test-ai-pinned: | |
name: AI (pinned) | |
timeout-minutes: 30 | |
runs-on: ${{ matrix.os }} | |
strategy: | |
fail-fast: false | |
matrix: | |
python-version: ["3.8","3.9","3.11","3.12","3.13"] | |
# python3.6 reached EOL and is no longer being supported on | |
# new versions of hosted runners on Github Actions | |
# ubuntu-20.04 is the last version that supported python3.6 | |
# see https://github.com/actions/setup-python/issues/544#issuecomment-1332535877 | |
os: [ubuntu-20.04] | |
steps: | |
- uses: actions/[email protected] | |
- uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
allow-prereleases: true | |
- name: Setup Test Env | |
run: | | |
pip install "coverage[toml]" tox | |
- name: Erase coverage | |
run: | | |
coverage erase | |
- name: Test anthropic pinned | |
run: | | |
set -x # print commands that are executed | |
./scripts/runtox.sh --exclude-latest "py${{ matrix.python-version }}-anthropic" | |
- name: Test cohere pinned | |
run: | | |
set -x # print commands that are executed | |
./scripts/runtox.sh --exclude-latest "py${{ matrix.python-version }}-cohere" | |
- name: Test langchain pinned | |
run: | | |
set -x # print commands that are executed | |
./scripts/runtox.sh --exclude-latest "py${{ matrix.python-version }}-langchain" | |
- name: Test openai pinned | |
run: | | |
set -x # print commands that are executed | |
./scripts/runtox.sh --exclude-latest "py${{ matrix.python-version }}-openai" | |
- name: Test huggingface_hub pinned | |
run: | | |
set -x # print commands that are executed | |
./scripts/runtox.sh --exclude-latest "py${{ matrix.python-version }}-huggingface_hub" | |
- name: Generate coverage XML (Python 3.6) | |
if: ${{ !cancelled() && matrix.python-version == '3.6' }} | |
run: | | |
export COVERAGE_RCFILE=.coveragerc36 | |
coverage combine .coverage-sentry-* | |
coverage xml --ignore-errors | |
- name: Generate coverage XML | |
if: ${{ !cancelled() && matrix.python-version != '3.6' }} | |
run: | | |
coverage combine .coverage-sentry-* | |
coverage xml | |
- name: Upload coverage to Codecov | |
if: ${{ !cancelled() }} | |
uses: codecov/[email protected] | |
with: | |
token: ${{ secrets.CODECOV_TOKEN }} | |
files: coverage.xml | |
# make sure no plugins alter our coverage reports | |
plugin: noop | |
verbose: true | |
- name: Upload test results to Codecov | |
if: ${{ !cancelled() }} | |
uses: codecov/test-results-action@v1 | |
with: | |
token: ${{ secrets.CODECOV_TOKEN }} | |
files: .junitxml | |
verbose: true | |
check_required_tests: | |
name: All pinned AI tests passed | |
needs: test-ai-pinned | |
# Always run this, even if a dependent job failed | |
if: always() | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Check for failures | |
if: contains(needs.test-ai-pinned.result, 'failure') || contains(needs.test-ai-pinned.result, 'skipped') | |
run: | | |
echo "One of the dependent jobs has failed. You may need to re-run it." && exit 1 |