Media Pipe Pose Estimation + Visualization #357
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: tests | |
on: | |
pull_request: | |
types: [opened, synchronize, reopened, labeled] | |
jobs: | |
macos-tests: | |
if: github.event.pull_request.draft == false && contains(github.event.pull_request.labels.*.name, 'to-test') | |
name: macOS-tests | |
runs-on: ${{ matrix.os }} | |
strategy: | |
fail-fast: true | |
matrix: | |
include: | |
- {os: macos-latest, architecture: arm64, python-version: '3.10'} | |
# - {os: macos-latest, architecture: arm64, python-version: '3.11'} | |
# - {os: macos-latest, architecture: arm64, python-version: '3.12'} | |
# the reason why we commented out 3.11 and 3.12 is that it hits github rate limit for some modules (e.g., knn-vc, Camb-ai/mars5-tts) | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 1 # no need for the history | |
- name: Set up Python ${{ matrix.python-version }} | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install ffmpeg (Ubuntu) | |
if: startsWith(matrix.os, 'ubuntu') | |
run: sudo apt-get update && sudo apt-get install -y ffmpeg | |
shell: bash | |
- name: Install ffmpeg (macOS) | |
if: startsWith(matrix.os, 'macos') | |
run: brew install ffmpeg | |
shell: bash | |
- name: Install Poetry | |
uses: snok/install-poetry@v1 | |
with: | |
virtualenvs-create: true | |
virtualenvs-in-project: true | |
- name: Install dependencies with Poetry | |
run: | | |
poetry install --with dev | |
shell: bash | |
- name: check files | |
run: | | |
ls /Users/runner/work/senselab/senselab/src/tests/data_for_testing/ | |
shell: bash | |
- name: check pwd | |
run: pwd | |
shell: bash | |
- name: Run unit tests | |
id: run-tests | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
HF_TOKEN: ${{ secrets.HF_TOKEN }} | |
run: > | |
poetry run pytest -n auto \ | |
--junitxml=pytest.xml \ | |
--cov-report=term-missing:skip-covered \ | |
--cov-report=xml:coverage.xml \ | |
--cov=src src/tests \ | |
--log-level=DEBUG \ | |
--verbose | |
shell: bash | |
- name: Upload coverage to Codecov | |
uses: codecov/codecov-action@v5 | |
with: | |
token: ${{ secrets.CODECOV_TOKEN }} | |
pre-commit: | |
if: github.event.pull_request.draft == false && contains(github.event.pull_request.labels.*.name, 'to-test') | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ubuntu-latest] | |
python-version: ['3.10'] | |
steps: | |
- uses: actions/checkout@v4 | |
with: # no need for the history | |
fetch-depth: 1 | |
- name: Set up Python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install Poetry | |
uses: snok/install-poetry@v1 | |
with: | |
virtualenvs-create: true | |
virtualenvs-in-project: true | |
- name: Install dependencies with Poetry | |
run: | | |
poetry install --with dev | |
shell: bash | |
- name: Install pre-commit | |
run: pipx install pre-commit | |
shell: bash | |
- name: Run pre-commit | |
run: | | |
poetry run pre-commit run --all-files | |
shell: bash | |
start-runner-310: | |
if: github.event.pull_request.draft == false && contains(github.event.pull_request.labels.*.name, 'to-test-gpu') && success() | |
needs: | |
- pre-commit | |
- macos-tests | |
name: start-runner-310 | |
runs-on: ubuntu-latest | |
outputs: | |
label: ${{ steps.start-ec2-runner.outputs.label }} | |
ec2-instance-id: ${{ steps.start-ec2-runner.outputs.ec2-instance-id }} | |
job-ran: ${{ steps.set-ran.outputs.ran }} | |
steps: | |
- id: set-ran | |
run: echo "::set-output name=ran::true" | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_KEY_SECRET }} | |
aws-region: ${{ vars.AWS_REGION }} | |
- name: Start EC2 runner | |
id: start-ec2-runner | |
uses: machulav/ec2-github-runner@v2 | |
with: | |
mode: start | |
github-token: ${{ secrets.GH_TOKEN }} | |
ec2-image-id: ${{ vars.AWS_IMAGE_ID }} | |
ec2-instance-type: ${{ vars.AWS_INSTANCE_TYPE }} | |
subnet-id: ${{ vars.AWS_SUBNET }} | |
security-group-id: ${{ vars.AWS_SECURITY_GROUP }} | |
ubuntu-tests-310: | |
name: ubuntu-tests-310 | |
needs: start-runner-310 | |
runs-on: ${{ needs.start-runner-310.outputs.label }} | |
defaults: | |
run: | |
shell: bash | |
working-directory: ${{ vars.WORKING_DIR }} | |
strategy: | |
matrix: | |
python-version: ['3.10'] | |
env: | |
WORKING_DIR: ${{ vars.WORKING_DIR }} | |
POETRY_CACHE_DIR: ${{ vars.WORKING_DIR }} | |
outputs: | |
job-ran: ${{ steps.set-ran.outputs.ran }} | |
steps: | |
- id: set-ran | |
run: echo "::set-output name=ran::true" | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 1 # no need for the history | |
- name: Set up Python ${{ matrix.python-version }} | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install ffmpeg (Ubuntu) | |
if: startsWith(matrix.os, 'ubuntu') | |
run: sudo apt-get update && sudo apt-get install -y ffmpeg | |
shell: bash | |
- name: Install Poetry | |
uses: snok/install-poetry@v1 | |
with: | |
virtualenvs-create: true | |
virtualenvs-in-project: true | |
- name: Check available space | |
run: | | |
df -h | |
shell: bash | |
- name: Echo python info | |
run: | | |
python --version | |
which python | |
shell: bash | |
- name: Copy senselab directory to current directory | |
run: | | |
cp -r /actions-runner/_work/senselab/senselab . | |
- name: Install dependencies with Poetry | |
run: | | |
cd senselab | |
poetry env use ${{ matrix.python-version }} | |
poetry install --with dev | |
shell: bash | |
- name: Check poetry info | |
run: | | |
cd senselab | |
poetry env info | |
poetry --version | |
shell: bash | |
- name: Check NVIDIA SMI details | |
run: | | |
cd senselab | |
poetry run nvidia-smi | |
poetry run nvidia-smi -L | |
poetry run nvidia-smi -q -d Memory | |
shell: bash | |
- name: Prepare cache folder for pytest | |
run: mkdir -p $WORKING_DIR/pytest/temp | |
shell: bash | |
- name: Run unit tests | |
id: run-tests | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
HF_TOKEN: ${{ secrets.HF_TOKEN }} | |
run: > | |
cd senselab && poetry run pytest \ | |
--rootdir=$WORKING_DIR/pytest \ | |
--basetemp=$WORKING_DIR/pytest/temp \ | |
--junitxml=pytest.xml \ | |
--cov-report=term-missing:skip-covered \ | |
--cov-report=xml:coverage.xml \ | |
--cov=src src/tests \ | |
--log-level=DEBUG \ | |
--verbose | |
shell: bash | |
stop-runner-310: | |
name: stop-runner-310 | |
needs: | |
- start-runner-310 # waits for the EC2 instance to be created | |
- ubuntu-tests-310 # waits for the actual job to finish | |
runs-on: ubuntu-latest | |
if: ${{ needs.start-runner-310.outputs.job-ran == 'true' && needs.ubuntu-tests-310.outputs.job-ran == 'true' || failure() }} # required to stop the runner even if an error occurred in previous jobs | |
steps: | |
- name: Check available space | |
run: | | |
df -h | |
shell: bash | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_KEY_SECRET }} | |
aws-region: ${{ vars.AWS_REGION }} | |
- name: Stop EC2 runner | |
uses: machulav/ec2-github-runner@v2 | |
with: | |
mode: stop | |
github-token: ${{ secrets.GH_TOKEN }} | |
label: ${{ needs.start-runner-310.outputs.label }} | |
ec2-instance-id: ${{ needs.start-runner-310.outputs.ec2-instance-id }} | |
start-runner-311: | |
if: github.event.pull_request.draft == false && contains(github.event.pull_request.labels.*.name, 'to-test-gpu') && success() | |
needs: | |
- pre-commit | |
- macos-tests | |
name: start-runner-311 | |
runs-on: ubuntu-latest | |
outputs: | |
label: ${{ steps.start-ec2-runner.outputs.label }} | |
ec2-instance-id: ${{ steps.start-ec2-runner.outputs.ec2-instance-id }} | |
job-ran: ${{ steps.set-ran.outputs.ran }} | |
steps: | |
- id: set-ran | |
run: echo "::set-output name=ran::true" | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_KEY_SECRET }} | |
aws-region: ${{ vars.AWS_REGION }} | |
- name: Start EC2 runner | |
id: start-ec2-runner | |
uses: machulav/ec2-github-runner@v2 | |
with: | |
mode: start | |
github-token: ${{ secrets.GH_TOKEN }} | |
ec2-image-id: ${{ vars.AWS_IMAGE_ID }} | |
ec2-instance-type: ${{ vars.AWS_INSTANCE_TYPE }} | |
subnet-id: ${{ vars.AWS_SUBNET }} | |
security-group-id: ${{ vars.AWS_SECURITY_GROUP }} | |
ubuntu-tests-311: | |
name: ubuntu-tests-311 | |
needs: start-runner-311 | |
runs-on: ${{ needs.start-runner-311.outputs.label }} | |
defaults: | |
run: | |
shell: bash | |
working-directory: ${{ vars.WORKING_DIR }} | |
strategy: | |
matrix: | |
python-version: ['3.11'] | |
env: | |
WORKING_DIR: ${{ vars.WORKING_DIR }} | |
POETRY_CACHE_DIR: ${{ vars.WORKING_DIR }} | |
outputs: | |
job-ran: ${{ steps.set-ran.outputs.ran }} | |
steps: | |
- id: set-ran | |
run: echo "::set-output name=ran::true" | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 1 # no need for the history | |
- name: Set up Python ${{ matrix.python-version }} | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install ffmpeg (Ubuntu) | |
if: startsWith(matrix.os, 'ubuntu') | |
run: sudo apt-get update && sudo apt-get install -y ffmpeg | |
shell: bash | |
- name: Install Poetry | |
uses: snok/install-poetry@v1 | |
with: | |
virtualenvs-create: true | |
virtualenvs-in-project: true | |
- name: Check available space | |
run: | | |
df -h | |
shell: bash | |
- name: Echo python info | |
run: | | |
python --version | |
which python | |
shell: bash | |
- name: Copy senselab directory to current directory | |
run: | | |
cp -r /actions-runner/_work/senselab/senselab . | |
- name: Install dependencies with Poetry | |
run: | | |
cd senselab | |
poetry env use ${{ matrix.python-version }} | |
poetry install --with dev | |
shell: bash | |
- name: Check poetry info | |
run: | | |
cd senselab | |
poetry env info | |
poetry --version | |
shell: bash | |
- name: Check NVIDIA SMI details | |
run: | | |
cd senselab | |
poetry run nvidia-smi | |
poetry run nvidia-smi -L | |
poetry run nvidia-smi -q -d Memory | |
shell: bash | |
- name: Prepare cache folder for pytest | |
run: mkdir -p $WORKING_DIR/pytest/temp | |
shell: bash | |
- name: Run unit tests | |
id: run-tests | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
HF_TOKEN: ${{ secrets.HF_TOKEN }} | |
run: > | |
cd senselab && poetry run pytest \ | |
--rootdir=$WORKING_DIR/pytest \ | |
--basetemp=$WORKING_DIR/pytest/temp \ | |
--junitxml=pytest.xml \ | |
--cov-report=term-missing:skip-covered \ | |
--cov-report=xml:coverage.xml \ | |
--cov=src src/tests \ | |
--log-level=DEBUG \ | |
--verbose | |
shell: bash | |
stop-runner-311: | |
name: stop-runner-311 | |
needs: | |
- start-runner-311 # waits for the EC2 instance to be created | |
- ubuntu-tests-311 # waits for the actual job to finish | |
runs-on: ubuntu-latest | |
if: ${{ needs.start-runner-311.outputs.job-ran == 'true' && needs.ubuntu-tests-311.outputs.job-ran == 'true' || failure() }} # required to stop the runner even if an error occurred in previous jobs | |
steps: | |
- name: Check available space | |
run: | | |
df -h | |
shell: bash | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_KEY_SECRET }} | |
aws-region: ${{ vars.AWS_REGION }} | |
- name: Stop EC2 runner | |
uses: machulav/ec2-github-runner@v2 | |
with: | |
mode: stop | |
github-token: ${{ secrets.GH_TOKEN }} | |
label: ${{ needs.start-runner-311.outputs.label }} | |
ec2-instance-id: ${{ needs.start-runner-311.outputs.ec2-instance-id }} | |
start-runner-312: | |
if: github.event.pull_request.draft == false && contains(github.event.pull_request.labels.*.name, 'to-test-gpu') && success() | |
needs: | |
- pre-commit | |
- macos-tests | |
name: start-runner-312 | |
runs-on: ubuntu-latest | |
outputs: | |
label: ${{ steps.start-ec2-runner.outputs.label }} | |
ec2-instance-id: ${{ steps.start-ec2-runner.outputs.ec2-instance-id }} | |
job-ran: ${{ steps.set-ran.outputs.ran }} | |
steps: | |
- id: set-ran | |
run: echo "::set-output name=ran::true" | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_KEY_SECRET }} | |
aws-region: ${{ vars.AWS_REGION }} | |
- name: Start EC2 runner | |
id: start-ec2-runner | |
uses: machulav/ec2-github-runner@v2 | |
with: | |
mode: start | |
github-token: ${{ secrets.GH_TOKEN }} | |
ec2-image-id: ${{ vars.AWS_IMAGE_ID }} | |
ec2-instance-type: ${{ vars.AWS_INSTANCE_TYPE }} | |
subnet-id: ${{ vars.AWS_SUBNET }} | |
security-group-id: ${{ vars.AWS_SECURITY_GROUP }} | |
ubuntu-tests-312: | |
name: ubuntu-tests-312 | |
needs: start-runner-312 | |
runs-on: ${{ needs.start-runner-312.outputs.label }} | |
defaults: | |
run: | |
shell: bash | |
working-directory: ${{ vars.WORKING_DIR }} | |
strategy: | |
matrix: | |
python-version: ['3.12'] | |
env: | |
WORKING_DIR: ${{ vars.WORKING_DIR }} | |
POETRY_CACHE_DIR: ${{ vars.WORKING_DIR }} | |
outputs: | |
job-ran: ${{ steps.set-ran.outputs.ran }} | |
steps: | |
- id: set-ran | |
run: echo "::set-output name=ran::true" | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 1 # no need for the history | |
- name: Set up Python ${{ matrix.python-version }} | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install ffmpeg (Ubuntu) | |
if: startsWith(matrix.os, 'ubuntu') | |
run: sudo apt-get update && sudo apt-get install -y ffmpeg | |
shell: bash | |
- name: Install Poetry | |
uses: snok/install-poetry@v1 | |
with: | |
virtualenvs-create: true | |
virtualenvs-in-project: true | |
- name: Check available space | |
run: | | |
df -h | |
shell: bash | |
- name: Echo python info | |
run: | | |
python --version | |
which python | |
shell: bash | |
- name: Copy senselab directory to current directory | |
run: | | |
cp -r /actions-runner/_work/senselab/senselab . | |
- name: Install dependencies with Poetry | |
run: | | |
cd senselab | |
poetry env use ${{ matrix.python-version }} | |
poetry install --with dev | |
shell: bash | |
- name: Check poetry info | |
run: | | |
cd senselab | |
poetry env info | |
poetry --version | |
shell: bash | |
- name: Check NVIDIA SMI details | |
run: | | |
cd senselab | |
poetry run nvidia-smi | |
poetry run nvidia-smi -L | |
poetry run nvidia-smi -q -d Memory | |
shell: bash | |
- name: Prepare cache folder for pytest | |
run: mkdir -p $WORKING_DIR/pytest/temp | |
shell: bash | |
- name: Run unit tests | |
id: run-tests | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
HF_TOKEN: ${{ secrets.HF_TOKEN }} | |
run: > | |
cd senselab && poetry run pytest \ | |
--rootdir=$WORKING_DIR/pytest \ | |
--basetemp=$WORKING_DIR/pytest/temp \ | |
--junitxml=pytest.xml \ | |
--cov-report=term-missing:skip-covered \ | |
--cov-report=xml:coverage.xml \ | |
--cov=src src/tests \ | |
--log-level=DEBUG \ | |
--verbose | |
shell: bash | |
stop-runner-312: | |
name: stop-runner-312 | |
needs: | |
- start-runner-312 # waits for the EC2 instance to be created | |
- ubuntu-tests-312 # waits for the actual job to finish | |
runs-on: ubuntu-latest | |
if: ${{ needs.start-runner-312.outputs.job-ran == 'true' && needs.ubuntu-tests-312.outputs.job-ran == 'true' || failure() }} # required to stop the runner even if an error occurred in previous jobs | |
steps: | |
- name: Check available space | |
run: | | |
df -h | |
shell: bash | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_KEY_SECRET }} | |
aws-region: ${{ vars.AWS_REGION }} | |
- name: Stop EC2 runner | |
uses: machulav/ec2-github-runner@v2 | |
with: | |
mode: stop | |
github-token: ${{ secrets.GH_TOKEN }} | |
label: ${{ needs.start-runner-312.outputs.label }} | |
ec2-instance-id: ${{ needs.start-runner-312.outputs.ec2-instance-id }} |