Kelvin has uses a relatively complicated set of runtime services, so you need to configure a bunch of things to start using it.
Firstly, install necessary system packages:
$ apt-get install libsasl2-dev libgraphviz-dev graphviz gcc libxml2-dev libxslt1-dev libffi-dev libz-dev
Secondly, you need to prepare a Python virtual environment and install dependencies of Kelvin, which is
a Django app. The easiest way of doing that is to use uv,
which manages the dependencies of this project. As a first step for working
with the Python code, install uv
using some supported approach, for example:
$ pip install --user uv==0.4.4
Then, use uv
to create a virtual environment and install the necessary dependencies into it:
$ uv sync
Do not forget to activate the virtual environment if you want to work with Python:
$ source .venv/bin/activate
To ensure that the code is formatted correctly and linted, you can install pre-commit hooks:
$ pre-commit install
For building the frontend, you'll need npm
:
$ cd frontend
$ npm ci
# Perform a production build:
$ npm run build
# Perform a development build with live-reload:
$ npm run dev
The frontend build will store JS and CSS files into web/static
.
The web app needs a PostgreSQL database to run. You can either provide it yourself, or use the provided docker-compose.yaml
file (recommended).
As a first step, you should configure an .env
file that contains various environment
variables used to configure Kelvin and also docker-compose
, which can be used to set up Kelvin
runtime services.
$ cp .env.example .env
You can modify the environment variables in the file to your liking.
Then, you can start a PostgreSQL database using docker-compose
:
$ docker-compose up db
Note that docker-compose
will load the DB (and other) configuration options from the .env
file, same as Kelvin, so they should match.
Once you have a working connection to the DB, you should run migrations on it:
(.venv) $ python3 manage.py migrate
Once you built the frontend, installed Python dependencies and configured the database, you can start a local development server using this command:
$ python3 manage.py runserver 8000
And then you can find the web on http://localhost:8000
.
To perform code plagiarism checks or evaluate code submits, you'll also need to deploy Redis and start RQ workers.
You can start Redis using the provided docker-compose.yml
file:
$ docker-compose up redis
Note that the Redis instance does not store data persistently.
You also need to compile the Docker images used for evaluation:
(.venv) $ cd evaluator/images
(.venv) $ python3 build.py
Then you can start a worker with the following command:
(.venv) $ python3 manage.py rqworker default evaluator --with-scheduler