Github For Teams
Leon Noel
data:image/s3,"s3://crabby-images/931bc/931bcda3cf874ee316cc7f3851a0571e0e69c668" alt=""
#100Devs
Sponsored by Microsoft Azure!
Agenda
-
Let's Talk - #100Devs & Thank You Microsoft Azure
-
Learn - GIT / Github Basics
-
Learn - Projects / Repos / Copilot
-
Learn - Issues / Pull Requests
-
Learn - Code Review
-
Learn - Merging
-
Learn - Dev vs Prod
-
Learn - GitHub Projects
-
Homework - Intro. to Git & Github
Questions
About last class or life
data:image/s3,"s3://crabby-images/ff3c8/ff3c8881ef667b0d161cf3dac9091093f3da60ae" alt=""
Checking In
data:image/s3,"s3://crabby-images/d0008/d00086f2e9179bf58916ddcff8a290c3f1697f69" alt=""
Like and Retweet the Tweet
!checkin
Who is this for?
data:image/s3,"s3://crabby-images/85940/85940004ecedc67f607ae6e6add38121dca206ff" alt=""
*Played around with git and maybe Github
You Are Not Alone!
data:image/s3,"s3://crabby-images/7d17d/7d17de778c881de728e12b4fd2e253a8d194c82e" alt=""
!100Devs
leonnoel.com/100devs
THANK YOU
data:image/s3,"s3://crabby-images/7354f/7354f1a520919251fd22a4b0b4f20cf46012eb94" alt=""
Microsoft Azure you a real one
SECRET !NEWSLETTER RAFFLE
data:image/s3,"s3://crabby-images/1046a/1046ad54e2b1db8a54fd42721f610584c73540ef" alt=""
Let's GIT IT ON
data:image/s3,"s3://crabby-images/27b66/27b66faadbb65c1c224c6b6c7cb62a3f769f99c8" alt=""
First, The Terminal
data:image/s3,"s3://crabby-images/f98e2/f98e20373db8720b33ed70133ac1ee846b4ada94" alt=""
Terminal, Bash, Git Bash, Unix, Shell, CLI, cmd
data:image/s3,"s3://crabby-images/4f9be/4f9be4c0688c90284921b2201851c48a6b50941f" alt=""
data:image/s3,"s3://crabby-images/bfc7f/bfc7f054eaf8d43b206547ac4de9b7ec4e979aeb" alt=""
A place where you can type commands that cause actions
CLI > GUI
Command Line Interface vs. Graphical User Interface
Let's Look
The Terminal
data:image/s3,"s3://crabby-images/931bc/931bcda3cf874ee316cc7f3851a0571e0e69c668" alt=""
Common Commands
data:image/s3,"s3://crabby-images/5c037/5c0374c5b1393cadb19ec7201942e1a66cb51fb4" alt=""
pwd
(print working directory) shows where you are
data:image/s3,"s3://crabby-images/58c07/58c073bf1c6953780593ea45b994f509a497e609" alt=""
mkdir
(make directory) create a folder
data:image/s3,"s3://crabby-images/314ef/314efa003f683d62ca44ef568583f9146494daec" alt=""
cd
(change directory) move to a different folder
data:image/s3,"s3://crabby-images/4c031/4c031c3231485932cf806165e2ced1d8a2d494ca" alt=""
cd ..
goes up a folder
data:image/s3,"s3://crabby-images/4f918/4f9180f0c08574a27dc05d1d3abafeaf687b68a2" alt=""
cd ~
go back to home folder
data:image/s3,"s3://crabby-images/417de/417de9be38d245bb028b64de17a4803f2c98f715" alt=""
touch
create a file
data:image/s3,"s3://crabby-images/251db/251db62b1a3bbcdc3e4a4ca45b9a1dfcc1e6eb60" alt=""
ls
shows you all the files in a folder
data:image/s3,"s3://crabby-images/8e215/8e215a6fa78883a4f598b128139801eea5c4fad5" alt=""
ls -l
shows you all the files in a folder with more info
data:image/s3,"s3://crabby-images/abd53/abd53c2cc46a7bd906a5ecfe863f76456a7c1189" alt=""
ls -la
shows you all the files in a folder including hidden
data:image/s3,"s3://crabby-images/10423/10423602102274d30571743202ee4c88b288981f" alt=""
rm
removes a file
data:image/s3,"s3://crabby-images/6537a/6537a0a7aa9f072d9bb0210b953402b235a8a4a0" alt=""
rm -r <folder>
removes a folder
data:image/s3,"s3://crabby-images/997b0/997b06f7c6bdb0f72ed0f35904d9e880e0707234" alt=""
rm -rf <folder>
removes everything even protected files - be careful!
data:image/s3,"s3://crabby-images/96e45/96e45f51e7631f65c4cc90e76c8040f8beb05a26" alt=""
clear
clears what is currently being displayed
data:image/s3,"s3://crabby-images/3e46a/3e46a3db54299dcb199225ff30b2ad29eaf725c6" alt=""
data:image/s3,"s3://crabby-images/9ab9e/9ab9e606f18cd0ab4461febc7fb1e53f46a4c31f" alt=""
code filename
Opens file in VS Code
In VS Code:
view -> Command Palette ->
Shell Command: Install 'code' command in PATH
data:image/s3,"s3://crabby-images/1a10a/1a10a003ea3ee6abc3c75f40dfbf9926c53b441c" alt=""
Access The Terminal?
Mac & GNU/Linux
Applications -> Terminal
Windows
Git Bash
https://gitforwindows.org
(for today)
Let's Code
Normal Folder Setup
data:image/s3,"s3://crabby-images/931bc/931bcda3cf874ee316cc7f3851a0571e0e69c668" alt=""
!raffle
data:image/s3,"s3://crabby-images/d337b/d337b56fc91eb3938222aa47dc9c93d8e362f721" alt=""
WHAT IS GIT?
While working on a really important Word Doc what did you do?
What if you wanted to work with someone else?
Git solves this problem when working with code
(save points)
Git is a version control system
A really fancy way of tracking changes
Git enables you to take "snapshots"
This has a deeper meaning, but similar to save points
Git enables you to take "snapshots" by making a commit
Just the term for creating that save point
Git enables you to roll back to previous "snapshots" (commits)
No more file -> save as -> folder132
Install Git
Windows
Git Bash
https://gitforwindows.org
(for today)
WSL
(for life)
MacOS
Install Homebrew:
$ /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
$ brew install git
GNU / Linux
Debian / Ubuntu
$ sudo apt-get update
$ sudo apt-get install git
Once Installed
Setup User Name and Email
$ git config --global user.name "Leon Noel"
$ git config --global user.email "leon@leonnoel.com"
Let's Install
Try Installing Git
*If you get stuck, leonnoel.com/discord
data:image/s3,"s3://crabby-images/931bc/931bcda3cf874ee316cc7f3851a0571e0e69c668" alt=""
!raffle
data:image/s3,"s3://crabby-images/fe9c2/fe9c2c73001b33183d4e70761b8272058b51dbd3" alt=""
Basic Git Commands
git init
Creates a special folder to hold all of your snapshots (commits)
data:image/s3,"s3://crabby-images/a1f2c/a1f2ccca2632c12fd6685de1d0abdec288b2a36b" alt=""
git add <file>
Adds file to staging area (not yet in that special folder)
git add *.html
Adds all html files to staging area (not yet in that special folder)
git add .
Adds everything to staging area (not yet in that special folder)
git status
Shows everything in staging area (not yet in that special folder)
git rm --cached index.html
Removes index.html from staging area
git commit
Adds everything in staging to the special folder as a snapshot
data:image/s3,"s3://crabby-images/52f97/52f977ef7f5bd886ba36062850611fb866e76be3" alt=""
If you get stuck in vim:
i -> then type your message -> escape -> type :wq -> enter
git commit -m "text"
Adds everything in staging to the special folder as a snapshot
data:image/s3,"s3://crabby-images/52f97/52f977ef7f5bd886ba36062850611fb866e76be3" alt=""
git branch -M main
Changes name of staging area to main
Let's Code
Make A Commit
data:image/s3,"s3://crabby-images/931bc/931bcda3cf874ee316cc7f3851a0571e0e69c668" alt=""
!raffle
data:image/s3,"s3://crabby-images/f9a47/f9a47507cf187fc85e91441ae7716359998b5996" alt=""
Want to try something without borking all your code
BRANCHES
data:image/s3,"s3://crabby-images/d1682/d1682e6da1f2ac9e7467bd7d4d6979d92e3f3dde" alt=""
git status
Find out if you are on main first
git branch <name>
Creates a new branch for you to make changes on without affecting the rest of your code!
git checkout <name>
Moves you to new branch where you can make changes without affecting the rest of your code!
Make Your Changes
Add your changes to staging
Commit Your Changes
git add .
git commit -m "changes made"
git checkout main
Moves you back to main branch
git merge <branch>
Adds changes from other branch to main
Let's Code
Use A Branch
data:image/s3,"s3://crabby-images/931bc/931bcda3cf874ee316cc7f3851a0571e0e69c668" alt=""
!raffle
data:image/s3,"s3://crabby-images/7165a/7165a3357d9031ffe582a08bfd58884c38572b21" alt=""
What is Github?
Local Vs. Remote
data:image/s3,"s3://crabby-images/5b08a/5b08a1b7238fffff5987da51853164bbd9ae0f8c" alt=""
Not only backups,
but a whole suite of tools to work with other developers
data:image/s3,"s3://crabby-images/78745/78745cdbb2843b38b4ebf19b034bdcdc4b74f089" alt=""
Let's Make
A Github Account
data:image/s3,"s3://crabby-images/931bc/931bcda3cf874ee316cc7f3851a0571e0e69c668" alt=""
!raffle
data:image/s3,"s3://crabby-images/c7c8b/c7c8b0fe93f427421a40e5b0da7d123b7b9dedcb" alt=""
Let's Create A Freelancer Listing
Github Copilot To Help
data:image/s3,"s3://crabby-images/399fc/399fc7463891e5fdc951f110a61dbd66cb33b810" alt=""
Create A Github Repo
data:image/s3,"s3://crabby-images/9b5e3/9b5e3aa9d53d1dac65dbb85a5198c54aca176328" alt=""
data:image/s3,"s3://crabby-images/460b9/460b964afa438c895e4ca856f4cf64cb2e73dbfc" alt=""
Instructions with each new repo
PUSH IT
data:image/s3,"s3://crabby-images/35db1/35db170ea2816cec49977bab0db1c1b1a9c0a3a2" alt=""
Now Let's Work Together
data:image/s3,"s3://crabby-images/762ee/762ee33ec31d18f720e1110894e90f01fd8bcb05" alt=""
Create Repo and Invite Bob
data:image/s3,"s3://crabby-images/6d588/6d5887ad467c01299267a02c4d8618bedf2092a0" alt=""
Create A File
data:image/s3,"s3://crabby-images/b0010/b00108adaaec04d1da0963caf3f4698c7a7b602e" alt=""
We'll Code In The Cloud
data:image/s3,"s3://crabby-images/ef38b/ef38be33731761fdcba4caceb969f76dd8bef66f" alt=""
Just press .
GITHUB CODESPACES
60 hours of free compute time
data:image/s3,"s3://crabby-images/cc41c/cc41c26c95ad12b9fdee0e9ecab4bfefcecd9161" alt=""
What are Github Issues?
Create An Issue
data:image/s3,"s3://crabby-images/3aa66/3aa66b1804be9ee24fc2e96cd9ff0507eb9d3b9d" alt=""
Assign The Issue
data:image/s3,"s3://crabby-images/8dafc/8dafc7b2c99c97cf28faf0c16fdfba1ff5c2756e" alt=""
Let's Create
Our First Issue
Freelancer Repo We Just Created
data:image/s3,"s3://crabby-images/931bc/931bcda3cf874ee316cc7f3851a0571e0e69c668" alt=""
Let's Talk Workflow
Repeat With Me
Every Team Is Different
This Is For Beginners
I Will Not Workflow Shame
GitHub Flow
"GitHub flow is a lightweight, branch-based workflow. The GitHub flow is useful for everyone, not just developers. For example, here at GitHub, we use GitHub flow for our site policy, documentation, and roadmap."
https://docs.github.com/en/get-started/quickstart/github-flow
GitHub Flow
- Create A Branch
- Make Changes
- Create A Pull Request
- Address Review Comments
- Merge Your Pull Request
- Delete Your Branch
Creater Flow
- Create Issue
- Review PR
- Request Changes
- Approve Changes
- Close Issue
Dev Flow
- Pick Issue
- Comment Working On
- Assign To Themself
- Make Changes / Commit
- Make Pull Request
- Complete Requested Changes
- Merge Pull Request
- Delete Branch
Create A Branch
data:image/s3,"s3://crabby-images/e21e1/e21e1ae0c5a10cdfe005b8c20afd43119e4b10bb" alt=""
Get The Code
git pull git checkout or just .
data:image/s3,"s3://crabby-images/84ea2/84ea273a0888f4afa84c69100271ec9468190498" alt=""
Make Changes
Push The Repo
Commit has issue number
Ex: Added company name #1
data:image/s3,"s3://crabby-images/61fd7/61fd7f0481a37b5ec9443b6654e8522158672267" alt=""
Create A Pull Request
data:image/s3,"s3://crabby-images/e9cd9/e9cd9330fe6ed9341d5577fcb19a6d1d4b1f655a" alt=""
Let's Review
Some Code!
Start A Review
data:image/s3,"s3://crabby-images/defd6/defd6f27e463e4216cce9a61623614324c164a61" alt=""
Resolve Conversation
data:image/s3,"s3://crabby-images/3e75b/3e75b79aa57c2b2885fb83e3ebcda65599a42881" alt=""
Request Changes
data:image/s3,"s3://crabby-images/a894d/a894d524098d899960b6b47e28122cfaddd63c5e" alt=""
Make The New Changes
data:image/s3,"s3://crabby-images/349d7/349d7d9f76a233997dd0c1f067c7092d04113c2e" alt=""
Approve The New Changes
data:image/s3,"s3://crabby-images/1bf80/1bf80c9277610b23d34a755beb29fa8ff1a6682c" alt=""
Merge The Changes
data:image/s3,"s3://crabby-images/e47ae/e47ae7feb9946ea6a51467b0a2161a01ba9a96bf" alt=""
STRAIGHT TO MAIN
data:image/s3,"s3://crabby-images/5a9e4/5a9e4e0fc1c48173826d26ac119eda067296c394" alt=""
Delete The Branch
data:image/s3,"s3://crabby-images/2d735/2d7358bb18d93fa5d7fe70a0beb0f6ff30e6a1c7" alt=""
Close The Issue
data:image/s3,"s3://crabby-images/d08a8/d08a81afdbb2c762cae85b29b4ca3f6b43a0bfda" alt=""
Questions?
data:image/s3,"s3://crabby-images/3f3a3/3f3a3f071a46bde7178c3e740482f41826a284fd" alt=""
!raffle
data:image/s3,"s3://crabby-images/a3017/a3017a130afa8b0e9d85475643c92371e12fda48" alt=""
Let's Create A Dev Branch
data:image/s3,"s3://crabby-images/cb436/cb4366d69a7ad776371f2fe037253af5607e62e9" alt=""
Both Make Changes On Dev
data:image/s3,"s3://crabby-images/e0c9b/e0c9b900822cced856bfcb4dbe73d40095b6c404" alt=""
Manage Conflicts
data:image/s3,"s3://crabby-images/9a22f/9a22fac74060fe7987f66db9085e3de976ee7d97" alt=""
How To Prevent Merge Conflicts
- git checkout development
- git pull
- git checkout your-branch
- git merge development
- MAKE YOUR CHANGES
- git add .
- git commit -m "Added changes #issue-num"
- git push
!raffle
data:image/s3,"s3://crabby-images/55bdb/55bdb5f86d0b3a7402b7c8bedfbca5601f34be9d" alt=""
GitHub Projects
data:image/s3,"s3://crabby-images/f2426/f2426a55292d77519b4a278258aa5a214e93b501" alt=""
Let's Submit
A Real Pull Request
data:image/s3,"s3://crabby-images/931bc/931bcda3cf874ee316cc7f3851a0571e0e69c668" alt=""
JOB-ULY
Laptop !raffle
data:image/s3,"s3://crabby-images/e6f42/e6f421289cc0412f9c658f2ddabc7a52c5e84b62" alt=""
Homework
data:image/s3,"s3://crabby-images/75146/751462b91e4c4bcef3175a0e0cb42c3acb62d261" alt=""
#100Devs - Github For Teams (cohort 2)
By Leon Noel
#100Devs - Github For Teams (cohort 2)
Class 72 of our Free Web Dev Bootcamp for folx affected by the pandemic. Join live T/Th 6:30pm ET leonnoel.com/twitch and ask questions here: leonnoel.com/discord
- 1,590