NGF is an open source and public repository; our goal is to keep the number of branches in the repository to a minimum: the main branch, release branches and long-term feature branches.
Internal developers and external contributors will follow a fork and merge process. Each contributor should fork the repo to their own space; branch, experiment, develop and prepare a pull request (PR) to merge their work into NGF’s main branch. This way ephemeral developer branches will remain outside the main repository.
Below is an example of following the merge and fork process. Developer Alice:
-
Forks
github.com/nginxinc/nginx-gateway-fabric
→github.com/<alice-user-id>/nginx-gateway-fabric
-
Adds upstream:
git remote add upstream [email protected]:nginxinc/nginx-gateway-fabric.git
-
Alice lists all of her configured remotes:
git remote -v
Which shows the following:
origin [email protected]:<alice-user-id>/nginx-gateway-fabric.git (fetch) origin [email protected]:<alice-user-id>/nginx-gateway-fabric.git (push) upstream [email protected]:nginxinc/nginx-gateway-fabric.git (fetch) upstream [email protected]:nginxinc/nginx-gateway-fabric.git (push)
-
Alice develops a feature or bugfix - using as many ephemeral branches as she needs.
-
Alice creates a PR
github.com/<alice-user-id>/nginx-gateway-fabric:feature/some-feature
→github.com/nginxinc/nginx-gateway-fabric:main
-
Alice keeps her fork up to date by running:
git pull upstream main
This will sync her local main branch with the main branch of the project's repo.
To maintain consistency and facilitate proper labeling of pull requests (PRs), we follow specific branch naming conventions. Each branch should contain a prefix that accurately describes the purpose of the PR. The prefixes align with the labels defined in the labeler file, which are used to create release notes.
For example, if you are working on a bug fix, name your branch starting with bug/
or fix/
, followed by a descriptive
name of the bug you are fixing.
To ensure correct labeling of your PRs, please use the appropriate prefix from the predefined list when naming your branches. This practice helps maintain consistent labeling and allows for the automated generation of accurate release notes.
For a comprehensive list of labels and prefixes, please refer to the labeler file.
The CI/CD pipeline builds a Docker image for NGINX Plus from the NGINX Plus Dockerfile for every commit to the main
branch, the release branches and for every PR.
When a PR is opened, the CI/CD will use the cached image from the last build if there aren't any changes to the Dockerfile. If you're planning to make changes to the Dockerfile,
you would need to create a branch in the upstream repository. If you don't have write access to the upstream repository, you would need to contact the maintainers
and ask them to create a branch for you so that the changes to the Dockerfile can be cached. After that your PR from a forked repository will be able to use the cached image.