1 Introduction
The Radicle CI broker runs CI for repositories in the local Radicle node. This is the user guide for the CI broker.
The CI broker helps users run validation on changes to their software project, by automating the building and testing of the projects when anything in the repository changes. This is often called "continuous integration".
(Technically, "continuous integration" is the software development practice to merge changes into the main line of development frequently, at least daily, to avoid painful merge conflict resolutions. However, for this guide we say "CI" to mean "when repository changes, perform these actions", which is a more generic, and quite popular definition, if not very purist.)
2 Overview
The Radicle node stores Git repositories and synchronizes them with other Radicle nodes. The CI broker connects to its local node and gets "node events" whenever anything changes in the node. The relevant change for the CI broker is that a Git references ("refs") in a repository have been created, updated, or deleted. For now, these are branches. Later, Radicle and the CI broker will support other references, such as tags.
There are no node events for Git repositories being created or deleted. It's not possible to create a Radicle repository without creating a branch, so just looking at references is enough.
The CI broker looks at the reference changes and refines them into "CI events", which are more suitable for the kind CI use that the CI broker is meant to enable, than "this ref changed", which is quite low level.
3 CI events
The CI broker currently supports a small set of CI events. There will be more.
In the tables below, the fields have the following meanings:
from_node-- the node from which the event originatedrepo-- the ID of the repository concernedbranch-- the name of the branch created of updatedtip-- the newest commit in the branch or patchold_tip-- the previous newest tip, before the change
3.1 BranchCreated
A branch has been created. This may mean the repository has also been created, but that is not certain.
| Event | fields | field types |
|---|---|---|
BranchCreated | from_node | NodeId |
repo | RepoId | |
branch | RefSting | |
tip | Oid |
3.2 BranchUpdated
A branch has been updated.
| Event | fields | field types |
|---|---|---|
BranchUpdated | from_node | NodeId |
repo | RepoId | |
branch | RefSting | |
tip | Oid | |
old_tip | Oid |
3.3 BranchDeleted
A branch has been deleted.
| Event | fields | field types |
|---|---|---|
BranchDeleted | repo | RepoId |
branch | RefString | |
tip | Oid |
3.4 PatchCreated
A patch has been created.
| Event | fields | field types |
|---|---|---|
PatchCreated | from_node | NodeId |
repo | RepoId | |
patch | PatchId | |
new_tip | Oid |
3.5 PatchUpdated
A patch has been updated.
| Event | fields | field types |
|---|---|---|
PatchUpdated | from_node | NodeId |
repo | RepoId | |
patch | PatchId | |
new_tip | Oid | |
4 Event filters
The CI broker configuration can use the following conditions, and AND/OR/NOT operators to build a filter expression: if the expression evaluates as "true", the event is allowed and will trigger a CI run. Otherwise it is discarded and does not trigger a CI run.
| Condition | Meaning |
|---|---|
Repository | Event refers to a specific repository, identified by ID |
Branch | Event refers to a specific Git branch |
BranchCreated | Branch was created |
BranchUpdated | Branch was updated |
BranchDeleted | Branch was deleted |
Patch | Event refers to a specific patch, identified by ID |
PatchCreated | Patch was created |
PatchUpdated | Patch was updated |
Allow | Change is allowed |
Deny | Changes is not allowed |
Not | Change is allowed is the operand expressions are is false |
And | Change is allowed if all the operands are true |
Or | Change is allows if any of the operands is true |
4.1 Example
The following example is a snippet of YAML for the CI broker
configuration file to match events that refer to the main in the CI
broker repository.
filters:
- !And
- !Repository "rad:zwTxygwuz5LDGBq255RA2CbNGrz8"
- !Branch "main"
The conditions are expressed using the !Foo syntax in YAML. Foo
must be one of the operands from the table above. Simple values are
expressed as doubly quoted strings, and lists of operands are
sub-lists in YAML syntax.