Skip to content

Latest commit

 

History

History
457 lines (334 loc) · 20.4 KB

CONTRIBUTING.md

File metadata and controls

457 lines (334 loc) · 20.4 KB

Contributing to aswf-docker

Thank you for your interest in contributing to aswf-docker. This document explains our contribution process and procedures:

Getting Information

There are three primary ways to connect with the aswf-docker project:

  • The TAC mailing list: This is a general mailing list which can be used to discuss CI issues, please use the #ci-working tag.

  • The ASWF Slack workspace: The CI working group has a channel #wg-ci for discussions.

  • GitHub Issues: GitHub Issues are used both to track bugs and to discuss feature requests.

How to Report a Bug

aswf-docker use GitHub's issue tracking system for bugs and enhancements: https://github.com/AcademySoftwareFoundation/aswf-docker/issues

If you are submitting a bug report, please be sure to note which Docker image you are using. Please give a specific account of

  • what you tried
  • what happened
  • what you expected to happen instead

with enough detail that others can reproduce the problem.

How to Request a Change

Open a GitHub issue: https://github.com/AcademySoftwareFoundation/aswf-docker/issues .

Describe the situation and the objective in as much detail as possible. Feature requests will almost certainly spawn a discussion among the project community.

How to Contribute a Bug Fix or Change

To contribute code to the project, you will need:

  • A good knowledge of git.

  • A fork of the GitHub repo.

  • An understanding of the project's development workflow.

  • Legal authorization, that is, you need to have signed a Contributor License Agreement. See below for details.

Legal Requirements

aswf-docker is a project of the Academy Software Foundation and follows the open source software best practice policies of the Linux Foundation.

License

aswf-docker is licensed under the Apache-2.0 license. Contributions to the project should abide by that standard license.

Commit Sign-Off

Every commit must be signed off. That is, every commit log message must include a “Signed-off-by” line (generated, for example, with “git commit --signoff”), indicating that the committer wrote the code and has the right to release it under the Apache-2.0 license. See Contribution Sign-Off for more information on this requirement.

Development Workflow

Git Basics

Working with aswf-docker requires understanding a significant amount of Git and GitHub based terminology. If you’re unfamiliar with these tools or their lingo, please look at the GitHub Glossary or browse GitHub Help.

To contribute, you need a GitHub account. This is needed in order to push changes to the upstream repository, via a pull request.

You will also need Git installed on your local development machine. If you need setup assistance, please see the official Git Documentation.

Docker Basics

You will also need to understand how Docker images are built and how to test them. The aswfdocker Python utility wraps many of the complexities of the Docker build process and must be installed locally before starting. Please read the Python README.md file for further instructions.

Repository Structure and Commit Policy

The aswf-docker repository uses a simple branching and merging strategy.

All development work is done directly on the master branch. The master branch represents the bleeding-edge of the project and most contributions should be done on top of it.

After sufficient work is done on the master branch and the aswf-docker leadership determines that a release is due, we will bump the relevant internal versioning and tag a commit with the corresponding version number, e.g. v2.0.1. Each Minor version also has its own “Release Branch”, e.g. RB-1.1. This marks a branch of code dedicated to that Major.Minor version, which allows upstream bug fixes to be cherry-picked to a given version while still allowing the master branch to continue forward onto higher versions. This basic repository structure keeps maintenance low, while remaining simple to understand.

To reiterate, the master branch represents the latest development version, so beware that it may include untested features and is not generally stable enough for release. To retrieve a stable version of the source code, use one of the release branches.

The Git Workflow

This development workflow is sometimes referred to as OneFlow. It leads to a simple, clean, linear edit history in the repo.

The aswf-docker GitHub repo allows rebase merging and disallows merge commits and squash merging. This ensures that the repo edit history remains linear, avoiding the "bubbles" characteristic of the GitFlow workflow.

Use the Fork, Luke.

In a typical workflow, you should fork the aswf-docker repository to your account. This creates a copy of the repository under your user namespace and serves as the “home base” for your development branches, from which you will submit pull requests to the upstream repository to be merged.

Once your Git environment is operational, the next step is to locally clone your forked aswf-docker repository, and add a remote pointing to the upstream aswf-docker repository. These topics are covered in the GitHub documentation Cloning a repository and Configuring a remote for a fork, but again, if you need assistance feel free to reach out on the [email protected] mail list.

