# Developer Setup

## Set up the Python virtual environment

First, create a Python virtual environment with Python version >= 3.8 and activate it.

Using [Virtualenv](https://docs.python.org/3/library/venv.html#creating-virtual-environments):

    # Create a virtual environment.
    # Only run this the first time.
    python3 -m pip install virtualenv
    python3 -m virtualenv -p python3 venv

    # Activate the virtual environment.
    source venv/bin/activate

Using [Anaconda](https://conda.io/projects/conda/en/latest/user-guide/tasks/manage-environments.html):

    # Create a virtual environment.
    # Only run this the first time.
    conda create -n crfm-helm python=3.8 pip

    # Activate the virtual environment.
    conda activate crfm-helm

## Install dependencies

To install any dependencies (creates into `venv`):

    ./pre-commit.sh

If you get the following error during installation, please delete the `venv` folder and re-run the above command:

    Installing build dependencies ... error
    error: subprocess-exited-with-error

Optionally, install git commit hooks:

    pre-commit install

## Run tests

First, follow the earlier instructions to activate the virtual environment.

To run all unit tests:

    python -m pytest

Append `-vv` to output the full diff and results:

    python -m pytest -vv

To run a specific file, simply specify the path:

    python -m pytest <path/to/file> -vv
