22.7. Studio: Communication Log

Note

If you have not installed Visual Studio Code on your computer yet, now would be the time to do so!

22.7.1. Code Together

Coding together allows you to work as a team so you can build bigger projects faster.

In this studio, we will practice the common Git commands used when multiple people work on the same code base.

You and a partner will code in tag-team shifts. By the end of the studio, you should have a good idea about how two people can work on the same code at the same time. You will learn how to:

  1. Quickly add code in pull + push cycles (Important! This is the fundamental process!)

  2. Add a collaborator to a GitHub Project

  3. Share repositories on GitHub

  4. Create a branch in Git

  5. Create a pull request in GitHub

  6. Resolve merge conflicts (which are not as scary as they sound)

This lesson reinforces:

  1. Creating repositories

  2. Cloning repositories

  3. Working with Git concepts: Staging, Commits, and Status.

22.7.2. Overview

The instructor will discuss why GitHub is worth learning. You already know how to use a local Git repository with one branch, giving you the ability to move your code forward and backward in time. Working with branches on GitHub extends this ability by allowing multiple people to build different features at the same time, then combine their work. Pull requests act as checkpoints when code flows from branch to branch.

Students must pair off for this exercise. If you have trouble finding a partner, ask your TA for help.

22.7.3. Gitting Ready

You are going to simulate a radio conversation between a shuttle pilot and mission control. You and your partner will alternate tasks, so decide who will be the Pilot and who will be the Control.

Before you and your partner can begin your collaboration, some preparation is required first. You will both start by creating a new repository on your separate GitHub accounts.

22.7.3.1. Step 1: Create a New Local Repository

Warning

Be careful if you try to copy/paste the git commands! The $ symbol in the sample code represents the terminal prompt. The symbol is NOT part of the commands.

Control and Pilot: Both of you need to complete steps 1 - 6 on your own machines.

  1. In the terminal, navigate to your development folder. Enter the following 3 commands to create a new project. Replace -ROLE with your part in this studio, either -pilot or -control.

    $ mkdir communication-log-ROLE
    $ cd communication-log-ROLE
    $ git init
    

    Note

    IMPORTANT: To avoid confusion later, it's critical that you and your partner give different names to your repositories.

    For the remainder of this studio, we will refer to the repo as communication-log.

  2. Launch Visual Studio Code. Use the File menu to open the communication-log folder.

  3. Create a new file called index.html and open it in the workspace.

  4. Paste this code into index.html:

    1
    2
    3
    4
    5
    6
    <!DOCTYPE html>
    <html>
       <body>
          <p>Radio check. Pilot, please confirm.</p>
       </body>
    </html>
    
  5. Save your work, then stage and commit it.

    1. First, check the status.

      $ git status
      On branch main
      
      Initial commit
      
      Untracked files:
      (use "Git add <file>..." to include in what will be committed)
      
         index.html
      
      nothing added to commit but untracked files present (use "git add" to track)
      
    2. The output shows is that index.html is not staged. Let's add everything in this directory, then check the status again.

      $ git add .
      $ git status
      On branch main
      
      Initial commit
      
      Changes to be committed:
      (use "git rm --cached <file>..." to unstage)
      
         new file:   index.html
      
    3. The output tells us that the file is staged. Now let's commit. After that, we can see a record of our progress by using git log.

      $ git commit -m "Started communication log."
      [main (root-commit) e1c1719] Started communication log.
      1 file changed, 5 insertions(+)
      create mode 100644 index.html
      
      $ git log
      commit 679de772612099c77891d2a3fab12af8db08b651
      Author: Chris <[email protected]>
      Date:   Wed Apr 5 10:55:56 2021 -0500
      
         Started communication log.
      
  6. Use the command git branch to check the name for the default branch. If necessary, change the name to main.

    $ git branch
    * default_name
    
    $ git branch -m default_name main.
    

    GitHub uses main for its default branch. To make things easier, you should always try to match your local and remote branch names.

Great! You've got your project going locally. The next step is to push it up to GitHub.

22.7.3.2. Step 2: Push Your Repository To GitHub

