Skip to main content

Setting up a Rucio Developer environment using IntelliJ Ultimate

This tutorial works on Linux, but it was confirmed, in the past, to not work on Windows. Windows support could have improved in later IntelliJ versions. If you manage to make it work, please tell us and update the documentation.

Prerequisites

  • An IntelliJ Ultimate licence is required. The Free versions doesn't have the needed features. Some people may qualify for a free licence. Refer to their website for more information. I assume it's easy to adapt the following tutorial for PyCharm Professional, but I don't have a licence to test it.

  • If not already done, install the official Python plugin by following their official documentation

  • Your local user running IntelliJ must be able to run docker commands without the need for becoming root with sudo/su. Running the following command and re-logining should be enough:

      sudo gpasswd -a $USER docker

Open the rucio project in IntelliJ

Open the existing rucio project in intellij. This should be trivial. However, if you need help with it, refer to the official documentation

Add docker-compose remote interpreters

Once the rucio project opened in IntelliJ, navigate to File/Project Structure and add a new python SDK as shown in the following picture:

Add new Python SDK

In the new window, as shown on the next picture:

  • select Docker Compose in the left menu.
  • in the Configuration Files field, navigate to the ./etc/docker/dev/docker-compose.yaml within the project
  • in the Service field select rucio

Remote interpreter for rucio service

Repeat the operation, but select rucioclient in the Service field.

Now you should have two remote interpreters configured. IntelliJ will start indexing the projects (see progress bar in the bottom right corner). Wait for indexing to finish.

It's important for the default interpreter to be the one with Service = rucioclient. This should be the case if you added them in the order mentioned previously.

Mark the bin and lib folders as Source folders

Open File/Project Structure again and navigate to Project Settings/Modules in the left menu. Mark the bin and lib folders as Source folders. For that, right click on them and select the folder type. As shown in the following screenshot:

Source folders

Start and initialize the docker-compose env

Follow our documentation to manually start the docker-compose environment and initialize the database and storage.

Debugging a daemon or core function

With the docker-compose env up in running, navigate to a test file. For example, open the file lib/tests/test_config.py and refer to the following video for an example how to debug a test:

Debugging the server

The procedure configured until now works very well for developing and testing daemons and core code. However, it doesn't allow to debug the server code. For that, one has to run the server separately.

Add a new Flask server run configuration in the menu Run/Edit Configurations

  • Target type: Module name
  • Target: rucio.web.rest.flaskapi.v1.main
  • Additional options: --cert=/etc/grid-security/hostcert.pem --key=/etc/grid-security/hostkey.pem --host=0.0.0.0 --port=443
  • Environment variables: LC_ALL=en_US.utf-8
  • Use specified interpreter: select the rucio docker-compose remote interpreter.

This will allow to debug the code on server side.