Before You Submit a Pull Request

This guide is for contributors who already have a pull request to submit. If you are looking for information on setting up your developer environment and creating code to contribute to Traefik Proxy or related projects, see the development guide.

Looking for a way to contribute to Traefik Proxy? Check out this list of Priority Issues, the Good First Issue list, or the list of confirmed bugs waiting to be remedied.

How We Prioritize

We wish we could review every pull request right away, but because it’s a time consuming operation, it’s not always possible.

The PRs we are able to handle the fastest are:

  • Documentation updates.
  • Bug fixes.
  • Enhancements and Features with a contributor/wanted tag.

PRs that take more time to address include:

  • Enhancements or Features without the contributor/wanted tag.

If you have an idea for an enhancement or feature that you would like to build, create an issue for it first and tell us you are interested in writing the PR. If an issue already exists, definitely comment on it to tell us you are interested in creating a PR.

This will allow us to communicate directly and let you know if it is something we would accept.

It also allows us to make sure you have all the information you need during the design phase so that it can be reviewed and merged quickly.

Read more about the Triage process in the docs.

The Pull Request Submit Process

Merging a PR requires the following steps to be completed before it is merged automatically.

  • Make sure your pull request adheres to our best practices. These include:
    • Following project conventions; including using the PR Template.
    • Make small pull requests.
    • Solve only one problem at a time.
    • Comment thoroughly.
    • Do not open the PR from an organization repository.
    • Keep “allows edit from maintainer” checked.
    • Use semantic line breaks for documentation.
    • Ensure your PR is not a draft. We do not review drafts, but do answer questions and confer with developers on them as needed.
    • Ensure that the dependencies in the go.mod file reference a tag. If referencing a tag is not possible, add a comment explaining why.
  • Pass the validation check.
  • Pass all tests.
  • Receive 2 approving reviews from maintainers.

Pull Request Review Cycle

Learn about our Triage Process, in short, it looks like this:

  • We triage every new PR or comment before entering it into the review process.
    • We ensure that all prerequisites for review have been met.
    • We check to make sure the use case meets our needs.
    • We assign reviewers.
  • Design Review.
    • This takes longer than other parts of the process.
    • We review that there are no obvious conflicts with our codebase.
  • Code Review.
    • We review the code in-depth and run tests.
    • We may ask for changes here.
    • During code review, we ask that you be reasonably responsive, if a PR languishes in code review it is at risk of rejection, or we may take ownership of the PR and the contributor will become a co-author.
  • Merge.
    • Success!

Note

Occasionally, we may freeze our codebase when working towards a specific feature or goal that could impact other development. During this time, your pull request could remain unmerged while the release work is completed.

Run Local Verifications

You must run these local verifications before you submit your pull request to predict the pass or failure of continuous integration. Your PR will not be reviewed until these are green on the CI.

  • make generate
  • make generate-crd
  • make test-gateway-api-conformance
  • make validate
  • make pull-images
  • make test

The Testing and Merge Workflow

Pull Requests are managed by the bot Myrmica Lobicornis. This bot is responsible for verifying GitHub Checks (CI, Tests, etc), mergability, and minimum reviews. In addition, it rebases or merges with the base PR branch if needed. It performs several other housekeeping items and you can read more about those on the README for Lobicornis.

The maintainer giving the final LGTM must add the status/3-needs-merge label to trigger the merge bot.

By default, a squash-rebase merge will be carried out.

The status status/4-merge-in-progress is only used by the bot.

If the bot is not able to perform the merge, the label bot/need-human-merge is added. In such a situation, solve the conflicts/CI/… and then remove the label bot/need-human-merge.

To prevent the bot from automatically merging a PR, add the label bot/no-merge.

The label bot/light-review decreases the number of required LGTM from 2 to 1.

This label can be used when:

  • Updating a dependency.
  • Merging branches back into the next version branch.
  • Submitting minor documentation changes.
  • Submitting changelog PRs.

Why Was My Pull Request Closed?