Pull Requests

Contributions should be submitted as GitHub pull requests. See Creating a pull request if you're unfamiliar with this concept.

The development cycle for a code change should follow this protocol:

  1. Create a topic branch in your local repository, following the naming format "feature/" or "bugfix/".

  2. Make changes, compile, and test thoroughly. Code style should match existing style and conventions, and changes should be focused on the topic the pull request will be addressing. Make unrelated changes in a separate topic branch with a separate pull request.

  3. Push commits to your fork.

  4. Create a GitHub pull request from your topic branch.

  5. Pull requests will be reviewed by project Committers and Contributors, who may discuss, offer constructive feedback, request changes, or approve the work.

  6. Upon receiving the required number of Committer approvals (as outlined in Required Approvals), a Committer other than the PR contributor may merge changes into the master branch.

Code Review and Required Approvals

Modifications of the contents of the aswf-docker repository are made on a collaborative basis. Anyone with a GitHub account may propose a modification via pull request and it will be considered by the project Committers.

Pull requests must meet a minimum number of Committer approvals prior to being merged. Rather than having a hard rule for all PRs, the requirement is based on the complexity and risk of the proposed changes, factoring in the length of time the PR has been open to discussion. The following guidelines outline the project's established approval rules for merging:

  • Core design decisions, large new features, or anything that might be perceived as changing the overall direction of the project should be discussed at length in the mail list before any PR is submitted, in order to: solicit feedback, try to get as much consensus as possible, and alert all the stakeholders to be on the lookout for the eventual PR when it appears.

  • Small changes (bug fixes, docs, tests, cleanups) can be approved and merged by a single Committer.

  • Big changes that can alter behavior, add major features, or present a high degree of risk should be signed off by TWO Committers, ideally one of whom should be the "owner" for that section of the codebase (if a specific owner has been designated). If the person submitting the PR is him/herself the "owner" of that section of the codebase, then only one additional Committer approval is sufficient. But in either case, a 48 hour minimum is helpful to give everybody a chance to see it, unless it's a critical emergency fix (which would probably put it in the previous "small fix" category, rather than a "big feature").

  • Escape valve: big changes can nonetheless be merged by a single Committer if the PR has been open for over two weeks without any unaddressed objections from other Committers. At some point, we have to assume that the people who know and care are monitoring the PRs and that an extended period without objections is really assent.

Approval must be from Committers who are not authors of the change. If one or more Committers oppose a proposed change, then the change cannot be accepted unless:

  • Discussions and/or additional changes result in no Committers objecting to the change. Previously-objecting Committers do not necessarily have to sign-off on the change, but they should not be opposed to it.

Test Policy

All functionality in the aswfdocker Python library must be covered by an automated test.

  • Any new functionality should be accompanied by a test that validates its behavior.

  • Any change to existing functionality should have tests added if they don't already exist.

Pre-commit hooks need to be installed by running pre-commit install, and tests can be run manually by running pre-commit run --all-files.

Coding Style

Formatting

Black is the automatic formatter of choice for aswf-docker and is required to be run before any commit.

Naming Conventions

We follow PEP-8 naming convention which is also checked before any commit by the PyLint linter.

Copyright Notices

All new source files should begin with a copyright and license stating:

# Copyright (c) Contributors to the aswf-docker Project. All rights reserved.
# SPDX-License-Identifier: Apache-2.0

Versioning Policy

Any non-trivial change to the Docker images should be followed by incrementing the corresponding image version. We use MAJOR.MINOR versioning for all images. Versioning is further explained in the README file.

Building Conan Packages

This repository contains 2 ways of building packages, Docker packages (aswf/ci-package-* images) and Conan packages.

The Docker packages are being phased out as Conan offers a lot more flexibility when building options and variants of packages, with great cross-platform support.

The Conan Reference Documentation is a great way to discover and learn all about the Conan package manager.

The AcademySoftwareFoundation has an Artifactory server which hosts all aswf Conan packages. Credentials of the artifactory server are maintained by the Linux Foundation and are not known by the ASWF crew, new packages get uploaded via GitHub organisation secrets.

Getting started

Use the existing recipes as an example, and borrow from the MIT-licensed Conan Center Index.

Follow the great instructions there: Conan Center Index - How to add Packages, but ignore the config.yml instructions as the aswfdocker versions.yaml already takes care of listing all the maintained package versions.

