Skip to content

Setting up

In this section, you will set up everything you need to complete the tutorial.

Prerequisites🔗

You should have a GitHub personal account. See the Signing up for a new GitHub account page in the GitHub docs.

Create a new repository🔗

In this section, you will create a new repository from a template. The new repository will live within your personal account; the template lives within the opensafely organization.

  1. Visit https://github.com/opensafely/ehrql-tutorial

  2. Click Use this template

    A screenshot of GitHub's user interface, highlighting "Use this template"

  3. Click Create a new repository

  4. Name the new repository ehrql-tutorial

    A screenshot of GitHub's user interface, highlighting the repository name

  5. Click Create repository

The new repository will live within your personal account.

Create a codespace🔗

In this section, you will create a codespace for working with the ehrql-tutorial repository. A codespace is a development environment that's hosted in the cloud.

  1. Click < > Code

    A screenshot of GitHub's user interface, highlighting "< > Code"

  2. Click Codespaces

  3. Click Create codespace on main

The codespace will open in a new tab.

Run an OpenSAFELY command🔗

In this section, you will run an OpenSAFELY command to test that the codespace is working correctly.

Towards the bottom of the codespace, you will see the terminal.

The terminal

The terminal allows you to interact with programs, such as ehrQL, that have command line interfaces. Whilst terminal and shell are often used synonymously, a shell runs within a terminal.

You may have used a shell before: Git Bash, for example, bundles Git with the Bash shell for the Windows operating system. The codespace's default shell is also the Bash shell, so if you've used Git Bash before, then you'll find the codespace's default shell familiar.

In the terminal, type:

opensafely exec ehrql:v0 --version

And press Enter.

A screenshot of VS Code, showing the terminal

The codespace is working correctly.

The anatomy of an OpenSAFELY command

What do the parts of the OpenSAFELY command opensafely exec ehrql:v0 --version do?

  • opensafely exec executes an OpenSAFELY action outside the project pipeline
  • ehrql is the OpenSAFELY action to execute
  • v0 is the major version of the ehrQL action
  • --version instructs the ehrQL action to display its full version