In order to develop the project on Fedora or CentOS Stream you need to install following dependencies.
To build the project on CentOS Stream you need to enable CodeReady Build and EPEL repositories:
sudo dnf install dnf-plugin-config-manager
sudo dnf config-manager --set-enabled crb
sudo dnf install -y epel-release
sudo dnf install \
bzip2 \
clang-tools-extra \
gcc \
gcc-c++ \
git \
golang-github-cpuguy83-md2man \
make \
meson \
systemd-devel \
selinux-policy-devel
markdownlint-cli2 can be used for static analysis of markdown files. Check the installation guide and use the most appropriate way of installation for your setup.
busctl is a systemd tool to introspect and monitor the D-Bus bus. See below some examples using busctl with bluechi service.
Instrospect org.eclipse.bluechi:
# busctl introspect \
org.eclipse.bluechi \
/org/eclipse/bluechi
NAME TYPE SIGNATURE RESULT/VALUE FLAGS
org.eclipse.bluechi.Controller interface - - -
.CreateMonitor method - o -
.DisableMetrics method - - -
.EnableMetrics method - - -
.GetNode method s o -
.ListNodes method - a(sos) -
.ListUnits method - a(sssssssouso) -
.Ping method s s -
.SetLogLevel method s - -
.JobNew signal uo - -
.JobRemoved signal uosss - -
org.freedesktop.DBus.Introspectable interface - - -
.Introspect method - s -
org.freedesktop.DBus.Peer interface - - -
.GetMachineId method - s -
.Ping method - - -
org.freedesktop.DBus.Properties interface - - -
.Get method ss v -
.GetAll method s a{sv} -
.Set method ssv - -
.PropertiesChanged signal sa{sv}as - -
Example calling ListNodes:
export SERVICE="org.eclipse.bluechi"
export OBJECT="/org/eclipse/bluechi"
export INTERFACE="org.eclipse.bluechi.Controller"
export METHOD="ListNodes"
# busctl call \
"${SERVICE}" \
"${OBJECT}" \
"${INTERFACE}" \
"${METHOD}"
a(sos) 3 "control" "/org/eclipse/bluechi/node/control" "online" "node1" "/org/eclipse/bluechi/node/node1" "online" "qm-node1" "/org/eclipse/bluechi/node/qm_2dnode1" "online"
clang-format is used to enforce a uniform code style. The formatting of all source files can be checked via:
# only check for formatting
make check-fmt
# apply formatting to files
make fmt
For the most part, this project follows systemd coding style:
systemd-coding-style. Also, this project borrows
some of the coding conventions from systemd. For example, function names pertaining to D-Bus services look like
bus_service_set_property()
.
clang-tidy is used for static analysis of C source codes. markdownlint-cli2 is used for static analysis of markdown files. flake8 is used for format checking and linting of python code.
The following make targets simplify the usage of the different linting tools:
# using clang-tidy, lint all C source files
make lint-c
# same as lint-c target, but auto-fix errors if possible
make lint-c-fix
# using markdownlint-cli2, lint all markdown files
make lint-markdown
# combines lint-c and lint-markdown
make lint
The project is using meson as its primary build system.
The binaries and other artifacts (such as the man pages) can be built via:
meson setup builddir
meson compile -C builddir
After successfully compiling the binaries, they can be installed into a destination directory (by default
/usr/local/bin
) using:
meson install -C builddir
To install it into builddir/bin
use:
meson install -C builddir --destdir bin
After building, the following binaries are available:
bluechi-controller
: the systemd service controller which is run on the main machine, sending commands to the agents and monitoring the progressbluechi-agent
: the node agent unit which connects with the controller and executes commands on the node machinebluechi-proxy
: an internally used application to resolve cross-node dependenciesbluechictl
: a helper (CLI) program to send an commands to the controller
BlueChi can be built with configurable options as listed in meson_options.txt. The value for those settings can either be changed directly in the file or via
# assuming an initial "meson setup builddir"
meson configure -D<option-name>=<option-value> builddir
Current options include:
with_analyzer
: This option enables the gcc option for static analysiswith_coverage
: This option ensures that BlueChi is built to collect coverage when running a BlueChi binarywith_man_pages
: This option enables building man pages as a part of the project buildwith_selinux
: This option includes building the SELinux policy for BlueChi
Bindings for the D-Bus API of BlueChi
are located in src/bindings. Please refer to the
README.md for more details.
A complete set of typed python bindings for the D-Bus API is auto-generated. On any change to any of the interfaces, these need to be re-generated via
./build-scripts/generate-bindings.sh python
Additional, static code analysis is applied when running the unit tests in CI by
enabling the meson option with_analyzer
:
meson configure -Dwith_analyzer=true builddir
Since the result of the analysis is heavily dependent on the compiler version, flags, etc., its recommended to build and run tests for BlueChi also in the build-base:
# navigate into the bluechi directory
cd bluechi
# run build-base container and mount bluechi directory
podman run -it -v ./:/var/bluechi quay.io/bluechi/build-base:latest
# configure meson to enable code analysis and build the project
meson setup builddir
meson configure -Dwith_analyzer=true builddir
meson compile -C builddir
In some cases, developers might need a debug session with tools like gdb, here an example:
First, make sure meson.build contains debug=true.
Rebuild the BlueChi project with debug symbols included:
bluechi> make clean
bluechi> meson install -C builddir --dest=bin
bluechi> gdb --args ./builddir/bin/usr/local/libexec/bluechi-controller -c /etc/bluechi/controller.conf
Unit tests can be executed using following commands:
meson setup builddir
meson configure -Db_coverage=true builddir # if you want to collect coverage data
meson compile -C builddir
meson test -C builddir
ninja coverage-html -C builddir # if you want to generate coverage report
will produce a coverage report in builddir/meson-logs/coveragereport/index.html
All files related to the integration tests are located in tests and are organized via tmt. How to get started with running and developing integration tests for BlueChi is described in tests/README.
The following sections describe how to run the built application(s) locally on one machine. For this, the assumed setup used is described in the first section.
The project has been build with the following command sequence:
meson setup builddir
meson compile -C builddir
meson install -C builddir --destdir bin
Meson will output the artifacts to ./builddir/bin/usr/local/
. This directory is referred to in the following sections
simply as <builddir>
.
To allow bluechi-controller
and bluechi-agent
to own a name on the local system D-Bus, the provided configuration
files need to be copied (if not already existing):
cp <builddir>/share/dbus-1/system.d/org.eclipse.bluechi.Agent.conf /etc/dbus-1/system.d/
cp <builddir>/share/dbus-1/system.d/org.eclipse.bluechi.conf /etc/dbus-1/system.d/
Note: Make sure to reload the dbus service so these changes take effect: systemctl reload dbus-broker.service
(or
systemctl reload dbus.service
)
The newly built controller can simply be run via ./<builddir>/bin/bluechi-controller
, but it is recommended to use a
specific configuration for development. This file can be passed in with the -c
CLI option:
./<builddir>/bin/bluechi-controller -c <path-to-cfg-file>
Before starting the agent, it is best to have the bluechi-controller
already running. However, bluechi-agent
will
try to reconnect in the configured heartbeat interval.
Similar to bluechi-controller
, it is recommended to use a dedicated configuration file for development:
./<builddir>/bin/bluechi-agent -c <path-to-cfg-file>
The newly built bluechictl
can be used via:
./<builddir>/bin/bluechictl COMMANDS
Files for documentation of this project are located in the doc directory comprising:
- api examples: directory containing source files for different programming languages that use the D-Bus API of BlueChi, e.g. for starting a systemd unit
- man: directory containing the markdown files for generating the man pages (see Building MAN pages for more information)
- readthedocs files for building the documentation website of BlueChi (see the README for further information)
- diagrams.drawio file containing all diagrams used for BlueChi
The source markdown files for building the MAN pages are located in doc/man. For generating the MAN pages from the markdown files go-md2man is being used. Install it via:
sudo dnf install golang-github-cpuguy83-md2man
After executing a meson install
the MAN pages are located in the man/man*
directories.
In order to package BlueChi as an RPM the following dependencies are required:
sudo dnf install \
jq \
rpm-build
The scripts used to create the SRPM and RPM may be found in build-scripts directory. Executing following command will create RPM packages for the current content of the project:
sudo ./build-scripts/build-rpm.sh
Created RPM packages can be found under artifacts/rpms*
subdirectories according to the timestamp of the execution.
The package build process can be adjusted using following environment variables:
ARTIFACTS_DIR
- A full path to a directory where the RPMs will be saved. The script will create the directory if it does not exist.
SKIP_BUILDDEP
- To skip installation of build dependencies this option should contain
yes
value.
- To skip installation of build dependencies this option should contain
WITH_PYTHON
- To skip building python bluechi modules this option should contain
0
. Default:1
.
- To skip building python bluechi modules this option should contain
WITH_COVERAGE
- To start collecting coverage this option should contain
1
. Default:0
.
- To start collecting coverage this option should contain
So for example following command will skip build dependencies installation and store create RPM packages into output
subdirectory:
SKIP_BUILDDEP=yes ARTIFACTS_DIR=${PWD}/output ./build-scripts/build-rpm.sh
Creating the BlueChi .deb
package is described in the debian/README.md.