This is the repository we will use to do practice exercises for the whole team.
Open the starter-project-[your team]-[your group]
folder where you will find a README.md
file with instruction to follow. The goal of this exercise is to practice the consistent worlflow we would use during development in the respective teams and technologies
- Look into the Workflow Steps and the Instructions in
Names.md
. Follow the Steps to add your name and prefered project in theNames.md
file
- Clone the repository if you don't have it already (this tends to get more difficult as the project grows and the file size grows)
- If you already had the project locally, perform a
git pull
on the main branch - Create and checkout to a new branch from the main. You can use
git checkout -b branch-name
, which is a shorter alternative forgit branch branch-name
followed bygit checkout branch-name
- The branch naming convention should follow the pattern
name.feature-name
. (eg.nati.login
,emre.users-form
) - If you already have a branch and wish to continue working on it, use Rebase to bring in changes from the main branch. Use the command
git rebase main
if you are on your branch orgit rebase main branch-name
from anywhere to rebase your branch onto the main - Pulling from main into your branch (same as merging the main into your branch) could have similar results but using rebase from the main makes a more linear version control history as it basically pretends like whatever you committed on your branch happened After the changes in the main wheather they actually happend after or before
- Once your branch is rebased and upto date, make the changes you wish to make and stage and commit your changes. Make sure to remember if you need to add any files into the
.gitignore
before committing - The commit messages should be Present Tense Imparative Sentences (eg. "Create README.md", "Update the Login Page"). Imagine the phrase "This commit is made to..." before your commit message (eg. "This commit is made to
Create README.md
"). In addition to an imparetive statement, include a tag for what the commit is about in square braces. So a full commit message could look something like -[mobile] Update Login Page
. And make sure a commit is as small as can be explained in one statement. - Once the commits are made, push the local changes to github using
git push
. If you have made a rebase however, you may need to push forcefully cause you could get some weird conflicts otherwise. So usegit push --force
instead. - Once the changes are pushed to remote, go to github and create a pull request. for a few minutes after you made a push, GitHub presents a big
Make Pull Request
button for your branch to make it easy for you. In any case, you can go to the branches list and find an option to create one for your branch. - When creating a pull request, make sure to add atleast one reviewer (either your team leader or someone who maybe understand what you did better).
- If the reviewer leaves some comments, address those issues and make a commit for it and push it. However, make sure to pull in the main branch and rebase onto the main branch (Step 5) to get updates that other people added in the meantime whenever you want to make changes, make a push, or before you merge.
- If the reviewer approves the pull request, you can now merge it to the main branch. Github offers you the option to merge the pull request. If you choose the
Squash and Merge
option, it allows you to group together your multiple smaller commits into one commit message with the others listed as a description. - Once you have merged a branch, make sure to rebase again to get updates from the main if you intend to keep working on it. Otherwise try to delete it as soon as you can. It is better and easier to recreate the branch again later if you need it.
If you have any other questions, feel free to look it up, ask your team leads or really anyone else. Thank You.
Made with ❤ since 2019 in Ethiopia, Turkey and USA by the Eskalate team. Eskalate LLC is a American company.
Copyright © 2020 Eskalate. All rights reserved.