Skip to content

fix(sessions): for each session record first user by span start time #10727

fix(sessions): for each session record first user by span start time

fix(sessions): for each session record first user by span start time #10727

Workflow file for this run

name: Python CI
on:
push:
branches: [main, sessions]
pull_request:
paths:
- "src/**"
- "tests/**"
- "tutorials/**"
- "pyproject.toml"
- "packages/**"
- "tox.ini"
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
concurrency:
group: test-python-${{ github.head_ref }}
cancel-in-progress: true
env:
pip-version: 24.2
OPENAI_API_KEY: "sk-fake-openai-key" # fake openai key so that llama_index doesn't download huggingface embeddings
jobs:
changes:
name: Filter Changes
runs-on: ubuntu-latest
outputs:
ipynb: ${{ steps.filter.outputs.ipynb }}
ipynb_files: ${{ steps.filter.outputs.ipynb_files }}
proto: ${{ steps.filter.outputs.proto }}
phoenix: ${{ steps.filter.outputs.phoenix }}
phoenix_evals: ${{ steps.filter.outputs.phoenix_evals }}
phoenix_otel: ${{ steps.filter.outputs.phoenix_otel }}
steps:
- uses: actions/checkout@v4
- uses: dorny/paths-filter@v3
id: filter
with:
list-files: shell
filters: |
ipynb:
- "**/*.ipynb"
proto:
- "src/phoenix/proto/**"
- "src/phoenix/trace/v1/**"
phoenix:
- "src/**"
- "tests/**"
- "tutorials/**"
- "pyproject.toml"
- "tox.ini"
phoenix_evals:
- "packages/phoenix-evals/**"
- "tox.ini"
phoenix_otel:
- "packages/phoenix-otel/**"
- "tox.ini"
clean-jupyter-notebooks:
name: Clean Jupyter notebooks
runs-on: ubuntu-latest
needs: changes
if: ${{ needs.changes.outputs.ipynb == 'true' }}
steps:
- name: Checkout Repository
uses: actions/checkout@v4
- name: Set up python 3.9
uses: actions/setup-python@v5
with:
python-version: 3.9
- name: Install dependencies
run: |
python -m pip install --upgrade pip==${{ env.pip-version }}
pip install hatch
- name: Check notebooks have cleaned output and metadata
run: hatch run notebooks:clean
- run: git diff --exit-code
phoenix-evals:
name: Phoenix Evals
runs-on: ${{ matrix.os }}
needs: changes
if: ${{ needs.changes.outputs.phoenix_evals == 'true' }}
strategy:
matrix:
py: [3.8, 3.12]
os: [ubuntu-latest, windows-latest, macos-13]
steps:
- uses: actions/checkout@v4
with:
sparse-checkout: |
requirements/
packages/phoenix-evals/
- uses: actions/setup-python@v5
with:
python-version: ${{ matrix.py }}
- uses: astral-sh/setup-uv@v3
with:
version: 0.4.25
- run: uvx --with tox-uv tox run -e phoenix_evals -- -ra -x
phoenix-otel:
name: Phoenix OTel
runs-on: ${{ matrix.os }}
needs: changes
if: ${{ needs.changes.outputs.phoenix_otel == 'true' }}
strategy:
matrix:
py: [3.8, 3.13]
os: [ubuntu-latest, windows-latest, macos-13]
steps:
- uses: actions/checkout@v4
with:
sparse-checkout: |
requirements/
packages/phoenix-otel/
- uses: actions/setup-python@v5
with:
python-version: ${{ matrix.py }}
- uses: astral-sh/setup-uv@v3
with:
version: 0.4.25
- run: uvx --with tox-uv tox run -e phoenix_otel -- -ra -x
# clean-jupyter-notebooks:
# name: Clean Jupyter Notebooks
# needs: changes
# if: ${{ needs.changes.outputs.ipynb == 'true' }}
# strategy:
# matrix:
# py: [ 3.12 ]
# os: [ ubuntu-latest ]
# runs-on: ${{ matrix.os }}
# steps:
# - name: Checkout repository
# uses: actions/checkout@v4
# - name: Set up Python ${{ matrix.py }}
# uses: actions/setup-python@v5
# with:
# python-version: ${{ matrix.py }}
# - name: Set up `uv`
# uses: astral-sh/setup-uv@v3
# with:
# version: 0.4.25
# enable-cache: true
# cache-dependency-glob: |
# pyproject.toml
# requirements/clean-jupyter-notebooks.txt
# github-token: ${{ secrets.GITHUB_TOKEN }}
# - name: Clean Jupyter notebooks
# run: uvx --with tox-uv tox run -e clean_jupyter_notebooks -- ${{ needs.changes.outputs.ipynb_files }}
# - run: git diff --exit-code
build-graphql-schema:
name: Build GraphQL Schema
needs: changes
if: ${{ needs.changes.outputs.phoenix == 'true' }}
strategy:
matrix:
py: [3.12]
os: [ubuntu-latest]
runs-on: ${{ matrix.os }}
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Python ${{ matrix.py }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.py }}
- name: Set up `uv`
uses: astral-sh/setup-uv@v3
with:
version: 0.4.25
enable-cache: true
cache-dependency-glob: |
pyproject.toml
requirements/build-graphql-schema.txt
github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Build GraphQL schema
run: uvx --with tox-uv tox run -e build_graphql_schema
- run: git diff --exit-code
build-openapi-schema:
name: Build OpenAPI Schema
needs: changes
if: ${{ needs.changes.outputs.phoenix == 'true' }}
strategy:
matrix:
py: [3.12]
os: [ubuntu-latest]
runs-on: ${{ matrix.os }}
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Python ${{ matrix.py }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.py }}
- name: Set up `uv`
uses: astral-sh/setup-uv@v3
with:
version: 0.4.25
enable-cache: true
cache-dependency-glob: |
pyproject.toml
github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Build OpenAPI schema
run: uvx --with tox-uv tox run -e build_openapi_schema
- run: git diff --exit-code
compile-protobuf:
name: Compile Protobuf
needs: changes
if: ${{ needs.changes.outputs.proto == 'true' }}
strategy:
matrix:
# uv fails on 3.12 as of 10/16/2024 when installing protobuf dependencies
py: [3.11]
os: [ubuntu-latest]
runs-on: ${{ matrix.os }}
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Python ${{ matrix.py }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.py }}
- name: Set up `uv`
uses: astral-sh/setup-uv@v3
with:
version: 0.4.25
enable-cache: true
cache-dependency-glob: |
pyproject.toml
requirements/compile-protobuf.txt
github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Compile Protobuf
run: uvx --with tox-uv tox run -e compile_protobuf
- run: git diff --exit-code
ruff:
name: Ruff
runs-on: ${{ matrix.os }}
strategy:
matrix:
py: [3.12]
os: [ubuntu-latest]
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Python ${{ matrix.py }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.py }}
- name: Set up `uv`
uses: astral-sh/setup-uv@v3
with:
version: 0.4.25
- name: Run `ruff`
run: uvx --with tox-uv tox run -e ruff
- run: git diff --exit-code
type-check:
name: Type Check
runs-on: ${{ matrix.os }}
needs: changes
if: ${{ needs.changes.outputs.phoenix == 'true' }}
strategy:
matrix:
py: [3.9, 3.12]
os: [ubuntu-latest]
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
sparse-checkout: |
requirements/
src/phoenix/
tests/
- name: Set up Python ${{ matrix.py }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.py }}
- name: Set up `uv`
uses: astral-sh/setup-uv@v3
with:
version: 0.4.25
enable-cache: true
cache-dependency-glob: |
pyproject.toml
requirements/ci.txt
requirements/type-check.txt
github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Check types
run: uvx --with tox-uv tox run -e type_check
type-check-unit-tests:
name: Type Check Unit Tests
runs-on: ${{ matrix.os }}
needs: changes
if: ${{ needs.changes.outputs.phoenix == 'true' }}
strategy:
matrix:
py: [3.9, 3.12]
os: [ubuntu-latest]
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
sparse-checkout: |
requirements/
src/phoenix/
tests/
- name: Set up Python ${{ matrix.py }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.py }}
- name: Set up `uv`
uses: astral-sh/setup-uv@v3
with:
version: 0.4.25
enable-cache: true
cache-dependency-glob: |
pyproject.toml
requirements/ci.txt
requirements/unit-tests.txt
github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Check types on unit tests
run: uvx --with tox-uv tox run -e type_check_unit_tests
unit-tests:
name: Unit Tests
runs-on: ${{ matrix.os }}
needs: changes
if: ${{ needs.changes.outputs.phoenix == 'true' }}
strategy:
matrix:
py: [3.9, 3.12]
os: [ubuntu-latest, windows-latest, macos-13]
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
sparse-checkout: |
requirements/
src/phoenix/
tests/unit/
tests/conftest.py
- name: Set up Python ${{ matrix.py }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.py }}
- name: Set up `uv`
uses: astral-sh/setup-uv@v3
with:
version: 0.4.25
enable-cache: true
cache-dependency-glob: |
pyproject.toml
requirements/ci.txt
requirements/unit-tests.txt
github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Install PostgreSQL (Linux)
if: runner.os == 'Linux'
run: sudo apt-get -yqq install postgresql
- name: Run tests with PostgreSQL (Linux)
if: runner.os == 'Linux'
run: uvx --with tox-uv tox run -e unit_tests -- -ra -x --run-postgres
- name: Run tests without PostgreSQL (non-Linux)
if: runner.os != 'Linux'
run: uvx --with tox-uv tox run -e unit_tests -- -ra -x
type-check-integration-tests:
name: Type Check Integration Tests
runs-on: ${{ matrix.os }}
needs: changes
if: ${{ needs.changes.outputs.phoenix == 'true' }}
strategy:
matrix:
py: [3.9, 3.12]
os: [ubuntu-latest]
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
sparse-checkout: |
requirements/
src/phoenix/
tests/integration/
- name: Set up Python ${{ matrix.py }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.py }}
- name: Set up `uv`
uses: astral-sh/setup-uv@v3
with:
version: 0.4.25
enable-cache: true
cache-dependency-glob: |
pyproject.toml
requirements/ci.txt
requirements/integration-tests.txt
github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Check types on integration tests
run: uvx --with tox-uv tox run -e type_check_integration_tests
integration-tests:
name: Integration Tests
runs-on: ${{ matrix.os }}
needs: changes
if: ${{ needs.changes.outputs.phoenix == 'true' }}
strategy:
matrix:
py: [3.9, 3.12]
db: [sqlite, postgresql]
os: [ubuntu-latest, windows-latest, macos-13]
exclude:
- db: postgresql
os: windows-latest
- db: postgresql
os: macos-13
env:
CI_TEST_DB_BACKEND: ${{ matrix.db }}
services:
postgres:
# Applying this workaround: https://github.com/actions/runner/issues/822
image: ${{ (matrix.db == 'postgresql') && 'postgres:12' || '' }}
env:
POSTGRES_PASSWORD: phoenix
options: >-
--health-cmd pg_isready
--health-interval 10s
--health-timeout 5s
--health-retries 5
ports:
- 5432:5432
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
sparse-checkout: |
requirements/
src/phoenix/
tests/integration/
- name: Set up Python ${{ matrix.py }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.py }}
- name: Set up `uv`
uses: astral-sh/setup-uv@v3
with:
version: 0.4.25
enable-cache: true
cache-dependency-glob: |
pyproject.toml
requirements/ci.txt
requirements/integration-tests.txt
github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Run integration tests
run: uvx --with tox-uv tox run -e integration_tests -- -ra -x -n auto --reruns 5