Version Control with Git
Contents
Version Control with Git#
Installation#
The basic Git program is installed using
sudo apt install git
Additional utilities for git
are installed using:
sudo apt install git-extras
This include the git-ignore
utility, which comes in handy when you have files that you don’t
actually want to push to the remote branch (such as temporary files).
##Setting up global configurations for Git
Use these commands to tell Git who you are:
git config --global user.email "![email]"
git config --global user.name "![full name]"
Git tips#
Fork a repository#
To fork (creating a copy of a repository, that does not belong to you), you simply have to go to the repository’s webpage dashboard and click fork on the upper right corner.
Clone a repository#
To clone a repository, copy either the HTTPS or SSH link from the repository’s webpage. The following command will download the git repository in a new directory on the local computer (starting from the current working directory).
git clone [email protected]:USERNAME/REPOSITORY
If you have SSH setup properly, you can directly download it. If you are using the HTTPS then github will ask for your credentials.
Move between branches#
You can move to a different branch using the command,
git checkout ![destination-branch]
Create a new branch#
After you successfully cloned a repository, you may want to work on your own branch. Move to the branch you want to start from and run the following command,
git checkout -b ![branch-name]
To see which branch you are working on you can either use both of these commands
git branch
git status
The latter provides more information on which files you might have changed, which are staged for a new commit or that you are up-to-date (everything is ok).
Commit and Push changes#
After you edited some files, you want to push your changes from the local to the remote location. Check the changes that need to be committed/pushed with the command,
git status
Use the following command to mark a ![file]
as ready to be committed,
git add ![file]
Once you marked all the files you want to include in the next commit, complete the commit with a commit message to let collaborators know what you have changed,
git commit -m "![commit-message]"
If everything went well, you are now ready to push your changes to your remote with,
git push origin ![branch-name]
Fetch new branches#
If new branches have been pushed recently to the repository and you don’t have them you can invoke a
git fetch --all
to see all new branches and checkout to those.
Delete branches#
To delete a local branch execute (you cannot be on the branch that you are going to delete!):
git branch -d ![branch-name]
To delete a remote branch you need to push the delete command:
git push origin --delete ![branch-name]
Open a pull request#
If you are working on another branch than the master or if you forked a repository and want to propose changes you made into the master, you can open a so-called pull-request
. In order to do so, press the corresponding tab in the dashboard of a repository and then press the green button New pull request
. You will be asked which branch from which fork you want to merge.
Keep your password stored locally#
If you are setting up Github on your own personal computer, and you use two factor authentication, it might be time consuming to configure that every time you need to provide git credentials. Instead, you can have the computer to remember your password. To do that, you can:
git config --global credential.helper store
Please note you should only do that if this is your personal computer!
Connect with SSH#
From GitHub:
You can use SSH to perform Git operations in repositories on GitHub.com.
If you have an existing SSH key, you can use the key to authenticate Git operations over SSH.
Checking for existing SSH keys#
From GitHub:
Before you generate a new SSH key, you should check your local machine for existing keys.
Open Terminal.
Enter
ls -al ~/.ssh
to see if existing SSH keys are present.$ ls -al ~/.ssh # Lists the files in your .ssh directory, if they exist
Check the directory listing to see if you already have a public SSH key. By default, the filenames of supported public keys for GitHub are one of the following.
id_rsa.pub
id_ecdsa.pub
id_ed25519.pub
Tip
If you receive an error that
~/.ssh
doesn’t exist, you do not have an existing SSH key pair in the default location. You can create a new SSH key pair in the next step.Either generate a new SSH key or upload an existing key.
If you don’t have a supported public and private key pair, or don’t wish to use any that are available, generate a new SSH key.
If you see an existing public and private key pair listed (for example,
id_rsa.pub
andid_rsa
) that you would like to use to connect to GitHub, you can add the key to the ssh-agent.
Before you generate a new SSH key, you should check your local machine for existing keys.
Open Terminal.
Enter
ls -al ~/.ssh
to see if existing SSH keys are present.$ ls -al ~/.ssh # Lists the files in your .ssh directory, if they exist
Check the directory listing to see if you already have a public SSH key. By default, the filenames of supported public keys for GitHub are one of the following.
id_rsa.pub
id_ecdsa.pub
id_ed25519.pub
Tip
If you receive an error that
~/.ssh
doesn’t exist, you do not have an existing SSH key pair in the default location. You can create a new SSH key pair in the next step.Either generate a new SSH key or upload an existing key.
If you don’t have a supported public and private key pair, or don’t wish to use any that are available, generate a new SSH key.
If you see an existing public and private key pair listed (for example,
id_rsa.pub
andid_rsa
) that you would like to use to connect to GitHub, you can add the key to the ssh-agent.
Before you generate a new SSH key, you should check your local machine for existing keys.
Open Git Bash.
Enter
ls -al ~/.ssh
to see if existing SSH keys are present.$ ls -al ~/.ssh # Lists the files in your .ssh directory, if they exist
Check the directory listing to see if you already have a public SSH key. By default, the filenames of supported public keys for GitHub are one of the following.
id_rsa.pub
id_ecdsa.pub
id_ed25519.pub
Tip
If you receive an error that
~/.ssh
doesn’t exist, you do not have an existing SSH key pair in the default location. You can create a new SSH key pair in the next step.Either generate a new SSH key or upload an existing key.
If you don’t have a supported public and private key pair, or don’t wish to use any that are available, generate a new SSH key.
If you see an existing public and private key pair listed (for example,
id_rsa.pub
andid_rsa
) that you would like to use to connect to GitHub, you can add the key to the ssh-agent.
Generating a new SSH key#
From GitHub:
You can generate a new SSH key on your local machine. After you generate the key, you can add the public key to your account on GitHub.com to enable authentication for Git operations over SSH.
Open Terminal.
Paste the text below, replacing the email used in the example with your GitHub email address.
ssh-keygen -t ed25519 -C "[email protected]"
Note
If you are using a legacy system that doesn’t support the Ed25519 algorithm, use:
ssh-keygen -t rsa -b 4096 -C "[email protected]"
This creates a new SSH key, using the provided email as a label.
> Generating public/private ALGORITHM key pair.
When you’re prompted to “Enter a file in which to save the key”, you can press
Enter
to accept the default file location. Please note that if you created SSH keys previously, ssh-keygen may ask you to rewrite another key, in which case we recommend creating a custom-named SSH key. To do so, type the default file location and replaceid_ALGORITHM
with your custom key name.> Enter a file in which to save the key (/home/YOU/.ssh/id_ALGORITHM):[Press enter]
At the prompt, type a secure passphrase.
> Enter passphrase (empty for no passphrase): [Type a passphrase] > Enter same passphrase again: [Type passphrase again]
You can generate a new SSH key on your local machine. After you generate the key, you can add the public key to your account on GitHub.com to enable authentication for Git operations over SSH.
Open Terminal.
Paste the text below, replacing the email used in the example with your GitHub email address.
ssh-keygen -t ed25519 -C "[email protected]"
Note
If you are using a legacy system that doesn’t support the Ed25519 algorithm, use:
ssh-keygen -t rsa -b 4096 -C "[email protected]"
This creates a new SSH key, using the provided email as a label.
> Generating public/private ALGORITHM key pair.
When you’re prompted to “Enter a file in which to save the key”, you can press
Enter
to accept the default file location. Please note that if you created SSH keys previously, ssh-keygen may ask you to rewrite another key, in which case we recommend creating a custom-named SSH key. To do so, type the default file location and replaceid_ALGORITHM
with your custom key name.> Enter a file in which to save the key (/Users/YOU/.ssh/id_ALGORITHM):[Press enter]
At the prompt, type a secure passphrase.
> Enter passphrase (empty for no passphrase): [Type a passphrase] > Enter same passphrase again: [Type passphrase again]
You can generate a new SSH key on your local machine. After you generate the key, you can add the public key to your account on GitHub.com to enable authentication for Git operations over SSH.
Open Git Bash.
Paste the text below, replacing the email used in the example with your GitHub email address.
ssh-keygen -t ed25519 -C "[email protected]"
Note
If you are using a legacy system that doesn’t support the Ed25519 algorithm, use:
ssh-keygen -t rsa -b 4096 -C "[email protected]"
This creates a new SSH key, using the provided email as a label.
> Generating public/private ALGORITHM key pair.
When you’re prompted to “Enter a file in which to save the key”, you can press
Enter
to accept the default file location. Please note that if you created SSH keys previously, ssh-keygen may ask you to rewrite another key, in which case we recommend creating a custom-named SSH key. To do so, type the default file location and replaceid_ALGORITHM
with your custom key name.> Enter file in which to save the key (c:\Users\YOU\.ssh\id_ALGORITHM):[Press enter]
At the prompt, type a secure passphrase.
> Enter passphrase (empty for no passphrase): [Type a passphrase] > Enter same passphrase again: [Type passphrase again]
Adding your SSH key to the SSH agent#
From GitHub:
Before adding a new SSH key to the ssh-agent to manage your keys, you should have checked for existing SSH keys and generated a new SSH key.
Start the ssh-agent in the background.
$ eval "$(ssh-agent -s)" > Agent pid 59566
Depending on your environment, you may need to use a different command. For example, you may need to use root access by running
sudo -s -H
before starting the ssh-agent, or you may need to useexec ssh-agent bash
orexec ssh-agent zsh
to run the ssh-agent.Add your SSH private key to the ssh-agent.
If you created your key with a different name, or if you are adding an existing key that has a different name, replace
id_ed25519
in the command with the name of your private key file.ssh-add ~/.ssh/id_ed25519
Add the SSH public key to your account on GitHub.
Before adding a new SSH key to the ssh-agent to manage your keys, you should have checked for existing SSH keys and generated a new SSH key. When adding your SSH key to the agent, use the default macOS ssh-add
command, and not an application installed by macports, homebrew, or some other external source.
Start the ssh-agent in the background.
$ eval "$(ssh-agent -s)" > Agent pid 59566
Depending on your environment, you may need to use a different command. For example, you may need to use root access by running
sudo -s -H
before starting the ssh-agent, or you may need to useexec ssh-agent bash
orexec ssh-agent zsh
to run the ssh-agent.If you’re using macOS Sierra 10.12.2 or later, you will need to modify your
~/.ssh/config
file to automatically load keys into the ssh-agent and store passphrases in your keychain.First, check to see if your
~/.ssh/config
file exists in the default location.
$ open ~/.ssh/config > The file /Users/YOU/.ssh/config does not exist.
If the file doesn’t exist, create the file.
touch ~/.ssh/config
Open your
~/.ssh/config
file, then modify the file to contain the following lines. If your SSH key file has a different name or path than the example code, modify the filename or path to match your current setup.
Host github.com AddKeysToAgent yes UseKeychain yes IdentityFile ~/.ssh/id_ed25519
Note
If you chose not to add a passphrase to your key, you should omit the
UseKeychain
line.If you see a
Bad configuration option: usekeychain
error, add an additional line to the configuration’s’Host *.github.com
section.
Host github.com IgnoreUnknown UseKeychain
Add your SSH private key to the ssh-agent and store your passphrase in the keychain. If you created your key with a different name, or if you are adding an existing key that has a different name, replace
id_ed25519
in the command with the name of your private key file.ssh-add --apple-use-keychain ~/.ssh/id_ed25519
Note
The
--apple-use-keychain
option stores the passphrase in your keychain for you when you add an SSH key to the ssh-agent. If you chose not to add a passphrase to your key, run the command without the--apple-use-keychain
option.The
--apple-use-keychain
option is in Apple’s standard version ofssh-add
. In macOS versions prior to Monterey (12.0), the--apple-use-keychain
and--apple-load-keychain
flags used the syntax-K
and-A
, respectively.If you don’t have Apple’s standard version of
ssh-add
installed, you may receive an error.If you continue to be prompted for your passphrase, you may need to add the command to your
~/.zshrc
file (or your~/.bashrc
file for bash).Add the SSH public key to your account on GitHub.
Before adding a new SSH key to the ssh-agent to manage your keys, you should have checked for existing SSH keys and generated a new SSH key.
If you have GitHub Desktop installed, you can use it to clone repositories and not deal with SSH keys.
In a new
admin elevated
PowerShell window, ensure the ssh-agent is running.# start the ssh-agent in the background Get-Service -Name ssh-agent | Set-Service -StartupType Manual Start-Service ssh-agent
In a terminal window without elevated permissions, add your SSH private key to the ssh-agent. If you created your key with a different name, or if you are adding an existing key that has a different name, replace
id_ed25519
in the command with the name of your private key file.ssh-add c:\Users\YOU\.ssh\id_ed25519
Add the SSH public key to your account on GitHub.
Generating a new SSH key for a hardware security key#
From GitHub:
If you are using macOS or Linux, you may need to update your SSH client or install a new SSH client prior to generating a new SSH key.
Insert your hardware security key into your computer.
Open Terminal.
Paste the text below, replacing the email address in the example with the email address associated with your account on GitHub.
ssh-keygen -t ed25519-sk -C "[email protected]"
Note
If the command fails and you receive the error
invalid format
orfeature not supported
, you may be using a hardware security key that does not support the Ed25519 algorithm. Enter the following command instead.ssh-keygen -t ecdsa-sk -C "[email protected]"
When you are prompted, touch the button on your hardware security key.
When you are prompted to “Enter a file in which to save the key,” press
Enter
to accept the default file location.> Enter a file in which to save the key (/Users/YOU/.ssh/id_ed25519_sk):[Press enter]
When you are prompted to type a passphrase, press
Enter
.> Enter passphrase (empty for no passphrase): [Type a passphrase] > Enter same passphrase again: [Type passphrase again]
Add the SSH public key to your account on GitHub.
If you are using macOS or Linux, you may need to update your SSH client or install a new SSH client prior to generating a new SSH key.
Insert your hardware security key into your computer.
Open Terminal.
Paste the text below, replacing the email address in the example with the email address associated with your account on GitHub.
ssh-keygen -t ed25519-sk -C "[email protected]"
Note
If the command fails and you receive the error
invalid format
orfeature not supported
, you may be using a hardware security key that does not support the Ed25519 algorithm. Enter the following command instead.ssh-keygen -t ecdsa-sk -C "[email protected]"
When you are prompted, touch the button on your hardware security key.
When you are prompted to “Enter a file in which to save the key,” press
Enter
to accept the default file location.> Enter a file in which to save the key (/Users/YOU/.ssh/id_ed25519_sk):[Press enter]
When you are prompted to type a passphrase, press
Enter
.> Enter passphrase (empty for no passphrase): [Type a passphrase] > Enter same passphrase again: [Type passphrase again]
Add the SSH public key to your account on GitHub.
If you are using macOS or Linux, you may need to update your SSH client or install a new SSH client prior to generating a new SSH key.
Insert your hardware security key into your computer.
Open Git Bash.
Paste the text below, replacing the email address in the example with the email address associated with your account on GitHub.
ssh-keygen -t ed25519-sk -C "[email protected]"
Note
If the command fails and you receive the error
invalid format
orfeature not supported
, you may be using a hardware security key that does not support the Ed25519 algorithm. Enter the following command instead.ssh-keygen -t ecdsa-sk -C "[email protected]"
When you are prompted, touch the button on your hardware security key.
When you are prompted to “Enter a file in which to save the key,” press
Enter
to accept the default file location.> Enter a file in which to save the key (c:\Users\YOU\.ssh\id_ed25519_sk):[Press enter]
When you are prompted to type a passphrase, press
Enter
.> Enter passphrase (empty for no passphrase): [Type a passphrase] > Enter same passphrase again: [Type passphrase again]
Add the SSH public key to your account on GitHub.
Adding a new SSH key to your GitHub account#
From GitHub:
You can add an SSH key and use it for authentication, or commit signing, or both. If you want to use the same SSH key for both authentication and signing, you need to upload it twice.
After adding a new SSH authentication key to your account on GitHub.com, you can reconfigure any local repositories to use SSH.
Copy the SSH public key to your clipboard.
If your SSH public key file has a different name than the example code, modify the filename to match your current setup. When copying your key, don’t add any newlines or whitespace.
$ cat ~/.ssh/id_ed25519.pub # Then select and copy the contents of the id_ed25519.pub file # displayed in the terminal to your clipboard
Tip
Alternatively, you can locate the hidden
.ssh
folder, open the file in your favorite text editor, and copy it to your clipboard.In the upper-right corner of any page on GitHub, click your profile photo, then click
Settings
.In the “Access” section of the sidebar, click
SSH and GPG keys
.Click
New SSH key
orAdd SSH key
.In the “Title” field, add a descriptive label for the new key. For example, if you’re using a personal laptop, you might call this key “Personal laptop”.
Select the type of key, either authentication or signing.
In the “Key” field, paste your public key.
Click
Add SSH key
.If prompted, confirm access to your account on GitHub.
You can add an SSH key and use it for authentication, or commit signing, or both. If you want to use the same SSH key for both authentication and signing, you need to upload it twice.
After adding a new SSH authentication key to your account on GitHub.com, you can reconfigure any local repositories to use SSH.
Copy the SSH public key to your clipboard.
If your SSH public key file has a different name than the example code, modify the filename to match your current setup. When copying your key, don’t add any newlines or whitespace.
$ pbcopy < ~/.ssh/id_ed25519.pub # Copies the contents of the id_ed25519.pub file to your clipboard
Tip
If
pbcopy
isn’t working, you can locate the hidden.ssh
folder, open the file in your favorite text editor, and copy it to your clipboard.In the upper-right corner of any page on GitHub, click your profile photo, then click
Settings
.In the “Access” section of the sidebar, click
SSH and GPG keys
.Click
New SSH key
orAdd SSH key
.In the “Title” field, add a descriptive label for the new key. For example, if you’re using a personal laptop, you might call this key “Personal laptop”.
Select the type of key, either authentication or signing.
In the “Key” field, paste your public key.
Click
Add SSH key
.If prompted, confirm access to your account on GitHub.
You can add an SSH key and use it for authentication, or commit signing, or both. If you want to use the same SSH key for both authentication and signing, you need to upload it twice.
After adding a new SSH authentication key to your account on GitHub.com, you can reconfigure any local repositories to use SSH.
Copy the SSH public key to your clipboard.
If your SSH public key file has a different name than the example code, modify the filename to match your current setup. When copying your key, don’t add any newlines or whitespace.
$ clip < ~/.ssh/id_ed25519.pub # Copies the contents of the id_ed25519.pub file to your clipboard
Note
With Windows Subsystem for Linux (WSL), you can use
clip.exe
. Otherwise ifclip
isn’t working, you can locate the hidden.ssh
folder, open the file in your favorite text editor, and copy it to your clipboard.On newer versions of Windows that use the Windows Terminal, or anywhere else that uses the PowerShell command line, you may receive a
ParseError
stating thatThe '<' operator is reserved for future use.
In this case, the following alternativeclip
command should be used:
$ cat ~/.ssh/id_ed25519.pub | clip # Copies the contents of the id_ed25519.pub file to your clipboard
In the upper-right corner of any page on GitHub, click your profile photo, then click
Settings
.In the “Access” section of the sidebar, click
SSH and GPG keys
.Click
New SSH key
orAdd SSH key
.In the “Title” field, add a descriptive label for the new key. For example, if you’re using a personal laptop, you might call this key “Personal laptop”.
Select the type of key, either authentication or signing.
In the “Key” field, paste your public key.
Click
Add SSH key
.If prompted, confirm access to your account on GitHub.
Testing your SSH connection#
From GitHub:
Open Terminal.
Enter the following:
ssh -T git@github.com # Attempts to ssh to GitHub
You may see a warning like this:
> The authenticity of host 'github.com (IP ADDRESS)' can't be established. > ED25519 key fingerprint is SHA256:+DiY3wvvV6TuJJhbpZisF/zLDA0zPMSvHdkr4UvCOqU. > Are you sure you want to continue connecting (yes/no)?
Verify that the fingerprint in the message you see matches GitHub’s public key fingerprint. If it does, then type
yes
:> Hi USERNAME! You've successfully authenticated, but GitHub does not > provide shell access.
You may see this error message:
... Agent admitted failure to sign using the key. debug1: No more authentication methods to try. Permission denied (publickey).
This is a known problem with certain Linux distributions.
Note
The remote command should exit with code 1.
Verify that the resulting message contains your username.
Open Terminal.
Enter the following:
ssh -T git@github.com # Attempts to ssh to GitHub
You may see a warning like this:
> The authenticity of host 'github.com (IP ADDRESS)' can't be established. > ED25519 key fingerprint is SHA256:+DiY3wvvV6TuJJhbpZisF/zLDA0zPMSvHdkr4UvCOqU. > Are you sure you want to continue connecting (yes/no)?
Verify that the fingerprint in the message you see matches GitHub’s public key fingerprint. If it does, then type
yes
:> Hi USERNAME! You've successfully authenticated, but GitHub does not > provide shell access.
Note
The remote command should exit with code 1.
Verify that the resulting message contains your username.
Open Git Bash.
Enter the following:
ssh -T git@github.com # Attempts to ssh to GitHub
You may see a warning like this:
> The authenticity of host 'github.com (IP ADDRESS)' can't be established. > ED25519 key fingerprint is SHA256:+DiY3wvvV6TuJJhbpZisF/zLDA0zPMSvHdkr4UvCOqU. > Are you sure you want to continue connecting (yes/no)?
Verify that the fingerprint in the message you see matches GitHub’s public key fingerprint. If it does, then type
yes
:> Hi USERNAME! You've successfully authenticated, but GitHub does not > provide shell access.
Note
The remote command should exit with code 1.
Verify that the resulting message contains your username.
Submitting issues#
If you are experiencing issues with any code or content of a repository (such as this operating manual you are reading right now), you can submit issues. For doing so go to the dashboard of the corresponding repository and press the Issues
tab where you can open a new request.
For example you encounter a bug or a mistake in this operating manual, please visit this repository to open a new issue.
Git troubleshooting#
Problem 1: https instead of ssh:#
The symptom is:
$ git push
Username for 'https://github.com':
Diagnosis: the remote
is not correct.
If you do git remote
you get entries with https:
:
$ git remote -v
origin https://github.com/duckietown/Software.git (fetch)
origin https://github.com/duckietown/Software.git (push)
Expectation:
$ git remote -v
origin [email protected]:duckietown/Software.git (fetch)
origin [email protected]:duckietown/Software.git (push)
Solution:
git remote remove origin
git remote add origin [email protected]:duckietown/Software.git
Problem 2: git push
complains about upstream#
The symptom is:
fatal: The current branch ![branch name] has no upstream branch.
Solution:
$ git push --set-upstream origin ![branch name]