Skip to content

Files

Latest commit

 

History

History
832 lines (500 loc) · 42.1 KB

GETTING_STARTED.md

File metadata and controls

832 lines (500 loc) · 42.1 KB

Getting started on contributing to Docs CSC using a local development server

The procedure described in this file aims to set up the necessary tools on Windows without the need for a system administrator account. However, the simple Git workflow example that follows the Windows-specific instructions doesn't make any particular assumptions on the operating system used. The two alternative paths for command-line and graphical interfaces are marked Option A – CLI and Option B – GUI, respectively. The GUI path should work with only minor deviation on a Mac.

Important

While these instructions are meant to provide a way for installing everything as user installations, i.e. without touching any system files or the like, please consult your local IT support first, for there may be a preferred way of installing some or all of the following software. Some of it may even come pre-installed on your machine.

Workflow

Set up a development environment

This only needs to be done once:

  1. Install the tools
  2. Clone the repository
  3. Install the dependencies

Working on your contribution

The main workflow once everything is installed:

  1. Start a local development server
  2. Create a branch for your work
  3. Stage the changes you've made
  4. Commit the staged changes
  5. Push the commits to the remote repository
  6. Open a pull request
  7. Check the test results

If something goes wrong

Here's a relevant xkcd:

relevant xkcd

The part about memorizing some shell commands is what this tutorial is about (Option A – CLI, at least). If you run into a problem with Git, you really can just

  1. copy the files you've worked on into some other folder (git status to see which files, or just copy everything)
  2. delete the repository folder
  3. clone the repository anew and
  4. copy your work from the other folder into the newly cloned folder

Remember to think before doing something destructive like deleting (or "restoring" unstaged changes). Git can't help you recover anything it doesn't know about and 'letting Git know about stuff' is basically what 'using Git' means.

Setting up a development environment — Step 1: Installing the tools

Visual Studio Code (VS Code)

This is only necessary for Option B – GUI, but may also be used with Option A – CLI.

Note

  • For "Free/Libre Open Source Software Binaries of VS Code" with telemetry disabled, have a look at VS Codium.
  • For information on telemetry data collection in Visual Studio Code, please see Visual Studio Code Telemetry.

Tasks

VS Code Tasks provide a way to run the Option A – CLI commands by using a graphical menu. Tasks for e.g. creating/updating the Conda environment or starting the development server have been pre-defined in the VS Code workspace (available after cloning the repository).

Using Tasks (click to expand)

Tasks can be found in VS Code (there are multiple ways)

  • by selecting Terminal -> Run task... from the menu bar.

  • or from Quick Open, accessed by either

    • using the keyboard shortcut Ctrl+P
    • selecting Go -> Go to file... from the menu bar
    • or by clicking the search field up top if the appropriate title bar style is enabled

    and typing "task" followed by a space

VS Code Tasks

Installation

Installing Visual Studio Code on Windows (click to expand)
  1. (Check if already installed or if another method is preferred in your organization)

  2. Download the 'User Installer" from the Download page

  3. Once the download has completed, click the downloaded executable file on the browser's downloaded files list (there might be a warning about running the file, just proceed). Alternatively, open the File Explorer, navigate to Downloads and double click on the downloaded executable to launch the installer.

  4. Advance the installer through the following steps:

    • License Agreement
    • Select Additional Tasks
      • Pick whatever you like, leave as-is if unsure.

    Click "Install" and after the installation has completed, if you leave "Launch Visual Studio Code" checked when clicking "Finish", VS Code will be launched.

Extensions (optional)

The Docs repository also comes with some pre-defined Workspace Settings for VS Code. Some of these settings are for configuring optional extensions for VS Code. If you feel that the extensions are not relevant for your use-case, feel free to skip the installations. In any case, you can do it later.

Extension: YAML

YAML at Visual Studio Marketplace

Material for MkDocs provides a YAML schema for validation and auto-complete in mkdocs.yml. This could come in handy if you intend to e.g. edit the Docs CSC left-hand navigation menu. To install the YAML extension,

  1. Select View -> Extensions from the menu bar or click on Extensions icon in the activity bar to the left of the side bar.
  2. Search for "yaml".
  3. In the list of search results, click on the little "Install" button next to the YAML extension that has Red Hat (might be redhat in VS Codium) as its publisher.
