add rendering notes #1983
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
# This workflow will install Python dependencies, run tests and lint with a variety of Python versions | |
# For more information see: https://help.github.com/actions/language-and-framework-guides/using-python-with-github-actions | |
name: OpenTimelineIO | |
# for configuring which build will be a C++ coverage build / coverage report | |
env: | |
GH_COV_PY: 3.7 | |
GH_COV_OS: ubuntu-latest | |
GH_DEPENDABOT: dependabot | |
on: | |
push: | |
branches: [ main ] | |
pull_request: | |
branches: [ main ] | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: true | |
jobs: | |
cpp_build: | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ubuntu-latest, windows-latest, macos-latest] | |
# Unfortunately the CMake test target is OS dependent so we set it as | |
# a variable here. | |
include: | |
- os: ubuntu-latest | |
OTIO_TEST_TARGET: test | |
- os: windows-latest | |
OTIO_TEST_TARGET: RUN_TESTS | |
- os: macos-latest | |
OTIO_TEST_TARGET: test | |
env: | |
OTIO_BUILD_CONFIG: Release | |
OTIO_BUILD_DIR: ${{ github.workspace }}/build | |
OTIO_INSTALL_DIR: ${{ github.workspace }}/install | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: 'recursive' | |
- name: Install coverage dependency | |
if: matrix.os == env.GH_COV_OS && github.actor != env.GH_DEPENDABOT | |
run: | | |
sudo apt-get install lcov | |
- name: Build | |
run: | | |
cmake -E make_directory ${{ env.OTIO_BUILD_DIR }} | |
cd ${{ env.OTIO_BUILD_DIR }} | |
cmake ${{ github.workspace }} -DCMAKE_INSTALL_PREFIX=${{ env.OTIO_INSTALL_DIR }} -DOTIO_SHARED_LIBS=OFF -DOTIO_CXX_COVERAGE=ON | |
cmake --build . --config ${{ env.OTIO_BUILD_CONFIG }} | |
- name: Run tests | |
run: | | |
cd ${{ env.OTIO_BUILD_DIR }} | |
cmake --build . --target ${{ matrix.OTIO_TEST_TARGET }} --config ${{ env.OTIO_BUILD_CONFIG }} | |
- name: Collect code coverage | |
if: matrix.os == env.GH_COV_OS && github.actor != env.GH_DEPENDABOT | |
run: | | |
cd ${{ env.OTIO_BUILD_DIR }} | |
lcov --capture -b . --directory . --output-file=coverage.info -q | |
cat coverage.info | sed "s/SF:.*src/SF:src/g" > coverage.filtered.info | |
lcov --remove coverage.filtered.info '*/usr/*' --output-file=coverage.filtered.info -q | |
lcov --remove coverage.filtered.info '*/deps/*' --output-file=coverage.filtered.info -q | |
lcov --remove coverage.filtered.info '*/tests/*' --output-file=coverage.filtered.info -q | |
lcov --list coverage.filtered.info | |
# \todo Should the Codecov web pages show the results of the C++ or Python tests? | |
# - name: Upload coverage to Codecov | |
# if: matrix.os == env.GH_COV_OS && github.actor != env.GH_DEPENDABOT | |
# uses: codecov/codecov-action@v2.1.0 | |
# with: | |
# files: ${{ env.OTIO_BUILD_DIR }}/coverage.filtered.info | |
# flags: unittests | |
# name: opentimelineio-codecov | |
# fail_ci_if_error: true | |
- name: Install | |
run: | | |
cd ${{ env.OTIO_BUILD_DIR }} | |
cmake --build . --target install --config ${{ env.OTIO_BUILD_CONFIG }} | |
py_build_test: | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ubuntu-latest, windows-latest, macos-latest] | |
python-version: ['2.7', '3.7', '3.8', '3.9', '3.10'] | |
include: | |
- { os: ubuntu-latest, shell: bash } | |
- { os: macos-latest, shell: bash } | |
- { os: windows-latest, shell: pwsh } | |
- { os: windows-latest, shell: msys2, python-version: 'mingw64' } | |
defaults: | |
run: | |
shell: '${{ matrix.shell }} {0}' | |
env: | |
OTIO_CXX_COVERAGE_BUILD: ON | |
OTIO_CXX_BUILD_TMP_DIR: ${{ github.workspace }}/build | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: 'recursive' | |
- name: Set up MSYS2 | |
if: matrix.python-version == 'mingw64' | |
uses: msys2/setup-msys2@v2 | |
with: | |
msystem: mingw64 | |
install: >- | |
mingw-w64-x86_64-python | |
mingw-w64-x86_64-python-pip | |
mingw-w64-x86_64-gcc | |
mingw-w64-x86_64-cmake | |
make | |
git | |
- name: Set up Python ${{ matrix.python-version }} | |
if: matrix.python-version != 'mingw64' | |
uses: actions/setup-python@v3 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install coverage dependency | |
if: matrix.python-version == env.GH_COV_PY && matrix.os == env.GH_COV_OS && github.actor != env.GH_DEPENDABOT | |
run: | | |
sudo apt-get install lcov | |
- name: Install python build dependencies | |
run: | | |
python -m pip install --upgrade pip setuptools wheel flake8>=3.5 check-manifest | |
- name: install mock for python 2.7 tests only | |
if: matrix.python-version == 2.7 | |
run: python -m pip install --upgrade mock | |
- name: Run check-manifest and lint check | |
run: make ci-prebuild | |
- name: Build and Install | |
run: | | |
# compile and install into virtualenv/virtual machine (verbosely) | |
pip install .[dev] -v | |
- name: Run tests w/ python coverage | |
run: make ci-postbuild | |
# (only on ubuntu/pyhton3.7) | |
- name: Generate C++ coverage report | |
if: matrix.python-version == env.GH_COV_PY && matrix.os == env.GH_COV_OS && github.actor != env.GH_DEPENDABOT | |
run: make lcov | |
- name: Upload coverage to Codecov | |
if: matrix.python-version == env.GH_COV_PY && matrix.os == env.GH_COV_OS && github.actor != env.GH_DEPENDABOT | |
uses: codecov/codecov-action@v2.1.0 | |
with: | |
flags: py-unittests | |
name: py-opentimelineio-codecov | |
fail_ci_if_error: true | |
package_wheels: | |
needs: py_build_test | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ubuntu-latest, windows-latest, macos-latest] | |
python-build: ['cp27*', 'cp37*', 'cp38*', 'cp39*', 'cp310*'] | |
steps: | |
- uses: actions/checkout@v3 | |
# cibuildwheel 1.12.0 gates Python 2.7 wheels builds | |
# by using two environment variables, DISTUTILS_USE_SDK and MSSdk. | |
# https://cibuildwheel.readthedocs.io/en/1.x/cpp_standards/#windows-and-python-27 | |
# Note that normally these are used by setuptools/distutils, but in our case | |
# they are really just used for cibuildwheel as we don't use any of the | |
# setuptools/distutils build tools. Our builds are entirely handled | |
# by CMake. CMake is able to find the right toolchain, thanks to | |
# the -A argument that we specify in the setup.py to set the | |
# target platform (x86, x64, etc). | |
- name: Set Windows Python 2.7 environment variables | |
if: matrix.python-build == 'cp27*' && runner.os == 'Windows' | |
shell: bash | |
run: | | |
echo "DISTUTILS_USE_SDK=1" >> $GITHUB_ENV | |
echo "MSSdk=1" >> $GITHUB_ENV | |
- name: Build wheels (Python 2.7) | |
if: matrix.python-build == 'cp27*' | |
# cibuildwheel 1.12.0 is the last release that supported Python 2.7. | |
uses: pypa/cibuildwheel@v1.12.0 | |
with: | |
output-dir: wheelhouse | |
env: | |
CIBW_BUILD: ${{ matrix.python-build }} | |
- name: Build wheels (Python 3) | |
uses: pypa/cibuildwheel@v2.3.1 | |
if: matrix.python-build != 'cp27*' | |
with: | |
output-dir: wheelhouse | |
env: | |
CIBW_BUILD: ${{ matrix.python-build }} | |
CIBW_SKIP: '*musllinux*' | |
CIBW_MANYLINUX_X86_64_IMAGE: manylinux2010 | |
CIBW_MANYLINUX_I686_IMAGE: manylinux2010 | |
- uses: actions/upload-artifact@v2 | |
with: | |
name: wheels | |
path: ./wheelhouse/*.whl | |
package_sdist: | |
needs: py_build_test | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: 'recursive' | |
- uses: actions/setup-python@v3 | |
- name: Install pypa/build | |
run: python -m pip install build --user | |
- name: Generate sdist | |
run: python -m build -s . | |
- uses: actions/upload-artifact@v2 | |
with: | |
name: sdist | |
path: dist |