- Learn about Issues, Commits, and Pull Requests
- Understand the collaborative git/GitHub work-flow that will be used throughout the internship
- Create an issue, and upon admin approval, create a branch to fix it
- After resolving the issue in the branch, make a pull request to the upstream repository
- Work with admins to make adjustments if necessary, and merge your branch into the upstream
- Comment on an existing issue
On GitHub, each repository has a section where issues can be added, discussed, and fixed as a means of categorizing and addressing problems we find. Issues are often opened by our team to fix software bugs on the Planet/Community and in our code.
NOTE: Issues are not just about adding to the wiki, but can also involve removing repetitive or unnecessary code or content. (please refer to #1108)
We encourage you to file as many issues as you can, no matter how big or small. If you notice something but are not sure how to solve it, file an issue anyway to let others know about it so it can be fixed. Strive to provide as much value as possible with the issues you submit. By doing so, you will better support the community and improve this section for all.
Below, you'll find the workflow where we brought up a problem, researched an answer, and then fixed the issue.
First, you will need to open an issue within the right repository (upstream repository) and explain the problem. If you are explaining a bug or how to replicate an issue, please be as explicit as possible and use pictures as necessary. You will then research the possible solutions or ideas on how to address the issue before detailing your proposed solution, as you can see here. Someone else will hopefully provide input, and then you can move ahead with making the proposed changes.
IMPORTANT: Issues are not required to be approved before a Pull Request is submitted for the respective fix; however, we do suggest that you wait until someone from the OLE confirms/approves the change that your issue addresses BEFORE you begin work on the fix. Check out this example issue, per Dogi, that shows the importance of confirmation: #1465.
BE WARNED! If the OLE member(s) does not approve your issue, prior to the creation of the Pull Request, your efforts may be in vain. If the OLE member(s) does not approve the change, the Pull Request will not be merged and the issue will not be counted towards your "First Steps" progress. Therefore, it is suggested that you wait for the OLE member(s) to approve your issue submission.
Already available issues: You can also help on issues which have already been created. Issues which are tagged as first step intern
can be taken and worked on. Please make sure when you start working on these issues that you assign yourself to said issue or ask to be assigned. If someone else is already assigned to an issue, do not try to work on that issue.
SPECIAL NOTE: Aspiring Virtual Interns have a tendency to speed through this process in order to check off their "First Steps" requirements. The purpose of these requirements is to fix an actual problem and improve the "First Steps" as a whole. Take time to review the "First Steps" materials to identify real issues and to research helpful solutions. It is also important to search current/open issues to see if the problem has already been identified.
Every time you start to work on an issue, you need to create a branch to keep issues you are working on separated from each other.
Before you create your branch, sync your repo using the commands:
git fetch upstream
git checkout master
git merge upstream/master
git push origin master
More details in the previous step.
To create a new branch, go to your github repo and create it in a similar fashion as the following image:
Use git checkout master
to switch to master branch, then use git checkout -b <name_of_your_new_branch>
to create and switch to a new branch on your local repository. Make sure to remove the angled brackets (< & >) as they are just place holders. More documentation on checkout can be found here.
Now you can go and make the proposed changes to your local files using any text editor you prefer. You can also use VIM or Nano to edit files from the terminal. This guide on VIM and this guide on Nano contain more information on their proper usage. In the future, we recommend you use Visual Studio Code for Planet, VIM for treehouse, and Android Studio for Android development.
NOTE: Use git branch
to see which branch you are in. Your master
branch is the base working branch. It needs to remain untouched just in case you need to revert some changes back to a working version. Make sure you are on right branch using git checkout <branch-name>
while making proposed changes to your local files and while committing.
If you're still confused, that's quite alright. Forking Workflow can be quite challenging at first. See the diagram below. For better context, the new branch you just made is inside your "Forked GitHub IO".
After making modifications to your local files and before making a commit, you would want to preview the changes locally. The following link, how to preview changes, gives all the information about how to preview changes from your machine. There's also another option to preview using online environment. This link takes you to the online environment.
NOTE: In case you have come up with the wrong edit and if you'd like to revert it back to the previous version of the file follow this link. This is applicable only before committing the change.
Use the next commands to commit and push the changes:
-
git status
to see which files in the working directory have been modified. -
git add .
to stage ALL of the modified files shown, orgit add <file1> <file2> <file3>...
to stage specific modified files. -
git commit -m "<your_commit_message> (fixes #<issue_no>)"
(refer to the commit message guidelines below). -
git push -u origin <name_of_your_new_branch>
to save your changes and push them to your GitHub (for any further commit on the same branch after the first one, you can just usegit push
).
Because the commits you will be making on this markdown wiki are fairly basic, it is not necessary to enforce a wordy commit style. However, in the future, when you start to work on more complex projects, it is helpful to write your commit messages in a certain way. Here is an article on how to write good commit messages.
For edits to this markdown wiki, we recommend that your commit messages only consist of the subject line (refer to the article for more on what the subject is). Rules 2-5 are the most important:
- Limit the subject line to 50 characters
- Capitalize the subject line
- Do not end the subject line with a period
- Use the imperative mood in the subject line
Here is an example of how you would write your commit message:
$ git commit -m "Add commit message style guide and add raw.githack section (fixes #841)"
NOTE: In your commit message, if you add a keyword like "fixes" or "resolves" followed by "#" and the issue number, once your pull request is merged, the issue will automatically be closed. This is helpful because it helps declutter the issues section. See more here.
Raw.githack is an important aspect of the pull request process. After you commit changes to your local branch and push them to your remote branch, you can view these changes by going to https://raw.githack.com/{YourGitHubUsername}/{YourGitHubUsername}.github.io/{YourBranchName}/#!index.md
and viewing the page(s) you have changed. You may need to change the link slightly depending on where the file you want to view is located. If everything looks correct, you are ready to create a pull request. If you need to change the file path try: https://raw.githack.com/{YourGitHubUsername}/{YourGitHubUsername}.github.io/{YourBranchName}/#!{file path separated by /}
.
For example, http://raw.githack.com/aasenomad/aasenomad-ole.github.io/master/#!index.md will result with this:
You can also use the raw.githack url generator on https://raw.githack.com
- Select the branch you were working on from the drop-down on the top left
- Navigate to the page you changed in your fork of the GitHub repository
- Copy the URL in your browser and paste it in the field on https://raw.githack.com
- Select the Development URL
- Add
#!
after the forward slash proceeding your branch name, this will show the markdown in presentation mode rather than as raw markdown.
example:
Raw.githack makes it easy to see what the page will look like if your branch is merged, so don't forget to include a raw.githack link in your next step, the pull request.
If you login to your own fork of OLE on Github, GitHub will notice that you recently pushed a new branch. The fork can be found via https://github.com/YourUsername/YourUsername.github.io
, replacing YourUsername with your own details. Press the green button that says Compare & pull request. In this new page, give the PR a title and description. Once you are done with filling out these forms, submit the pull request by clicking on the green create pull request button.
For everyone's convenience, we highly recommend that you follow a certain structure when submitting a pull request. We suggest to include the issue for which the pull request is resolving (for example, if your pull request fixes the issue number 320, then add #320
to your pull request) to the title of your PR and also the raw.githack link into the description of the pull request. This saves a lot of time for the person reading your pull request as he/she does not need to search and match the issues with the corresponding PR and is able to instantly see the changes pushed via the raw.githack link.
Additionally, creating a checklist will help others understand what you have done and what needs to be done - it helps you coordinate with your team members with the issues you are facing in an organized manner. GitHub will render the task list in markdown, and it will look similar to something like the checklist shown below this paragraph.
[x] Check for issue number in pull request title [x] Are there any unneeded files in the pull request? [x] Did they make a branch for their patch? [x] Does the pull request actually fix the issue? [x] Check the pull request on raw.githack, does it display without any errors? [x] Is there any merge conflicts? [x] Make sure that people use their GitHub accounts when making commits through git
Some of these items are of course optional, but try to include as much useful information for others as possible in your checklists because nobody really wants to work on something that has already been completed by someone else.
NOTE: While you are waiting on two OLE team members to approve your Pull Requests, it is OK to keep creating more Issues and Pull Requests in the meantime. They will all count towards your final Issue/PR total, and PR approval can take time, so do not let a lengthy approval/fix process keep you from moving on in your "First Steps".
-
Wait for the pull request merge! All that remains is posting your pull request in the chat and waiting until one of the OLE staff gets a chance to look at it. Be aware that a staff member may either submit a code review asking you to modify some of your changes, or accept the pull request and close the issue. You can see the process here.
-
Delete the branch from your remote repository. After your pull request has been approved and merged by OLE staff, you might want to delete the branch that is associated with your pull request. It can keep your local and remote (yourUserName.github.io on GitHub) repository away from a mess of defunct branches. To delete the defunct branch in your remote repository, you can click the "Delete branch" button in your pull request (see the picture below).
- Delete the branch from your local repository.
To delete the defunct branch in your local repository, use the command
git branch -d <yourLocalBranchName>
(make sure you are not on the branch that you want to delete). Go here to find out more about how to delete a branch locally.
NOTE: Remember to always sync your fork before starting to work on a new issue. To sync your fork you can follow the process in the previous step.
This is an exercise to help you familiarize yourself with GitHub issues, committing, and creating pull requests. This is a common process in large open source projects as there is always room for improvement. So, we strongly encourage you to follow this process and continue to post issues and resolve them.
You will need to make at least one comment on an issue you did not create.
-
Go to the upstream repository
-
Click on the
Issues
Tab -
Click on an issue, and read it thoroughly
-
Scroll down and add your comment in the Write box (comments are always written in Markdown, so click on Preview to see how your comment looks like)
-
Click on Comment when finished
NOTE: Make sure your comment is made with a purpose and provides useful feedback
Mastering Issues - The official Git Guide on the basics of filing an issue. Helpful links and videos How to Contribute to Open Source
Next Section (Step 7) →
In the next step, you will learn how to sync your Community Planet with the Nation.