[[TOC]]
You can make a clean installation of git using the installation instructions from the official website.
You will need a GitHub Account and configure your ssh key with github to collaborate with the IcaliaLabs git repositories.
If you never use git version control before you can continue with this guide you should check this awesome resources to learn git:
We at Icalia Labs never work directly on the master branch to build software, we use a git workflow to keep things isolated.
Lets take a look to this workflow:
You’ll develop your new feature, knowing that when finished, your feature will be ready to be deployed, instead of waiting in “inventory”.
- Keep small code features.
- You must keep track of changes coming from “master” while your code is still in development.
Automated CI tools (Drone, Foresight) will start giving you feedback throughout the process.
Lets your team know:
- Your feature is ready
- You’re stuck and need help
- You’re sharing code and/or general ideas
- The rest of the team may need to adapt to changes in code
Remember to use the Pull request template:
### What does this PR do?
* Add "create post" button
* etc
#### Merge Checklist:
- [ ] The branch is up-to-date (i.e. rebased) with the base branch
- [ ] All tests are passing - see ["Running tests"](../#running-tests)
- [ ] No code style issues
This template consists in two sections:
- A list for describing what the pull request does
- A list of checkboxes with information about the status of the pull request( tests status, branch status, code style issues)
- Lets you receive feedback from your team mates:
- Questions about how to use your new code feature, or how your code will impact their current work.
- Quick tips from your team mates.
- Lets you receive feedback from Icalia Labs’ Tech Leads:
- Learn how to improve your code.
- Learn development platform / framework features you might be missing.
- Lets you add changes to the code upon received feedback:
- Improve the quality of the code.
- Add missing code features (i.e. tests, etc).
An opportunity to detect deployment issues with your code without causing trouble on live / production servers.
By this point, your code has been reviewed, accepted, and validated on staging/demo servers, and ready to be merged back to master.
Your feature will automatically be deployed if continuous deployment is enabled, and your work is no longer in “Code Inventory”.
- Changes merged to master via “Squash & Merge”.
Selects code changes to add to an upcoming commit.
You can practice this command in the katacoda scenario 1.
Commit related code changes.
Recomendations:
- Commit messages reflect intent.
- Write meaningful commit messages, don't just go simple and short.
- Start your commit message with a present verb such as
Adds
,Removes
,Updates
. - Never track files specific to your local development machine.Some examples of this files are
.env
,.DS_Store
,.log
, etc.
You can practice this command in the katacoda scenario 1 and katacoda scenario 2.
Branches are created based on another branch, generally master. The command git branch takes an existing branch and creates a separate branch to work in. At this point both branches are identical.
You can practice this command in the katacoda scenario 6
Used to publish new local commits on a remote server.
You can practice this command in the katacoda scenario 3
Used to bring changes from our branch at origin.
Recomendations:
- Change into the branch you want to update.
- Don’t use “git pull” to merge code from other branches.
- If you’re forced to specify the branch name with pull your’e doing it wrong - ask for help.
Use it to bring up changes from other branches(most commonly, from “master”).
Recomendations:
- Solving code conflicts is not a code reviewer’s responsibility!
- However, you might ask for help when you get stuck.
- VS Code is a great tool to resolve merge conflicts VS Code git guide.
You can practice this command in the katacoda scenario 5.
Saves uncommitted changes into a “drawer”, from which you can retrieve those later.
- Used when you can’t pull from upstream because of conflicting uncommitted changes.
- Also used when you can’t switch between branches because of conflicting uncommitted changes.
You can learn git stash with the Git stash guide.
Picks one or several commits from another branch into yours(useful when back-porting fixes from another branch).
You can practice this command in the katacoda scenario 8.
Here are some git advanced guides that can help you in your everyday workflow