cockpit/bots/HACKING.md

1.5 KiB

Hacking on the Cockpit Bots

These are automated bots and testing that works on the Cockpit project. This includes updating operating system images, bringing in changes from other projects, releasing Cockpit and more.

Environment for the bots

The bots work in containers that are built in the cockpituous repository. New dependencies should be added there in the tests/Dockerfile file in that repository.

Invoking the bots

  1. The containers in the cockpitous repository invoke the .tasks file at root of this repository.
  2. The .tasks file prints out a list of possible tasks on standard out.
  3. The printed tasks are sorted in alphabetical reverse order, and one of the first items in the list is executed.

The bots themselves

Most bots are python scripts. They live in this bots/ directory. Shared code is in the bots/tasks directory.

Bots filing issues

Many bots file or work with issues in GitHub repository. We can use issues to tell bots what to do. Often certan bots will just file issues for tasks that are outstanding. And in many cases other bots will then perform those tasks.

These bots are listed in the bots/issue-scan file. They are written using the bots/tasks/__init__.py code, and you can see bots/example-task for an example of one.

Bots printing output

The bot output is posted using the cockpitous sink code. See that link for how it works.