Github For Teams
Leon Noel
#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
Checking In
Like and Retweet the Tweet
!checkin
Who is this for?
*Played around with git and maybe Github
You Are Not Alone!
!100Devs
leonnoel.com/100devs
THANK YOU
Microsoft Azure you a real one
SECRET !NEWSLETTER RAFFLE
Let's GIT IT ON
First, The Terminal
Terminal, Bash, Git Bash, Unix, Shell, CLI, cmd
A place where you can type commands that cause actions
CLI > GUI
Command Line Interface vs. Graphical User Interface
Let's Look
The Terminal
Common Commands
pwd
(print working directory) shows where you are
mkdir
(make directory) create a folder
cd
(change directory) move to a different folder
cd ..
goes up a folder
cd ~
go back to home folder
touch
create a file
ls
shows you all the files in a folder
ls -l
shows you all the files in a folder with more info
ls -la
shows you all the files in a folder including hidden
rm
removes a file
rm -r <folder>
removes a folder
rm -rf <folder>
removes everything even protected files - be careful!
clear
clears what is currently being displayed
code filename
Opens file in VS Code
In VS Code:
view -> Command Palette ->
Shell Command: Install 'code' command in PATH
Access The Terminal?
Mac & GNU/Linux
Applications -> Terminal
Windows
Git Bash
https://gitforwindows.org
(for today)
Let's Code
Normal Folder Setup
!raffle
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
!raffle
Basic Git Commands
git init
Creates a special folder to hold all of your snapshots (commits)
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
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
git branch -M main
Changes name of staging area to main
Let's Code
Make A Commit
!raffle
Want to try something without borking all your code
BRANCHES
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
!raffle
What is Github?
Local Vs. Remote
Not only backups,
but a whole suite of tools to work with other developers
Let's Make
A Github Account
!raffle
Let's Create A Freelancer Listing
Github Copilot To Help
Create A Github Repo
Instructions with each new repo
PUSH IT
Now Let's Work Together
Create Repo and Invite Bob
Create A File
We'll Code In The Cloud
Just press .
GITHUB CODESPACES
60 hours of free compute time
What are Github Issues?
Create An Issue
Assign The Issue
Let's Create
Our First Issue
Freelancer Repo We Just Created
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
Get The Code
git pull git checkout or just .
Make Changes
Push The Repo
Commit has issue number
Ex: Added company name #1
Create A Pull Request
Let's Review
Some Code!
Start A Review
Resolve Conversation
Request Changes
Make The New Changes
Approve The New Changes
Merge The Changes
STRAIGHT TO MAIN
Delete The Branch
Close The Issue
Questions?
!raffle
Let's Create A Dev Branch
Both Make Changes On Dev
Manage Conflicts
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
GitHub Projects
Let's Submit
A Real Pull Request
JOB-ULY
Laptop !raffle
Homework
#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,509