Control and Pilot: Complete steps 1 - 5 on your separate devices and GitHub accounts.

  1. Go to your GitHub profile in a web browser. Click on the "+" button to add a new repository (called a repo for short).

    The New Repository link in the dropdown menu at top right on GitHub.

    The New Repository link is in the dropdown menu at top right on GitHub.

  2. On the next page, fill in the Name and Description fields. Also, uncheck the Initialize this repository with a README option, then click Create Repository.

    Creating a new repository in GitHub by filling out the form.

    Create a new repository in GitHub.

    Note

    If you initialize with a README, Git will refuse to merge the remote repo with your local one. There are ways around this, but it's faster and easier to just create an empty repo on GitHub.

  3. After clicking, you should see something similar to:

    The page you see after creating an empty repository, with several options.

    Connecting to a repository in GitHub.

  4. Now go back to your terminal and copy/paste the commands shown in the GitHub instructions. These should be very similar to:

    $ git remote add origin https://github.com/your-username/communication-log.git
    $ git branch -M main
    $ git push -u origin main
    

    Note

    The first time you push up to GitHub, you will be prompted to enter your account username and personal access token. Do this.

    You will then see a large amount of output that you can safely ignore. The final few lines will confirm a successful push. They will look something like this:

    To github.com:your-username/communication-log.git
       c7f97814..54993de3  main -> main
    

    Warning

    Unless you've set up an SSH key with GitHub, make sure you've selected the HTTPS option in the Quick Setup. If you're not sure whether you have an SSH key, you probably don't.

  5. Confirm that GitHub has the same version as your local project. Click around and see what is there. You can view all your code through GitHub's web interface. The files and code you see in your browser should match what you have in Visual Studio Code!

    A repository with one commit in GitHub

    A repository with one commit in GitHub.

22.7.4. Git the Teamwork Started!

You've successfully created a new GitHub repository and pushed content to it. Now it's time for you and your partner to start collaborating on the same repo.

For the remaining sections of this studio, keep an eye on the Control and Pilot role tags. Make sure that you both perform your tasks in the recommended order. Mixing things up won't destroy the universe, but it will make finishing the studio more complicated.

Even when it is not your turn to complete a task, read and observe what your partner is doing. The steps here mimic a real-world collaborative Git workflow.

22.7.4.1. Step 3: Add A Collaborator

Control, the first step is yours. In order for Pilot to make changes to your GitHub repository, you must invite them to collaborate.

  1. Control: In your web browser, go to your communication-log repo. Click the Settings button then select the Manage Access option.

    Click "Settings" and "Manage Access" to let other users modify the repo.

    Manage access to your repo.

  2. Control: Click on the green Invite a collaborator button. Enter your partner's GitHub username and click Add to repository.

    Enter a GitHub username, then click the Add button.

    Choose who else can modify your GitHub repo.

  3. Pilot: You should receive an email invitation to join this repository. View and accept the invitation.

Note

Pilot: If you don't see the email, check your Spam folder. If you still don't have the email, login to your GitHub account. Visit the URL for Control's copy of the repo. You should see an invite notification at the top of the page.

22.7.4.2. Step 4: Clone Project from GitHub

Warning

Pilot, did you and your partner give different names to your communication-log repositories?

If not, take a moment to find your local communication-log folder on your machine. RENAME IT!

  1. Pilot: Go to Control's GitHub profile and find their communication-log repo. Click on the green Code button. Select the HTTPS option and copy the URL to your clipboard.

    The Code button is on the right-hand side of a project's main page.

    Cloning a repository in GitHub

  2. Pilot: In your terminal, navigate back to your development folder and clone Control's repo. You should be OUTSIDE of any other Git repositories.

    The clone command looks something like this:

    $ git clone https://github.com/username/communication-log.git
    

    Replace the URL with the address you copied from GitHub.

  3. Pilot: You should now have a copy of Control's project on your machine.

22.7.5. Git Talking

Whew! That was quite the setup experience. Now you're ready to dive into the main part of the assignment.

On to Studio Part 2!