CI, Docker Images, Docs, Tests & Release

This section contains an overview of the steps run on CI, as well as the tools used to simplify the testing (such as running on CPU).

We use Github Actions to run the tests, which simplifies the workflows significantly for contributors.

The tests run on CPU, and can be triggered using the ACT command line interface (https://github.com/nektos/act) - once you install the command line (And start the Docker daemon) you just have to type:

$ act

[Python Tests/python-tests] 🚀  Start image=axsauze/kompute-builder:0.2
[C++ Tests/cpp-tests      ] 🚀  Start image=axsauze/kompute-builder:0.2
[C++ Tests/cpp-tests      ]   🐳  docker run image=axsauze/kompute-builder:0.2 entrypoint=["/usr/bin/tail" "-f" "/dev/null"] cmd=[]
[Python Tests/python-tests]   🐳  docker run image=axsauze/kompute-builder:0.2 entrypoint=["/usr/bin/tail" "-f" "/dev/null"] cmd=[]
...

CI Commands Triggered

The simplest way to see how this works is by looking at the github actions commands that are run.

These can be found through the following files:

When submitting a PR or merging a PR into master, both of these will run - you can see the logs through the github interface.

Running on the CPU

We use Swiftshader to enable us to run the Kompute framework directly on the CPU for the CI tests.

Even though Swiftshader is optimized to function as a high-performance CPU backend for the Vulkan SDK, there are several limitations, the most notable are limitations in extensions.

This is one of the main reason why only a subset of the tests are run in the CI.

Dockerfiles

The dockerfiles created provide functionality to simplify the interaction with the system.

Image

Description

axsauze/kompute-builder:0.2

Main CI builder image with all required dependencies to build and run C++ & Python tests.

axsauze/swiftshader:0.1

Image building Swiftshader libraries only to reduce time via multi-staged builds

axsauze/vulkan-sdk:0.1

Image contained a linux build of the full Vulkan SDK to reduce time via multi-staged builds

Running / Building Documentation

In order to build the documentation you will need the following dependencies:

  • Install CI dependencies under scripts/requirements.txt

Once this installed:

  • You can build the documentation using the gendocsall cmake target
    • This can be done with make clean_cmake mk_cmake mk_build_docs

    • This can be done with mk_build_docs

  • You can serve the documentation locally using the mk_run_docs command in the Makefile

Performing Release

In order to perform the release the following steps need to be carried out:

  • Set up repo with next version as required if not yet updated
    • Update version in ./VERSION file

    • Update the version across the repo
      • If using Far.vim you can use :Far X\.Y\.Z XX.YY.ZZ **/**

      • Make sure you don’t accidentally replace the CHANGELOG.md

    • Create branch called v<VERSION>-release

    • Commit changes with new version

  • Building documentation
    • Follow section above to build documentation
      • Note: Currently some docs packages are only available in linux

  • Build changelog
    • Generate latest changelog make build_changelog

    • Update latest tag in new CHANGELOG.md to be the vesion to release

  • Python Release
    • Build dependency:
      • Intsall dependency: pip install .

      • Ensure all tests pass in GPU and CPU: python -m pytest

      • Build distribution python setup.py sdist bdist_wheel

    • Test repo:
      • Push to test repo python -m twine upload –repository testpypi dist/*

      • Install python dependency: python -m pip install –index-url https://test.pypi.org/simple/ –no-deps kp

      • Ensure all tests pass in GPU and CPU: python -m pytest

    • Prod repo:
      • Push to test repo python -m twine upload dist/*

      • Install package from prod pypi pip install kp

      • Ensure all tests pass in GPU and CPU: python -m pytest

  • Merge changes back to master
    • Open a PR to run the tests and check everything is working as expected

    • Once everything correct, merge back to master

    • Celebrate 🥳