Then ensure the ASWF-specific settings are added in the conanfile.py such as python.

To test locally, use the aswfdocker build command with the --use-conan argument. The --keep-source and --keep-build can help when iterating on the build recipe to avoid re-downloading the source, and even keep the previous build artifact. All regular aswfdocker commands and options work the same with conan or docker packages.

Docker-only Packages

If a package has no Conan recipe folder its conan package will be skipped at release time.

Conan-only Packages

If a package can only be built using Conan its name must be added to the conan_only list at the end of the versions.yaml file, see gtest as an example.

Releasing new Docker Images

The CHANGELOG.md file needs to be updated with the date of the change and the list of new Docker image versions that will be built by the CI infrastructure.

GitHub releases will trigger a Release GitHub action that will build the corresponding image and push it to Docker Hub.

Build

aswfdocker build builds CI packages and CI images. Example use: just build a single package for testing:

# Build and push USD package to aswftesting
aswfdocker --verbose build -t PACKAGE --group vfx --version 2019 --target usd --push
# Build and push ci-vfxall image to aswftesting
aswfdocker --verbose build -t IMAGE --group vfx --version 2019 --target vfxall --push

Migrate

aswfdocker migrate can migrate images between Docker organizations, should only be used on package images that are very heavy to build such as clang or qt. Example use: migrate a single package from aswftesting to aswf Docker Hub organization.

aswfdocker --verbose migrate --from aswftesting --to aswf --package usd

Updating versions

If a version number of a package or an image needs to be updated, the versions.yaml file is the main data source. In order to update the templated images with updated version numbers, run aswfdocker dockergen.

Manually push new packages

When rebuilding all packages from the CI is overkill, and if you have access to the right Docker Hub organizations, it is possible to manually build and push packages and images by overriding the automatic discovery of current repo and branch. E.g. to build and push a new ninja package these commands can be run to push to aswf and aswftesting organizations:

# push to aswftesting
aswfdocker --verbose --repo-uri https://github.com/AcademySoftwareFoundation/aswf-docker --source-branch refs/heads/testing build -t PACKAGE --group common --version 1 --target ninja --push
# push to aswf
aswfdocker --verbose --repo-uri https://github.com/AcademySoftwareFoundation/aswf-docker --source-branch refs/heads/master build -t PACKAGE --group common --version 1 --target ninja --push

Manual GitHub release creation

  • Create a new release in GitHub New Release
    • Use the following tag format: ci-NAME:X.Y (e.g. ci-common:1.4)
    • Use the following release name format: aswf/ci-NAME:X.Y (e.g. aswf/ci-common:1.4)
    • Enter the release notes for that particular image
    • Click Create
  • Run a manual build in Azure on the specific tagged commit created before

Automatic GitHub release creation

  • Generate a GitHub token to allow aswfdocker release to create GitHub releases: GitHub Settings with "repo" permissions.
  • Configure the token in the aswfdocker settings by running:
    aswfdocker settings --github-access-token MYTOKEN
  • Run the release command for a given image:
    aswfdocker release -n aswftesting/ci-base:2021
    or for a whole group of images:
    aswfdocker release -t PACKAGE -g base1 -v 2018 --docker-org aswftesting -m "Testing release"

Adding a new ci image

Let's consider the addition of a new ci-xyz Docker image to help the maintainers of the xyz library. The ci-xyz Docker image should be prepared with most upstream dependencies of the xyz library.