Extension: Better Jinja

Better Jinja at Visual Studio Marketplace

If you intend to edit or define some Jinja templates, the extension Better Jinja provides syntax highlighting and code snippets. To install it,

  1. Select View -> Extensions from the menu bar or click on Extensions icon in the activity bar to the left of the side bar.
  2. Search for "jinja".
  3. In the list of search results, click on the little "Install" button next to the Better Jinja extension.

Conda

A Python program called MkDocs is used to generate the Docs CSC website from documentation files written in a markup language called Markdown. To run a local development server for an instant preview of your work, MkDocs and all the software it depends on—all the way to Python itself—needs to be available on your computer. This is conveniently accomplished with a package and environment management system called Conda.

Installation

Installation instructions are provided for Windows, macOS and Linux here.

Installing Conda on Windows (click to expand)
  1. Download a minimal installer for Conda, called Miniconda, from docs.conda.io/projects/miniconda/en/latest/ by clicking the hyperlink "Miniconda3 Windows 64-bit".

    Latest Miniconda installer links

  2. Once the download has completed, click the downloaded executable file on the browser's downloaded files list (there might be a warning about running the file, just proceed). Alternatively, open the File Explorer, navigate to Downloads and double click on the downloaded executable to launch the installer.

    A security warning dialog will most likely pop up (if not, just proceed with the installation) asking for confirmation on running the file. Confirm that the digital signature of the file is OK on the Digital Signature Details opened by clicking the publisher name on the warning dialog.

    Digital Signature Details

    Then, only if so, click "Run" to start the installer (the version number py_something.something will look different to what's pictured here).

    Miniconda3 py38_23.3.1-0 (64-bit) Setup

  3. Advance the installer through the following steps:

    • License Agreement
    • Select Installation Type
      • Select "Just Me"
    • Choose Install Location
      • Install to C:\Users\<your username>\AppData\Local\miniconda3 (should be filled in by default).
    • Advanced Installation Options
      • Leave "Create start menu shortcuts (supported packages only)".
      • Do not check "Add Miniconda3 to my PATH environment variable".
      • If you have Python installed through some other means and would like to keep that as the default on your system, uncheck "Register Miniconda3 as my default Python 3.xx".
      • Check "Clear the package cache upon completion".

    Click "Install" and, after it's completed, click "Next". Then, unless you'd like to have the corresponding web pages opened for you (this and this, respectively), uncheck "Getting started with Conda" and "Welcome to Anaconda" before clicking "Finish".

Git

In order to "clone" the Docs CSC repository from (and later, to "push" your work back to) GitHub onto your computer, a tool called Git is needed. As an alternative to the command-line tool, GitHub provides their own graphical program called GitHub Desktop.

Documentation

Documentation on Git, with a reference manual, videos and an external links section is available at www.git-scm.com/doc. The Git commands introduced in this tutorial come with a link to the corresponding page of the reference manual.

Option B – GUI: GitHub Desktop documentation

Option A – CLI: Git from the command-line (click to expand)

Git for Windows

For Windows, there exists a port of Git called Git for Windows.

Installation
  1. Download the latest version of Git for Windows from gitforwindows.org by clicking the large button labeled "Download" on the front page.

    gitforwindows.org

  2. Once the download has completed, navigate to Downloads using the File Explorer. Double click on the downloaded executable, again (if the warning pops up) confirming that the digital signature is OK, and click "Run".

    Git 2.40.1 Setup

  3. Advance the installer through the following steps:

    • Information
    • Select Destination Location
      • Install to C:\Users\<your username>\AppData\Local\Programs\Git (should be filled in by default).
    • Select Components
      • No need to change anything.
    • Select Start Menu Folder
      • You can leave it as Git.
    • Choosing the default editor used by Git
      • If unsure, you can select "Use Notepad as Git's default editor" (don't accidentally select "Notepad++"). In any case, you can change it later.
    • Adjusting the name of the initial branch in new repositories
      • No need to change this.
    • Adjusting your PATH environment
      • Select "Use Git from Git Bash only".
    • Choosing the SSH executable
      • Select "Use bundled OpenSSH".
    • Choosing HTTPS transport backend
      • Select "Use the OpenSSL library".
    • Configuring the line ending conversions
      • Select "Checkout Windows-style, commit Unix-style line endings".
    • Configuring the terminal emulator to use with Git Bash
      • Select "Use MinTTY (the default terminal of MSYS2)".
    • Choose the default behaviour of `git pull`
      • Default is fine.
    • Choose a credential helper
      • Select "None". We're going to set up SSH keys in a moment.
    • Configuring extra options
      • No changes needed.
    • Configuring experimental options
      • Leave everything unchecked.

    Click "Install" and after the installation has completed, uncheck "View Release Notes", then click "Finish".

Git Bash

You can find a shortcut for Git Bash in the Start menu. If you don't see it under Recently added, simply start typing git bash and sooner or later Windows will find it for you.

Git Bash

Before we proceed further with setting up the tools, there are just a few things to keep in mind when starting to learn the command-line after using only graphical interfaces.

Commands

In addition to the git command, just to illustrate some basic principles without going too much into detail, here are a few essential commands. Feel free to try them in Git Bash.

  • pwd

    • Print working directory: Shows you your current location (the folder AKA directory) in the file system.
  • ls

    • List directory contents: View the contents of the current location.

Usually, the behaviour of a command can be altered in some way by giving it options. One useful option that almost all commands have is --help:

  • ls --help
    • Let ls itself tell you how to use it.

As you can see from the output of ls --help, some options have a short and a long form. Long form is prefixed with -- and short with -. When giving multiple options in one command, short form options can be grouped together. For example, ls --all --human-readable --reverse can be shortened to ls -ahr (though, short form is not always the first letter of long, contrary to this example). Some options also take arguments: ls --sort=size (or ls --sort size).

Many commands need operands to be useful, or to even do anything at all. Some commands will just tell you how to use them (as if given the --help option) if no operands are given. The command

  • cd
    • Change directory: Navigate to another location in the file system.

does work without operands (it navigates to the home directory), but it is commonly used with a path as its operand. Assuming the current location contains a directory named, say "example", this directory could then be navigated to using cd example/. Some locations can even be accessed with a shortcut:

  • .

    • The current directory.
  • ..

    • The parent directory, i.e. the directory that contains the current directory.
  • ~

    • The (current user's) home directory.

As we'll see later, these aren't only used with cd, as in cd .. or cd ~.

Tab completion

If you've never used a command-line interface before, having to type everything letter-to-letter might seem tedious compared to clicking or tapping on things in a graphical user interface. Fortunately, something called tab completion can be used to conveniently fill in commands, file or folder names, Git branch names and the like. There are differences on how it works exactly between different shells (like Bash, PowerShell, cmd and so on), but all you need to remember is, as the name of the concept suggests, the tabulator AKA tab key, usually marked on the keyboard with the word 'tab' or the symbol ↹.

This incredibly simple yet powerful concept is best explained by example, and in an article on the subject, Wikipedia provides one (they call it "Command-line completion" and you can skip straight to the example).

Command history

In addition to tab completion, the command history is among one of the most useful features of shells like Bash. Again, simple yet powerful:

  • Browse through previously entered commands with the up and down arrow keys. (The trick is to insist on finding some command you remember using ages ago, when it would clearly be quicker to just type it again!)
  • Search for matches in the command history with Ctrl+R. (Ctrl+R again to browse through matches.)

Many times you'll want to execute a command that is almost the same as a command in your history. You can, using the above methods, browse to the command in question and use it as a template for your new command.

  • Move the cursor with the left and right arrow keys. (As you would in a graphical text editor.)
  • Holding down Ctrl will move the cursor over a whole word instead of only a single character. (This also works with the Delete key, but not Backspace.)
  • Ctrl+A moves the cursor to the beginning, Ctrl+E to the end.
Clipboard copy/paste and keyboard shortcuts

If you're accustomed to using the clipboard with the keyboard shortcuts Ctrl+C and Ctrl+V, remember that these won't work in Git Bash. The corresponding shortcuts in Git Bash are (by default) Ctrl+Insert for copy and Shift+Insert for paste. If you accidentally input Ctrl+V in Git Bash with the intention of pasting text from the clipboard, you should hit the backspace key a couple of times before using the correct shortcut! Ctrl+C, on the other hand, will send a keyboard interrupt signal that is often used to stop a running program, for example, the MkDocs development server. You can access the context menu for clipboard copy and paste by clicking on the terminal with the right mouse button.

You can change the default behaviour by right-clicking on the title bar, selecting Options... and then Mouse in the left pane. There you can, e.g., set "Paste" to occur upon right-clicking on the terminal. Note that selecting any text in the terminal automatically copies it to the clipboard (this behaviour can be changed under Selection), so you do not actually need to rely on keyboard shortcuts or the context menu for copying/pasting.

Git for Windows - mouse settings

Also, while some websites might show commands or snippets of code/script in a box with a button for copying the snippet onto the clipboard, the result might not always be what the author of the tutorial intended. A snippet with multiple lines can get copied as only a single long line, or a command that is intended to be edited first can get executed straight away when pasting. To avoid this, instead of clicking the button, it is recommended to select (highlight) the text and copy it using either Ctrl+C, the context menu accessed by right-clicking, or even by selecting Edit -> Copy from the web browser's menu bar.

Keyboard shortcuts in general may produce unexpected results for users accustomed to graphical interfaces. Similarly to how Shift modifies the behaviour of the keys to produce uppercase characters, Ctrl has been used as a modifier key for sending control characters to computer terminals in the past. You have just installed a terminal emulator called MinTTY to use with Git Bash. In the early days of computer technology, there was a physical terminal to interact with the computer.

Setting up SSH authentication with GitHub
Storing your passphrase in KeePass 2

If you don't yet have a database for KeePass, you can create one by selecting File -> New... and following the instructions there. To add a passphrase into your database, select Entry -> Add entry... and input a "Title" (no need to input anything in the "User name" field). The "Password" field will hold your passphrase that KeePass has already automatically generated for you.

If you wish, you can try KeePass 2's password generator–accessed by clicking the button next to the "Repeat" field and selecting Open Password Generator...–for more options. Just remember to use at least 20 characters. The 128 bits of entropy recommended at SSH.com isn't quite reached with the default setting (20 chars of A-Z or a-z), but it will certainly be over the 80 bits of entropy they state as the minimum. As the point of using a password manager like KeePass 2 is not having to remember anything but the master password, why not go for something like the built-in profile "Hex Key - 256-Bit"?

KeePass 2 Add Entry

To make it even easier to input the passphrase on Git Bash, you can edit the auto-type sequence on the Auto-type tab: select "Override default sequence" and remove the {USERNAME}{TAB} part, leaving only {PASSWORD}{ENTER} as the sequence.

KeePass 2 Auto-type

After clicking "OK", the entry is added to your database. Remember to select File -> Save to save the changes to disk.

It is important to have a backup copy of the database file (.kdbx)! The recommendation is to have one backup copy on a separate device (such as an external hard drive) and another off-premises (like a cloud file storage). Although, if the only thing you have in the database is the passphrase and something goes wrong, you can just start over (see the note at Adding an SSH key to your GitHub account).

Generating an SSH key

We want to use the default location for SSH keys (/c/Users/<your username>/.ssh, AKA ~/.ssh), but it doesn't exist yet. We'll create it with the command

mkdir ~/.ssh

Now, to generate an SSH key, run the command

ssh-keygen -t ed25519

and, when prompted for a "file in which to save the key", press Enter without inputting anything to use the default location. You'll now be prompted to enter a passphrase. Open KeePass 2 (it is important to make sure Git Bash was the active window right before KeePass, i.e. pressing Alt+Tab would switch to Git Bash) and highlight the entry holding the generated passphrase from before by clicking on it, select Entry -> Perform Auto-type and KeePass will automatically switch to the previously active window, hopefully Git Bash, then "auto-type" the passphrase followed by the Enter key. You're then prompted to repeat the passphrase, so switch straight back to KeePass and have it perform the auto-type again.

If everything worked, ssh-keygen will tell you (along with some other things) that

Your identification has been saved in /c/Users/<your username>/.ssh/id_ed25519
Your public key has been saved in /c/Users/<your username>/.ssh/id_ed25519.pub

of which the latter contains your public key we'll be adding to your GitHub account momentarily. The former contains the private key which should be kept secret at all times.

Adding an SSH key to your GitHub account

For instructions on how to add the generated key—for authentication that is—to your GitHub account, see instructions at GitHub Docs. Note that the instructions use the convention of prefixing commands with a $ to denote a prompt. That is to be left out when copy-pasting the command since it's already there in Git Bash, waiting for your command.

We'll be testing the SSH connection to GitHub after we set up something called ssh-agent.

Note that if you lose your private key or the passphrase, you can just remove the public key from your GitHub account and start over by generating a new key pair (and a passphrase).

Setting up ssh-agent and Conda

Next, we'll set up ssh-agent so that you only need to input your passphrase when you open Git Bash. ssh-agent will then hold onto your passphrase for you for as long as it (ssh-agent.exe) is running. In addition, we need to set up Conda by running the conda.sh script from Conda's installation folder. If you didn't install Conda into the default folder, you need to edit the corresponding line. The following lines should go into a .profile file in the home folder. Now, run the command

notepad ~/.profile

clicking "Yes" if Notepad asks to create the file. Then, copy-paste the following lines (the part about auto-launching has been copied from GitHub's tutorial) into Notepad and save the file:

# Run Conda script

. ~/AppData/Local/miniconda3/etc/profile.d/conda.sh


# Auto-launching ssh-agent on Git for Windows

env=~/.ssh/agent.env

agent_load_env () { test -f "$env" && . "$env" >| /dev/null ; }

agent_start () {
    (umask 077; ssh-agent >| "$env")
    . "$env" >| /dev/null ; }

agent_load_env

# agent_run_state: 0=agent running w/ key; 1=agent w/o key; 2=agent not running
agent_run_state=$(ssh-add -l >| /dev/null 2>&1; echo $?)

if [ ! "$SSH_AUTH_SOCK" ] || [ $agent_run_state = 2 ]; then
    agent_start
    ssh-add
elif [ "$SSH_AUTH_SOCK" ] && [ $agent_run_state = 1 ]; then
    ssh-add
fi

unset env

It is a good practice to end text files with an empty line. Close Notepad to return to the prompt. You should now either "source" the file with the command

source ~/.profile

or close and then reopen Git Bash. ssh-agent will prompt for the passphrase, so have KeePass perform the auto-type again, just as before. If it worked, ssh-agent will inform you that

Identity added: /c/Users/<your username>/.ssh/id_ed25519 (<your username>@<your computer>)

and will now remember the passphrase so you don't have to keep getting it from KeePass every time you connect to GitHub with SSH while using Git. If you want to make ssh-agent forget your passphrase, you can simply end the task (ssh-agent.exe) in Task Manager.

You should now confirm that Conda is working with the command

conda --version

that should output the version number. To test the SSH connection, follow the instructions on another GitHub tutorial.

Associating your commits with your GitHub account

Follow the instructions at GitHub Docs for

Option B – GUI: Graphical interface with GitHub Desktop (click to expand)

GitHub Desktop

[!TIP] Even though you want to use GitHub Desktop, it might prove beneficial to also have an installation of Git at hand (on Windows, that would be Git for Windows, introduced above). That way you can use the Git integration in VS Code and, when you ask for help and get offered a solution as an elaborate Git command, you have something to run it with. The section is quite long, but you only need to install Git for Windows and maybe set your email/username. You can skip everything else. It's certainly fine to proceed with GitHub Desktop only. You can always install Git later if you really need it, but just so you know: GitHub recommends using the included version of Git only through the GitHub Desktop application.

Installation

Instructions for Windows and Mac are provided here and it is as simple as

  1. Download an installer by visiting desktop.github.com and clicking on "Download for Windows (64bit)".
  2. Once the download has completed, click the downloaded executable file on the browser's downloaded files list (there might be a warning about running the file, just proceed). Alternatively, open the File Explorer, navigate to Downloads and double click on the downloaded executable to launch the installer.
  3. GitHub Desktop should start automatically when the installation is complete.
Signing in

Follow the instructions for Authenticating to GitHub in GitHub Desktop (the regular, non-Enterprise authentication).

External editor

Configuring a default editor in GitHub Desktop

If you're using, for example VS Code (or Codium), you can set it as the default editor. This allows you to quickly open the repository with VS Code by clicking a "Open in Visual Studio Code" button in the Changes view of GitHub Desktop. There should be a link to the appropriate section for Options right under the text "Open the repository in your external editor" in the Changes view (if not, select File -> Options... and then Integrations from the sidebar).

Obtaining a local copy, i.e. cloning the repository

Option A – CLI (click to expand)

Clone the Docs repository (if not cloned yet) with git-clone:

git clone git@github.com:CSCfi/csc-user-guide.git

Navigate to the folder (remember tab completion):

cd csc-user-guide/
Option B – GUI (click to expand)

Instructions at GitHub Docs: Cloning and forking repositories from GitHub Desktop

In GitHub Desktop,

  1. Select File -> Clone repository... from the menu bar.
  2. Start typing CSCfi/csc-user-guide (or just csc-user-guide) into the filter field.
  3. When it appears on the list, click on CSCfi/csc-user-guide to activate the entry.
  4. Click Clone to start.

Now you can select the Repository -> Show in Explorer menu entry to browse the cloned repository files on your computer. If you set the external editor to VS Code above in External editor, you should see a button titled "Open in Visual Studio Code" in the Changes view. Alternatively, you can open the folder by selecting File -> Open Folder... in VS Code and looking for the cloned repository folder.

[!TIP] You'll probably want to uncheck "Hide extensions for known file types" (and have File Explorer "Show hidden files, folders and drives" too, while you're at it) from the Folder Options, accessed by clicking the Options button in the View ribbon.

Folder Options

Setting up a development environment — Step 2: Installing the dependencies

Now that you have cloned the repository, we can use the files it contains to prepare a virtual environment and install the needed software dependencies into it.

Creating a virtual Python environment using Conda

Option A – CLI (click to expand)

Create the Conda environment (if not created yet):

conda env create -f development/conda-docs-base-latest.yaml

[!NOTE] If an environment named docs-env already exists—i.e. you are updating it—add the --force flag:

conda env create --force -f development/conda-docs-base-latest.yaml

Activate the environment:

conda activate docs-env

Install the Python requirements with Pip (when starting fresh):

pip install -r requirements.txt

[!NOTE] When updating, you may need to add the --force-reinstall flag:

pip install --force-reinstall -r requirements.txt

The environment can be deactivated with

conda deactivate
Option B – GUI (click to expand)

Using VS Code, creating a virtual Conda environment is as simple as running the task Docs CSC: Create (see Using Tasks under VS Code – Tasks). A terminal panel will open showing you the progress on installing the dependencies. The environment is ready when the terminal instructs you to "press any key to close it", though you can leave it open if you like.

The virtual environment is now ready for installing the Python requirements for Docs CSC. Simply run the task Docs CSC: Install. Both creating the environment and installing the requirements need to be done only when starting fresh or when the dependencies/requirements have been changed, i.e. (for Conda dependencies) a new file named conda-docs-base-something.something.yaml has appeared in the development folder or (for Python requirements) the file requirements.txt has been changed.

Working on your contribution

That's it for setting up! All installations should now be done. Let's see if it'll run! From here on, the CLI and GUI paths shall be intertwined.

The procedure for Option B – GUI can be found in a blockquote like this,

while Option A – CLI will be implicit.

Previewing your changes locally

The main point of this tutorial is to be able to work on the files using the tools you prefer, and that by using a local preview server, you will immediately see your changes when you save a file you've edited. This happens quicker with the --dirtyreload option enabled, but is in any case quicker and more convenient than waiting for the Rahti preview to rebuild a branch.

Option B – GUI: Run the task Docs CSC: Serve

Run the development server (with the Conda environment activated):

mkdocs serve

or

mkdocs serve --dirtyreload

Option B – GUI: The task Docs CSC: Serve, for starting the development server, will ask whether you'd like to include e.g. the --dirtyreload flag.

It will take a moment for MkDocs to build and serve the site. If you wish to shut down the server (even when its building)–perhaps to restart it with --dirtyreload enabled–simply hit Ctrl+C.

Option B – GUI: Click on the terminal panel to activate it before hitting Ctrl+C. You can also click the trashcan icon with the tooltip "Kill Terminal" to shut the server down.

When MkDocs tells you it is serving on an address, you can point a web browser to the address for a preview. The default is 127.0.0.1:8000 AKA localhost:8000.

If you want to leave MkDocs running while continuing to work on the command-line, open a new Git Bash window and again navigate to the cloned folder:

cd csc-user-guide/

Creating a new branch for your work

Option B – GUI: See

Check that you are on the master branch using git-status:

$ git status
On branch master
Your branch is up to date with 'origin/master'.

nothing to commit, working tree clean

and git switch master if this is not the case. You'll be creating a new branch to work on and probably want to branch off of the very latest version of master, so check that your local branches are up to date using git-fetch:

git fetch origin

The line "Your branch is up to date with 'origin/master'" after git status just means that Git isn't aware of any new changes on the remote branch (called origin by default). Now, after fetching, things might have changed:

$ git status
On branch master
Your branch is behind 'origin/master' by 15000 commits, and can be fast-forwarded.
  (use "git pull" to update your local branch)

nothing to commit, working tree clean

Fast-forward the master branch to the latest commit with git-pull:

git pull origin master

Branch off of the latest commit on master using git-switch (replace my-branch-name):

git switch --create my-branch-name

Forgot to make a new branch?

If you forgot to make a new branch before editing some files, and the files you've edited have

  • not been changed by someone else since you last pulled from the remote, you can just fetch, pull and create a new branch.
  • been changed on the remote, Git will not let you pull the changes, since your local changes to the files would be overwritten. You'll need to

    Option B – GUI: See Stashing changes in GitHub Desktop

    • git-stash your changes

      $ git stash
      Saved working directory and index state blahblahblahblahblah
    • then, after pulling, pop your changes from the top of the stash

      $ git stash pop
      Auto-merging docs/your-file.md
      On branch master
      Your branch is up to date with 'origin/master'.
      
      Changes not staged for commit:
      (use "git add <file>..." to update what will be committed)
      (use "git restore <file>..." to discard changes in working directory)
          modified:   docs/your-file.md
      
      no changes added to commit (use "git add" and/or "git commit -a")
      Dropped refs/stash@{0} (77c8f9c7dbab452d84ea8e573edf27954b8bce34)
    • create the new branch

Getting your work back to the repository

Option B – GUI: See Committing and reviewing changes to your project in GitHub Desktop.

Staging your changes

Option B – GUI: See Selecting changes to include in a commit

Selecting specific changes that you want to include in a so called commit is done by staging.

Check which files you've changed, and that you are on the correct branch using git-status:

git status

Check what you changed in the files using git-diff:

git diff

or, for a single file (replace path/to/file):

git diff path/to/file

For example, if you'd have changed the file you are reading right now, you'd see what you changed with

git diff GETIING_STARTED.md

The actual content is under the docs folder, so path/to/file for, say, the Linux basics for CSC tutorial would be docs/support/tutorials/env-guide/index.md.

If the so called diff is long, it will be shown inside something called less. You can move up and down using arrow keys and Page Up / Page Down. Hit Q to quit less and return to the prompt.

Stage the changes you've made using git-add:

git add .

or, just a single file (replace path/to/file):

git add path/to/file

If you staged something you didn't intend to, unstage a file (replace path/to/file) with git-restore:

git restore --staged path/to/file

Be careful with git-restore without the --staged option. It is used to restore unstaged files to how they were before you changed them.

Committing the staged changes

Option B – GUI: See Write a commit message and push your changes

Check which changes you've staged with git-status:

git status

Check what the staged changes were with git-diff:

git diff --staged

Commit the staged changes (replace Why I made these changes, but do include the quotation marks) with git-commit:

git commit -m "Why I made these changes"

or, to write the commit message using the default editor:

git commit

then save the file, exit the editor and Git will read the commit message you typed into the file.

If you forget to give a message with the -m argument, you can enter it when the text editor opens to confirm the commit operation.

Pushing the commits to GitHub

Option B – GUI: See Pushing changes to GitHub from GitHub Desktop

Check what happened to the branch with git-log (replace the 9 in -9 to get more/less commits or remove --oneline to increase verbosity):

git log --oneline -9

Check the latest commit with git-show:

git show HEAD

Again, if the diff is long it'll be shown with less, so move with arrow keys and Page Up / Page Down, then Q to quit.

Push your branch to GitHub (replace my-branch-name) with git-push:

git push origin my-branch-name

Opening a pull request

Instructions for creating a pull request can be found

Checking the status of the tests

Every time a push is made, Travis CI will automatically run the tests defined in the tests folder.

Look for your

Note that local tests don't work in Git Bash without further configuration.