Skip to content

dev: when using multi devices, place sharding constraint on the fitne… #810

dev: when using multi devices, place sharding constraint on the fitne…

dev: when using multi devices, place sharding constraint on the fitne… #810

# This workflow will install Python dependencies, run tests and lint with a variety of Python versions
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-python
name: Python package
on:
push:
branches: [ "main" ]
pull_request:
branches: [ "main" ]
jobs:
build:
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
python-version: ["3.10", "3.11", "3.12"]
steps:
- uses: actions/checkout@v3
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
cache: pip
cache-dependency-path: requirements/test-requirements.txt
- name: Install build dependencies
run: |
python -m pip install --upgrade pip
python -m pip install build wheel setuptools pytest
- name: Build and install package Python 3.10 and above
run: |
output=$(python -m build --wheel)
if [[ "${{ matrix.python-version }}" == "3.12" ]]; then
# Exclude envpool when testing with Python 3.12
pip install dist/${output##* }[test]
pip install gymnasium ray gpjax plotly pandas tensorflow-datasets grain brax plotly pandas
else
pip install dist/${output##* }[full,test]
fi
- name: Test with pytest Python 3.10 and above
run: |
if [[ "${{ matrix.python-version }}" == "3.12" ]]; then
pytest -k 'not test_envpool_cartpole'
else
pytest
fi