It is usually a good idea to add this xyz package to the vfxall library so that it can be tested there.

  • Add a new xyz version section in the versions.yaml, for both the ci-package-xyz Docker package and the ci-xyz for the CI image.
  • Create a new ci-xyx/Dockerfile using an existing one as an example (e.g. ci-otio/Dockerfile).
  • Create a new scripts/vfx/build_xyz.sh file that builds and installs xyz from source.
  • Add a new xyz section at the end of the packages/Dockerfile file to build the ci-package-xyz Docker package using the previous script.
  • Add the xyz package to the ci-vfxall/Dockerfile image.
  • Test the scripts by running these commands in order and manually checking if everything works
    # Build the CI image
    aswfdocker build -n aswftesting/ci-xyz:2019
    # Build the CI package (a small Docker image that contains only the xyz build artifacts)
    aswfdocker build -n aswftesting/ci-package-xyz:2019 --progress plain
    # Buils the `vfxall` package that should now contain the `xyz` package
    aswfdocker build -n aswftesting/ci-vfxall:2019
    # Now run the vfxall image locally to test if xyz is working properly
    docker run --gpus=all -e DISPLAY=$DISPLAY -v /tmp/.X11-unix:/tmp/.X11-unix:rw -v `pwd`:/project --rm -it aswftesting/ci-vfxall:2019 bash
  • Do a pre-release of the new ci-package-xyz image so it can be used by the GitHub Action builds and tests:
    # Create a GitHub release to build the `ci-package-xyz:2___` image via a GitHub action
    aswfdocker release -n aswftesting/ci-package-xyz:2019 --sha `git rev-parse HEAD` --github-org MY_GITHUB_ORG
    aswfdocker release -n aswftesting/ci-package-xyz:2020 --sha `git rev-parse HEAD` --github-org MY_GITHUB_ORG
    aswfdocker release -n aswftesting/ci-package-xyz:2021 --sha `git rev-parse HEAD` --github-org MY_GITHUB_ORG
  • Create the Pull Request with these changes

Check #66 for an example.

Example of a large re-release of all images

# Common packages
aswfdocker release -t PACKAGE -g common -v 1 -v 2 --target ninja --docker-org aswf -m "RELEASE_NOTES!"
aswfdocker release -t PACKAGE -g common -v 1-clang6 -v 1-clang7 -v 1-clang8 -v 1-clang9 -v 1-clang10 -v 2-clang10 -v 2-clang11 --target clang --docker-org aswf -m "RELEASE_NOTES!"
# Wait for clang builds to finish (from 2 to 3 hours!)

# ci-common needs to be built before base packages can be built
aswfdocker release -t IMAGE -g common -v 1-clang6 -v 1-clang7 -v 1-clang8 -v 1-clang9 -v 1-clang10 -v 2-clang10 -v 2-clang11 --docker-org aswf -m "RELEASE_NOTES!"

# Base packages
aswfdocker release -t PACKAGE -g base1 -v 2018 -v 2019 -v 2020 -v 2021 --docker-org aswf -m "RELEASE_NOTES!"
aswfdocker release -t PACKAGE -g base2 -v 2018 -v 2019 -v 2020 -v 2021 --docker-org aswf -m "RELEASE_NOTES!"
# Wait for Qt builds to finish (2-6 hours!)

# Usually some Qt build will fail as too big and too slow for free GitHub actions... So here's how to build qt locally:
aswfdocker --repo-uri https://github.com/AcademySoftwareFoundation/aswf-docker --source-branch refs/heads/master --verbose build -n aswf/ci-package-qt
:2021
docker push aswf/ci-package-qt:2021
docker push aswf/ci-package-qt:2021-5.15.2
docker push aswf/ci-package-qt:preview
docker push aswf/ci-package-qt:2021.1

# Once all Qt are out, release PySide packages
aswfdocker release -t PACKAGE -g base3 -v 2018 -v 2019 -v 2020 -v 2021 --docker-org aswf -m "RELEASE_NOTES!"

# Wait for all Qt and Pyside builds to finish, then build downstream packages:
# VFX packages
aswfdocker release -t PACKAGE -g vfx1 -v 2018 -v 2019 -v 2020 -v 2021 --docker-org aswf -m "RELEASE_NOTES!"
aswfdocker release -t PACKAGE -g vfx2 -v 2018 -v 2019 -v 2020 -v 2021 --docker-org aswf -m "RELEASE_NOTES!"

# Finally build the CI images
aswfdocker release -t IMAGE -g base -v 2018 -v 2019 -v 2020 -v 2021 --docker-org aswf -m "RELEASE_NOTES!"
aswfdocker release -t IMAGE -g vfx1 -v 2018 -v 2019 -v 2020 -v 2021 --docker-org aswf -m "RELEASE_NOTES!"
aswfdocker release -t IMAGE -g vfx2 -v 2018 -v 2019 -v 2020 -v 2021 --docker-org aswf -m "RELEASE_NOTES!"
aswfdocker release -t IMAGE -g vfx3 -v 2018-clang7 -v 2019-clang6 -v 2019-clang7 -v 2019-clang8 -v 2019-clang9 -v 2020-clang7 -v 2021-clang10 -v 2021-clang11 --docker-org aswf -m "RELEASE_NOTES!"