Version 2018-Spring-1.1-Final, Revised 14 February 2018
Activity for practicing with git and issues on GitHub.
For this activity, the students will practice making changes to a GitHub repository. The repository has a text file that has been "scrambled" - meaning that random words have had their characters randomly rearranged, and considered to be issues to be fixed.
The misspellings were generated by the twiddle.py
program and then entered as issues by the report.py
program (from this git-twiddler fork.
- Git installed and configured on your computer.
- GitHub account created and username emailed to professor.
- Invitation to class organization on GitHub accepted.
- SSH key added to GitHub account.
If you have not completed these setup steps, see the instructions at the bottom of this document.
-
Fork the repository
-
Clone the repository
-
Add the original repository as an upstream remote:
git remote add upstream [email protected]:CS-Worcester-CS-348-SP-2018/git-issue-activity.git
-
Repeat as often as possible during the class:
- Assign yourself to an issue on GitHub (e.g. issue #42)
- Make sure you are on the Master branch:
git checkout master
- Pull any changes that have ocurred since your last pull, and correct merge conflicts
git pull upstream master
- Create a branch named for the issue (e.g.
issue-42
), and switch to that branch:git checkout -b issue-42
- Edit the
LICENSE.txt
file to correct the issue - Add the change
- Commit the change, with a message describing the change (include line number and correction, e.g.
Correct misspelling, line 1: UGN -> GNU
) - Pull any changes that have ocurred since your last pull, and correct merge conflicts
git pull upstream master
- Push the change
git push origin issue-42
- Make a pull request to have their change merged into the original repository.
- On GitHub switch to the newly pushed branch.
- Click the
New Pull Request
button. - Include in the pull request text a notation that it closes the assigned issue (e.g.
Closes #42
) - Click
Create Pull Request
- Wait for the repository owner to accept the pull request.
- Open your browser and go to: http://git-scm.com/downloads
- The picture of the monitor on the page should show the download for your operating system. Click on the download button and save the installer.
- Run the installer.
- On Windows, use the default settings, when given choices.
- Start a command-line/terminal window, as shown below:
- On Windows, go to the Start menu > All Programs > Git > Git Bash
- On Mac OS X, go to the Applications folder > Utilities folder > Terminal
- Configure Git, so that it knows who you are and can label your changes, and so it colors the output. Type the following commands (replacing
Jane Smith
and[email protected]
with your own name and email address):
git config --global user.name "Jane Smith"
git config --global user.email [email protected]
SSH (Secure Shell) is a network protocol for encrypted data transmission. It is often used for password-less login to remote servers, and we will be using it to allow you to communicate with the GitLab server without having to type your password every time you want to send code changes to the server. SSH uses public-key encryption, and to use it you need to create a public-private key pair. Your public key is made available to anyone with whom you want to exchange encrypted data. Your private key is used only on your computer and should be protected carefully.
- Create an ssh key pair by typing:
ssh-keygen -t rsa -C [email protected]
- When it asks you for the filename, use the default, by hitting
Enter
. - You should enter a passphrase when prompted. Using a passphrase will assure that no one else can use your private key, even if they gain access to the key file. When you type your passphrase, your typing will not show — not even as • or *.
- When it asks you for the filename, use the default, by hitting
- Keep your Git Bash or Terminal window open.
- Return to your browser and go to http://github.com
- Create an account. You may choose any username you wish, and use any email address you wish.
- One you have completed the account creation process, let your instructor know what username you chose. You will be added to a group for the course.
- Add your SSH key:
- Go to the Settings by clicking on the dropdown under your avatar at the top right of the screen. (That circle can hold a picture of you if you set an avatar under Settings")
- Click on the SSH and GPG Keys in the menu on the left.
- Clik on the green New SSH Key button.
- Copy your public key to the clipboard.
- Go back to your terminal window.
- On Windows type:
notepad ~/.ssh/id_rsa.pub
- In the Notepad window, select all the text and copy it.
- On Mac OS X, type:
pbcopy < ~/.ssh/id_rsa.pub
- Switch back to your browser and paste your key into the key box.
- Type a title for your key. (It can be anything you want.)
- Click the green Add SSH Key button.
- If you are on Windows, close Notepad.
This work is licensed under the Creative Commons Attribution-ShareAlike 4.0 International License. To view a copy of this license, visit http://creativecommons.org/licenses/by-sa/4.0/ or send a letter to Creative Commons, 444 Castro Street, Suite 900, Mountain View, California, 94041, USA.