-
Notifications
You must be signed in to change notification settings - Fork 3k
Pull Request Naming Guide
The name of a PR is important, because it will eventually become the commit that shows up in main
. Here are the guidelines for how to name a PR.
Anatomy of a PR name:
Keyword
FXIOS-{issue-number}
[Feature Name]
Short summary
For example Add FXIOS-9000 [Nimbus] New Nimbus manager added
The keyword should be the first thing in the name, to let everyone know what kind of change the PR is. Here is a table of the standard keywords, and what they mean:
Key Word | Meaning |
---|---|
Add | Create a capability e.g. feature, test, dependency. |
Remove | Remove a capability e.g. feature, test, dependency. |
Refactor | An update to existing code and/or refactoring. |
Bugfix | Fix an issue e.g. bug, typo, accident, misstatement. |
Bump | Increase the version of something e.g. dependency. |
Build | Change only to the build process, tooling, or infra. |
Document | A change to documentation only. |
Localize | String and localization only related changes. |
Revert | Reverting a previous commit. |
Discussion: Why the standard GitHib
Fixes
/Fix
keyword is not used? Simply put, these two keywords close tickets. However, we want to prevent tickets from being closed - rather, those tickets should follow our process and be moved to QA. As such, we useBugfix
instead.
Following the keyword is the issue number - this is the issue the ticket addresses. It is formatted as: FXIOS-XXXX
where XXXX is the ticket number from JIRA. Note: we should use the format prefix FXIOS-
. We use the JIRA number as a standard because JIRA is the source of truth. While contributors might use the GitHub number for issue, when we merge their tickets, we should still enter the appropriate JIRA ticket ID.
Contributor Note: Given that contributors don't have access to JIRA ticket numbers, it's fine to leave your Issue Number as
FXIOS-XXXX
or asFXIOS-YYYY
, whereYYYY
is the GitHub ticket number, and a reviewer will update the required information when going over the PR. Alternatively, for those who are proactive, you can hover over the "Issue is synchronized with JIRA task" in the GitHub issue and you'll see the link with the JIRA number. Either way is acceptable.
A short-form version of the feature you're working on, or, alternatively the location you're making changes. Serves as an easy, at a glance, indicator of what the PR is touching.
This is a short summary of what your commit is doing.
Firefox-iOS uses a Squash & Merge
policy which results in your entire PR being a single commit on the main
commit history. This, individual commit names are not important, but they're helpful for context.