On this page:
2.1 Prerequisites
2.1.1 Install Racket
2.1.2 Install Docker
2.2 Download Congame and Conscript
2.3 Install the packages
2.4 Build the Docker container
2.5 Normal use:   starting, stopping, and logging in
2.5.1 Logging in
2.5.1.1 Logging in anonymously
2.6 Updating the software
8.18

2 Installing, Running, and Updating🔗

Below are step-by-step instructions for installing Congame and Conscript on your personal computer, so you can develop and test studies.

These instructions don’t cover the steps needed to run your studies on a server so others can participate; for that, see Installing and Setting up Congame servers.

Conscript is not a distinct application. Rather, it’s a set of software packages that run on top of the Racket programming language environment.

2.1 Prerequisites🔗

Congame/Conscript have not yet been tested on Windows.

You’ll need a computer running Linux, Mac OS, or Windows.

Ensure Git is installed.

Install Git Large File Storage (Git LFS): follow these installation instructions for your operating system.

Git LFS (Large File Storage) is an extension for Git that manages large files efficiently by storing them separately and replacing them with lightweight pointers in the repository. Congame uses Git LFS to manage MP3 and PNG files included as part of certain example studies.

2.1.1 Install Racket🔗

Download and install Racket for your OS. This will also install DrRacket: The Racket Programming Environment.

Once Racket is installed, update your PATH environment variable to include the directories that contain Racket executables. That way, when you issue common Racket commands, your shell will be able to find those executables.

  • The simplest way to do this: open DrRacket, then click the Help menu → Configure Command Line for Racket.

  • Or, if you are using Linux or Mac OS, you may prefer to edit the Bash/ZSH profile config file in your home directory.

To check that Racket and your PATH are set up properly, open a terminal and type this command:

> racket -v

Welcome to Racket v8.18 [cs].

 

If everything went according to design, you should see the output as shown above.

2.1.2 Install Docker🔗

To test your studies locally, you’ll need Docker installed. Use the link for your OS below:

Follow the instructions linked above to install and run Docker. On first run, the app may prompt you to create a Docker “account”, but you can safely skip this step if you wish.

2.2 Download Congame and Conscript🔗

Using your Git client, clone the GitHub repository to your computer — somewhere permanent and easy to find.

Using the CLI, you would do this:

> git clone https://github.com/MarcKaufmann/congame

If you get an error at this point, ensure you have Git LFS installed (see Prerequisites above).

This will place the files in a subfolder of the current directory, named "congame".

2.3 Install the packages🔗

Now the Congame/Conscript packages need to be installed into Racket.

In a terminal, cd into the main "congame" folder and run this command:

Note the trailing slashes! These tell raco pkg to use these local folders as the package source, rather than looking for the packages on the main package catalog.

> raco pkg install congame-core/ congame-web/ congame-cli/ conscript/ congame-doc/

If prompted Would you like to install these dependencies? [Y/n/a/c/?], answer a to install all required dependencies.

2.4 Build the Docker container🔗

The Congame Docker container is a comparatively simple way to run an entire Congame server on your computer, so you can test your studies before uploading them to a “real” server accessible by other participants.

First, make sure the Docker desktop app is installed and running.

The docker compose terminal commands won’t work unless the Docker app is running.

Make sure you’re on a strong, stable internet connection.

In a terminal, run this command within the main "congame" folder:

> docker compose up

This command will take 10–15 minutes to complete. This is still quite a bit faster than it would take most people to install, configure and run a web server and a database server, prepare the databases, and configure the web application. Automation is a beautiful thing.

When the command completes, a Congame server will be running on localhost:5100. You can stop it by typing CTRLC in the same terminal window, or by pressing the stop ⏹️ button for the congame container in the Docker desktop app.

2.5 Normal use: starting, stopping, and logging in🔗

From this point, when you need to test your studies locally, simply open the Docker desktop app and press the play ▶️ button for the congame container. This will start the Congame server, at which point you should be able to browse to http://localhost:5100 in your browser to see the Congame home page.

If you prefer the command line, you can enter docker compose up from the main "congame" folder to start the Congame server, and (when finished) press CTRLC in the same terminal window to stop it. You’ll still need the Docker desktop app runnning in the background, however.

When finished, you can stop the Congame server by pressing the stop ⏹️ button for the congame container in the Docker desktop app.

2.5.1 Logging in🔗

To log in as the server admin, use the built-in user admin@congame.local with password admin.

2.5.1.1 Logging in anonymously🔗

Sometimes you need to log in as an anonymous participant in order to test a study (for example, a study that coordinates results between participants).

Here’s how (assuming you’ve already uploaded a study and created at least one instance for it):

  1. Open a new incognito browser window (or use a different browser than the one you used to log in as admin).

    • Chrome: Click the menu icon (three dots) → Select New incognito window

    • Firefox: Click the menu icon (three lines) → Select New Private Window

    • Safari: Click File menu → New Private Window

    • Edge: Click the menu icon (three dots) → New InPrivate window

  2. In the new browser window, open http://localhost:5100/_anon-login/[STUDY_INSTANCE] — replacing the last part with the instance (or “slug”) of your study.

    • You can find your study’s “slug” on the server by navigating to Admin → click your study → click your study instance. The top of the study instance page will show the study Slug.

2.6 Updating the software🔗

To update to a new version of Congame and Conscript:

  1. Ensure your local Congame container isn’t running.

  2. Update your local copy of the source code: go to the main "congame" folder and run these commands:

    > git pull

    > raco pkg update congame-core/ congame-web/ congame-cli/ conscript/ congame-doc/

  3. Ensure the Docker desktop app is open and running on your computer, and run these additional commands in the terminal:

    > docker compose pull

    > docker compose build

    This will take much less time than the initial Docker setup.