0
Files
src/docs/gerrit_guide.md
Allen Li 7082140d1f [docs] Cleanup Gerrit guide
Some general cleanups, re-arranging, and adding some new common issues.

Bug: 404613530
Change-Id: Icd61a66fcc7fb5e4f0510824698721e3b75570ef
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6395517
Reviewed-by: Josip Sokcevic <sokcevic@chromium.org>
Commit-Queue: Allen Li <ayatane@chromium.org>
Reviewed-by: Dirk Pranke <dpranke@google.com>
Cr-Commit-Position: refs/heads/main@{#1438475}
2025-03-26 16:32:56 -07:00

178 lines
6.4 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# Gerrit Guide
[TOC]
## Introduction
### (EVERYONE) To get access to the Chromium Gerrit instance
1. Install
[depot_tools](https://commondatastorage.googleapis.com/chrome-infra-docs/flat/depot_tools/docs/html/depot_tools_tutorial.html#_setting_up).
2. Set up your account on Gerrit by visiting
https://chromium-review.googlesource.com/ and signing in once. This makes
sure that you have an account, which is needed for uploading CLs.
3. Set your real name on Gerrit by visiting
https://chromium-review.googlesource.com/#/settings/ and check the "Full
Name" field.
4. Ensure Git is set up correctly:
# Make sure to set your name and email
git config --global user.name "CHANGE ME"
git config --global user.email CHANGE_ME@chromium.org
git config --global depot-tools.useNewAuthStack 1
update_depot_tools
git cl creds-check
5. If you are using a @google.com account:
1. Run gcert once a day to authenticate your account.
### (EVERYONE) Verification
Run `git ls-remote https://chromium.googlesource.com/chromiumos/manifest.git`
This should **not** prompt for any credentials, and should just print out a list
of git references.
### (Googler) Link @chromium.org & @google.com accounts
If you have both @chromium.org and @google.com accounts, you may want to link
them.
Doing so may make it easier to view all of your CLs at once, and may make it
less likely that you'll upload a CL with the wrong account.
However, if you do choose to link them, you will be prompted to log in using
only your @google.com account, and that means you have to follow all of the
security restrictions for @google.com accounts.
**Please note** that linking your accounts does NOT change ownership of CLs
you've already uploaded and **you will lose edit access** to any CLs owned by
your secondary (@google.com) account. i.e CLs you uploaded with your @google.com
account, before the link, will not show up in your @chromium.org dashboard. Any
in-flight changes will have to be re-uploaded, so if you have significant
in-flight changes we don't recommend linking accounts.
**To link them:**
If you have two email accounts (@chromium.org and @google.com) but **only have
one Gerrit account** you can link them yourself:
1. Login into https://chromium-review.googlesource.com using your @chromium.org account.
2. Go to [Settings -> Email Addresses](https://chromium-review.googlesource.com/#/settings/EmailAddresses).
3. In the "New email address" field, enter your @google.com account, click the
Send Verification button, and follow the instructions.
4. To verify that it worked, open [Settings ->
Identities](https://chromium-review.googlesource.com/#/settings/web-identities)
and verify your @chromium.org, @google.com and ldapuser/* identities are
listed.
5. Repeat 1-4 on https://chrome-internal-review.googlesource.com, but use your
@google.com email to login, and @chromium.org in "Register new email" dialog.
If you encounter any errors, [file a ticket](https://issues.chromium.org/issues/new?component=1456263&template=1923295).
**If you have two Gerrit accounts** you need an admin to link them. File a
ticket using go/fix-chrome-git
Once your accounts are linked, you'll be able to use both @chromium.org and
@google.com emails in git commits. This is particularly useful if you have your
@chromium.org email in global git config, and you try to trigger chrome-internal
trybots (that otherwise require @google.com email).
If you have linked accounts, and want to unlink them:
* On chromium-review, go to
https://chromium-review.googlesource.com/settings/#EmailAddresses, click
"Delete" on all addresses associated with the account you don't want to use
anymore (e.g. all the @google ones), and then sign in again using the account
you do want to use (e.g. their @chromium one).
* On chrome-internal-review, go to
https://chrome-internal-review.googlesource.com/settings/#EmailAddresses and
do the same (probably deleting @chromium, and then signing in with your
@google account).
If you encounter any errors, [file a ticket](https://issues.chromium.org/issues/new?component=1456263&template=1923295).
## Common issues
### email address blah@chromium.org is not registered in your account, and you lack 'forge committer' permission
This means that the email you're using to upload CLs is not the same as the
email you're making Git commits with.
To fix this problem, make sure your Git configured email is correct:
git config --global user.email CHANGE_ME@chromium.org
Run to fix your Gerrit auth:
git cl creds-check
If you don't use `git cl upload` or if you use it with `--no-squash`, you may
need to rewrite your commits with the correct email:
git rebase -f
### SSOAuthenticator: Timeout
If you're getting this error and you're using SSH to Windows, try using Chrome
Remote Desktop instead. (SSH introduces more latency depending on where you're
connecting to/from.)
### Not getting email?
In case you think you should be receiving email from Gerrit but don't see it in
your inbox, be sure to check your spam folder. It's possible that your mail
reader is mis-classifying email from Gerrit as spam.
### Still having a problem?
Check out the [Gerrit
Documentation](https://gerrit-review.googlesource.com/Documentation/index.html)
to see if there are hints in there.
If you have any problems please [open a Build Infrastructure
issue](https://bugs.chromium.org/p/chromium/issues/entry?template=Build+Infrastructure)
on the **Chromium** issue tracker (the "Build Infrastructure" template should be
automatically selected).
## Tips
### Watching Projects / Notifications
You can select Projects (and branches) you want to "watch" for any changes on by
adding the Project under [Settings ->
Notifications](https://chromium-review.googlesource.com/settings/#Notifications).
### How do I build on other ongoing Gerrit reviews?
Scenario: You have an ongoing Gerrit review, with issue number 123456 (this is
the number after the last / in the URL for your Gerrit review). You have a local
branch, with your change, say 2a40ae.
Someone else has an ongoing Gerrit review, with issue number 456789. You want to
build on this. Heres one way to do it:
```
git checkout -b their_branch
git cl patch -f 456789
git checkout -b my_branch # yes, create a new
git cherry-pick 2a40ae # your change from local branch
git branch --set-upstream-to=their_branch
git rebase
git cl issue 123456
<any more changes to your commit(s)>
git cl upload
```