Traefik Proxy is made by the community for the community, as such the goal is to engage the community to make Traefik the best reverse proxy available. Part of this goal is maintaining a lean codebase and ensuring code velocity. unfortunately, this means that sometimes we will not be able to merge a pull request.

Because we respect the work you did, you will always be told why we are closing your pull request. If you do not agree with our decision, do not worry; closed pull requests are effortless to recreate, and little work is lost by closing a pull request that subsequently needs to be reopened.

Your pull request might be closed if:

  • Your PR’s design conflicts with our existing codebase in such a way that merging is not an option and the work needed to make your pull request usable is too high.
    • To prevent this, make sure you created an issue first and think about including Traefik Proxy maintainers in your design phase to minimize conflicts.
  • Your PR is for an enhancement or feature that we will not use.
    • Please remember to create an issue for any pull request before you create a PR to ensure that your goal is something we can merge and that you have any design insight you might need from the team.
  • Your PR has been waiting for feedback from the contributor for over 90 days.

Why is My Pull Request Not Getting Reviewed

A few factors affect how long your pull request might wait for review.

We must prioritize which PRs we focus on. Our first priority is PRs we have identified as having high community engagement and broad applicability. We put our top priorities on our roadmap, and you can identify them by the contributor/wanted tag. These PRs will enter our review process the fastest.

Our second priority is bug fixes. Especially for bugs that have already been tagged with bug/confirmed. These reviews enter the process quickly.

If your PR does not meet the criteria above, it will take longer for us to review, as any PRs that do meet the criteria above will be prioritized.

Additionally, during the last few weeks of a milestone, we stop reviewing PRs to reduce churn and stabilize. We will resume after the release.

The second major reason that we deprioritize your PR is that you are not following best practices.

The most common failures to follow best practices are:

  • You did not create an issue for the PR you wish to make. If you do not create an issue before submitting your PR, we will not be able to answer any design questions and let you know how likely your PR is to be merged.
  • You created pull requests that are too large to review.
    • Break your pull requests up. If you can extract whole ideas from your pull request and send those as pull requests of their own, you should do that instead. It is better to have many pull requests addressing one thing than one pull request addressing many things.
    • Traefik Proxy is a fast-moving codebase — lock in your changes ASAP with your small pull request, and make merges be someone else’s problem. We want every pull request to be useful on its own, so use your best judgment on what should be a pull request vs. a commit.
  • You did not comment well.
    • Comment everything.

Please remember that we are working internationally, cross-culturally, and with different use-cases. Your reviewer will not intuitively understand the problem the same way you do or solve it the same way you would. This is why every change you make must be explained, and your strategy for coding must also be explained.

  • Your tests were inadequate or absent.
    • If you do not know how to test your PR, please ask! We will be happy to help you or suggest appropriate test cases.

If you have already followed the best practices and your PR still has not received a response, here are some things you can do to move the process along:

  • If you have fixed all the issues from a review, remember to re-request a review (using the designated button) to let your reviewer know that you are ready. You can choose to comment with the changes you made.
  • Kindly comment on the pull request. Doing so will automatically give your PR visibility during the triage process.

For more information on best practices, try these links:

It’s OK to Push Back

Sometimes reviewers make mistakes. It is OK to push back on changes your reviewer requested. If you have a good reason for doing something a certain way, you are absolutely allowed to debate the merits of a requested change. Both the reviewer and reviewee should strive to discuss these issues in a polite and respectful manner.

You might be overruled, but you might also prevail. We are pretty reasonable people.

Another phenomenon of open-source projects (where anyone can comment on any issue) is the dog-pile - your pull request gets so many comments from so many people it becomes hard to follow. In this situation, you can ask the primary reviewer (assignee) whether they want you to fork a new pull request to clear out all the comments. You do not have to fix every issue raised by every person who feels like commenting, but you should answer reasonable comments with an explanation.

Common Sense and Courtesy

No document can take the place of common sense and good taste. Use your best judgment, while you put a bit of thought into how your work can be made easier to review. If you do these things, your pull requests will get merged with less friction.