From 98e62f42a374b64b4588444187dc6648a5e699c2 Mon Sep 17 00:00:00 2001 From: Michael Engel Date: Thu, 19 Dec 2024 10:16:21 +0100 Subject: [PATCH 1/2] Fixed typo in log message setting up UDS handler Signed-off-by: Michael Engel --- src/controller/controller.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/controller/controller.c b/src/controller/controller.c index 23a38a8d48..222a7fe9ad 100644 --- a/src/controller/controller.c +++ b/src/controller/controller.c @@ -616,7 +616,7 @@ static bool controller_setup_uds_connection_handler(Controller *controller) { (void) sd_event_source_set_description(event_source, "node-accept-uds-socket"); controller->node_connection_uds_socket_source = steal_pointer(&event_source); - bc_log_infof("Waiting for connection requests on port %s...", CONFIG_H_UDS_SOCKET_PATH); + bc_log_infof("Waiting for connection requests on socket %s...", CONFIG_H_UDS_SOCKET_PATH); return true; } From e01b99b35e0f4867a2d8f35899448f75260270b5 Mon Sep 17 00:00:00 2001 From: Michael Engel Date: Thu, 19 Dec 2024 10:17:53 +0100 Subject: [PATCH 2/2] Updated readthedoc with changes of UDS Relates to: https://github.com/eclipse-bluechi/bluechi/issues/997 The readthedocs pages and diagrams have been updated to reflect the changes done to support Unix Domain Sockets (UDS) and TCP/IP with UDS in parallel. Signed-off-by: Michael Engel --- doc/diagrams.drawio.xml | 72 +++++++++--------- doc/docs/api/client_generation.md | 3 +- .../img/bluechi_architecture_overview.png | Bin 207313 -> 207987 bytes doc/docs/cross_node_dependencies/usage.md | 60 ++++++++------- .../cross_node_dependencies.md | 45 ++++++----- .../getting_started/examples_bluechictl.md | 19 ++--- doc/docs/getting_started/multi_node.md | 32 ++++---- doc/docs/getting_started/single_node.md | 35 ++++----- doc/docs/monitoring/peers.md | 9 ++- .../test_monitor_node_reconnect.py | 4 +- 10 files changed, 148 insertions(+), 131 deletions(-) diff --git a/doc/diagrams.drawio.xml b/doc/diagrams.drawio.xml index 21b0aa1680..c438b1377e 100644 --- a/doc/diagrams.drawio.xml +++ b/doc/diagrams.drawio.xml @@ -1,12 +1,12 @@ - + - + - + @@ -100,31 +100,31 @@ - + - + - + - + - - + + - - + + - + @@ -137,51 +137,51 @@ - + - + - + - + - + - - + + - + - + - + - + - + - + - + @@ -559,41 +559,41 @@ - + - + - + - + - + - + - + - + - + - + diff --git a/doc/docs/api/client_generation.md b/doc/docs/api/client_generation.md index f0a05cb1b0..75d92f40f3 100644 --- a/doc/docs/api/client_generation.md +++ b/doc/docs/api/client_generation.md @@ -1,4 +1,5 @@ + # Generating BlueChi clients BlueChi provides [introspection data](https://dbus.freedesktop.org/doc/dbus-specification.html#introspection-format) for its public API. These XML files are located in the [data directory](https://github.com/eclipse-bluechi/bluechi/tree/main/data) of the project and can be also be used as input to generate clients. @@ -49,7 +50,7 @@ The `bluechi` python package consists of two subpackages: - `api`: auto-generated code based the BlueChi D-BUS API description - `ext`: custom written code to simplify common tasks -Functions from the auto-generated `api` subpackage reduce boilerplate code. It also removes the need to explicitly specify the D-Bus name, paths and interfaces and offers abstracted and easy to use functions. For example, lets compare the python code for listing all nodes. +Functions from the auto-generated `api` subpackage reduce boilerplate code. It also removes the need to explicitly specify the D-Bus name, paths and interfaces and offers abstracted and easy to use functions. For example, let's compare the python code for listing all nodes. Using the auto-generated bindings, the code would look like this: diff --git a/doc/docs/assets/img/bluechi_architecture_overview.png b/doc/docs/assets/img/bluechi_architecture_overview.png index 871323d8bb64ac328df1e585c2dc9ca3be6ab286..ba2b4bab702ffc54feb9b76600af915aa0f0a8fa 100644 GIT binary patch delta 79992 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%0A72z5+^fnn8c!kT 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

e`d*__|7#v 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 DG4=JY delta 79246 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 + # Using Proxy Services This section describes different scenarios of cross-node dependencies between services, how to resolve them using BlueChi's proxy service feature and which systemd mechanisms to use for the desired behaviour. As a baseline, the term `source.service` will be used for the systemd service that depends on a remote service, which will be referred to as `target.service`. @@ -7,17 +8,18 @@ This section describes different scenarios of cross-node dependencies between se !!! Note - This section focuses on the systemd and BlueChi mechanisms to define dependencies enforcing certain behaviour. For an introduction to proxy services with an example application, please refer to the `Getting started guide` with the [cross-node dependency example](../getting_started/cross_node_dependencies.md). + This section focuses on the systemd and BlueChi mechanisms to define dependencies enforcing certain behaviour. For an introduction to proxy services with an example application, please refer to the `Getting started guide` with the [cross-node dependency example](../getting_started/cross_node_dependencies.md). ## Stop source service when starting target service fails If the `source.service` requires the `target.service` to be in an **active state** and otherwise stops, this can be ensured by using `Requires=`. The failure of `target.service` is simulated by just executing `/bin/false`, returning exit code 1. === "source.service" - ```systemd - [Unit] - Requires=bluechi-proxy@worker2_target.service - After=bluechi-proxy@worker2_target.service + +````systemd +[Unit] +Requires=bluechi-proxy@worker2_target.service +After=bluechi-proxy@worker2_target.service [Service] Type=simple @@ -26,9 +28,9 @@ If the `source.service` requires the `target.service` to be in an **active state ``` === "target.service" - ```systemd - [Unit] - Description=Target service +```systemd +[Unit] +Description=Target service [Service] Type=simple @@ -36,7 +38,7 @@ If the `source.service` requires the `target.service` to be in an **active state RemainAfterExit=yes ``` -Lets try out the example services from above: +Let's try out the example services from above: ```bash $ bluechictl start main source.service @@ -51,7 +53,7 @@ UNIT | LOADED | ACTIVE | SUBSTATE | FREEZERSTATE | ENABLED | ------------------------------------------------------------------------------------------------ target.service | loaded | failed | failed | running | static | -``` +```` !!! Note @@ -62,10 +64,11 @@ target.service | loaded | failed | failed | running | static | In order to automatically stop the `target.service` when the requiring `source.service` has been stopped, systemd's `StopWhenUnneeded=yes` can be used in the `[Unit]` section of the `target.service` as shown in the snippets below: === "source.service" - ```systemd - [Unit] - Wants=bluechi-proxy@worker2_target.service - After=bluechi-proxy@worker2_target.service + +````systemd +[Unit] +Wants=bluechi-proxy@worker2_target.service +After=bluechi-proxy@worker2_target.service [Service] Type=simple @@ -74,9 +77,9 @@ In order to automatically stop the `target.service` when the requiring `source.s ``` === "target.service" - ```systemd - [Unit] - StopWhenUnneeded=yes +```systemd +[Unit] +StopWhenUnneeded=yes [Service] Type=simple @@ -84,7 +87,7 @@ In order to automatically stop the `target.service` when the requiring `source.s RemainAfterExit=yes ``` -Lets try out the example services from above: +Let's try out the example services from above: ```bash # start the source service and check status @@ -112,7 +115,7 @@ $ bluechictl status worker2 target.service UNIT | LOADED | ACTIVE | SUBSTATE | FREEZERSTATE | ENABLED | --------------------------------------------------------------------------------- target.service | loaded | inactive | dead | running | static | -``` +```` !!! Note @@ -123,10 +126,11 @@ target.service | loaded | inactive | dead | running | static | If the `target.service` enters a **failed** or **inactive** state at some point in time, the `source.service` is able to restart it by using `Upholds=` as shown in the snippet below. === "source.service" - ```systemd - [Unit] - Upholds=bluechi-proxy@worker2_target.service - After=bluechi-proxy@worker2_target.service + +````systemd +[Unit] +Upholds=bluechi-proxy@worker2_target.service +After=bluechi-proxy@worker2_target.service [Service] Type=simple @@ -135,16 +139,16 @@ If the `target.service` enters a **failed** or **inactive** state at some point ``` === "target.service" - ```systemd - [Unit] - StopWhenUnneeded=yes +```systemd +[Unit] +StopWhenUnneeded=yes [Service] Type=simple ExecStart=/bin/sleep 5 ``` -Lets try out the example services from above: +Let's try out the example services from above: ```bash $ bluechictl start main source.service @@ -158,7 +162,7 @@ $ bluechictl status worker2 target.service UNIT | LOADED | ACTIVE | SUBSTATE | FREEZERSTATE | ENABLED | ------------------------------------------------------------------------------------- target.service | loaded | active | running | running | static | -``` +```` !!! Note diff --git a/doc/docs/getting_started/cross_node_dependencies.md b/doc/docs/getting_started/cross_node_dependencies.md index 059e4fd083..710c2f84c5 100644 --- a/doc/docs/getting_started/cross_node_dependencies.md +++ b/doc/docs/getting_started/cross_node_dependencies.md @@ -1,4 +1,5 @@ + # Resolving cross-node dependencies In practice, it is a common scenario that a service running on Node A requires another service to run on Node B. Consider the following example: @@ -40,7 +41,7 @@ Reload the systemd controller configuration so it can find the newly created ser $ systemctl daemon-reload ``` -Lets verify that the service works as expected. First, start the service via: +Let's verify that the service works as expected. First, start the service via: ```bash $ systemctl start bluechi-cdn.service @@ -51,20 +52,20 @@ Then submit a query to it. The response should be an HTML page that contains the ```html $ curl localhost:9000 - + - - -Directory listing for / - - -

Directory listing for /

-
- -
- + + + Directory listing for / + + +

Directory listing for /

+
+ +
+ ``` @@ -126,7 +127,7 @@ if __name__ == "__main__": server.handle_request() ``` -Lets create a new systemd unit to wrap the `service.py`. Copy and paste the following unit definition into `/etc/systemd/system/bluechi-webservice.service`: +Let's create a new systemd unit to wrap the `service.py`. Copy and paste the following unit definition into `/etc/systemd/system/bluechi-webservice.service`: ```systemd [Unit] @@ -144,13 +145,15 @@ ExecStart=/usr/bin/python3 /tmp/bluechi-webservice/service.py 9000 192.168.178.5 Start the service via `systemctl` to verify it works as expected: ```html -$ systemctl start bluechi-webservice.service -$ curl localhost:9000 +$ systemctl start bluechi-webservice.service $ curl localhost:9000 - - bluechi_architecture - + + bluechi_architecture + ``` @@ -162,7 +165,7 @@ $ systemctl stop bluechi-webservice.service ## Resolving the dependency via BlueChi -After implementing both applications, lets ensure that starting the webservice will also start the CDN. Add the following lines to `bluechi-webservice.service` in the `[Unit]` section: +After implementing both applications, let's ensure that starting the webservice will also start the CDN. Add the following lines to `bluechi-webservice.service` in the `[Unit]` section: ```systemd Wants=bluechi-proxy@pi_bluechi-cdn.service diff --git a/doc/docs/getting_started/examples_bluechictl.md b/doc/docs/getting_started/examples_bluechictl.md index 119f3c5466..349c9f1698 100644 --- a/doc/docs/getting_started/examples_bluechictl.md +++ b/doc/docs/getting_started/examples_bluechictl.md @@ -1,4 +1,5 @@ + # Examples on how to use BlueChi For the examples in this section the a [multi-node setup](./multi_node.md) is assumed to be running and uses [bluechictl](../man/bluechictl.md) to interact with BlueChi. In order to leverage the full potential of BlueChi, e.g. by writing custom applications, please refer to the section describing how to [use BlueChi's D-Bus API](../api/examples.md). @@ -42,7 +43,7 @@ Subscribing to node '*' and unit '*' !!! Note When a unit subscription with a wildcard `*` exists, BlueChi emits `virtual` events for the unit with name `*` on - + - creation of the wildcard subscription - node in the the wildcard subscription dis-/connects @@ -55,19 +56,19 @@ In addition to monitoring units, BlueChi's APIs can be used to query and monitor ```bash $ bluechictl status -NODE | STATE | LAST SEEN +NODE | STATE | LAST SEEN ========================================================================= -laptop | online | now -pi | online | now +laptop | online | now +pi | online | now ``` Assuming node `pi` would go offline, the output would immediately change to something like this: ```bash -NODE | STATE | LAST SEEN +NODE | STATE | LAST SEEN ========================================================================= -laptop | online | now -pi | online | 2023-10-06 08:38:20,000+0200 +laptop | online | now +pi | online | 2023-10-06 08:38:20,000+0200 ``` It is also possible to show the status of a specific node @@ -94,9 +95,9 @@ Done !!! Note - Starting a systemd unit via BlueChi's D-Bus API queues a job to start that unit in systemd. `bluechictl start` also waits for this job to be completed. This also applies to other operations like **stop**. + Starting a systemd unit via BlueChi's D-Bus API queues a job to start that unit in systemd. `bluechictl start` also waits for this job to be completed. This also applies to other operations like **stop**. -Lets stop the `httpd` service: +Let's stop the `httpd` service: ```bash $ bluechictl stop pi httpd diff --git a/doc/docs/getting_started/multi_node.md b/doc/docs/getting_started/multi_node.md index 61326916c8..20c7bcc35e 100644 --- a/doc/docs/getting_started/multi_node.md +++ b/doc/docs/getting_started/multi_node.md @@ -1,4 +1,5 @@ + # Setup: Multi node BlueChi is intended for multi-node environments with a predefined number of nodes. This section describes how to set it up based on an example with two machines - a laptop and a raspberry pi. The diagram below depicts the desired state of the system: @@ -7,32 +8,35 @@ BlueChi is intended for multi-node environments with a predefined number of node ## Installation and configuration -The main node will be the **laptop**. So first of all, lets install the controller, the agent and the CLI tool as well as the SELinux policy on it: +The main node will be the **laptop**. So first of all, let's install the controller, the agent and the CLI tool as well as the SELinux policy on it: ```bash -dnf install bluechi bluechi-agent bluechi-ctl bluechi-selinux +dnf install bluechi bluechi-agent bluechi-ctl bluechi-selinux ``` The **raspberry pi** will be (one of) the managed node in this example. Therefore, only install the agent and the SELinux policy on it: ```bash -dnf install bluechi-agent bluechi-selinux +dnf install bluechi-agent bluechi-selinux ``` Once the installations succeeded, BlueChi needs to be configured on both machines. ### Configuring the main node -Lets start with the main node (the **laptop** in this case). The configuration of the controller running on the **laptop** is similar to the [single node setup](#installation-and-configuration) with the exception of adding **pi** as another node to it: +Let's start with the main node (the **laptop** in this case). The configuration of the controller running on the **laptop** is similar to the [single node setup](#installation-and-configuration) with two exceptions: + +- **pi** needs to be added as another node +- **pi** is a remote agent and will connect to BlueChi via TCP/IP. By default, the privileged port 842 is used. To avoid any firewall issues for this demo, let's overwrite this setting and use the port **2020**. ```bash echo -e "[bluechi-controller]\nControllerPort=2020\nAllowedNodeNames=$(hostname),pi\n" > /etc/bluechi/controller.conf.d/1.conf ``` -Lets also create the configuration for the agent on the **laptop** changing the port: +Let's also create the configuration for the local agent on the **laptop** to use the Unix Domain Socket: ```bash -echo -e "[bluechi-agent]\nControllerPort=2020\n" > /etc/bluechi/agent.conf.d/1.conf +echo -e "[bluechi-agent]\nControllerAddress=unix:path=/run/bluechi/bluechi.sock\n" > /etc/bluechi/agent.conf.d/1.conf ``` ### Configuring the managed node @@ -57,7 +61,7 @@ ControllerPort=2020 ## Running BlueChi -After [installation and configuration](#installation-and-configuration) has been completed, lets start the systemd services. +After [installation and configuration](#installation-and-configuration) has been completed, let's start the systemd services. Starting the controller and agent on the main node (**laptop**): @@ -75,15 +79,17 @@ Once the services are up and running, the journald logs on the **laptop** should ```bash $ journalctl -u bluechi-controller - -Sep 14 14:51:58 laptop systemd[1]: Started BlueChi systemd service controller daemon. -Sep 01 14:51:58 laptop bluechi[3750775]: 2023-09-14 14:51:58,685+0200 INFO ../src/controller/controller.c:924 controller_start msg="Starting bluechi 0.7.0" -Sep 01 14:51:58 laptop bluechi[3750775]: 2023-09-14 14:51:58,928+0200 INFO ../src/controller/node.c:870 node_method_register msg="Registered managed node from fd 8 as 'laptop'" -Sep 01 14:52:02 laptop bluechi[3750775]: 2023-09-14 14:52:02,534+0200 INFO ../src/controller/node.c:870 node_method_register msg="Registered managed node from fd 9 as 'pi'" +Dec 18 08:03:03 localhost systemd[1]: Started BlueChi Controller systemd service +Dec 18 08:03:03 localhost bluechi-controller[680]: Starting bluechi-controller 0.10.0-0 +Dec 17 16:13:43 localhost bluechi-controller[2539]: Waiting for connection requests on port 842... +Dec 17 16:13:43 localhost bluechi-controller[2539]: Waiting for connection requests on socket /run/bluechi/bluechi.sock... +Dec 18 08:03:03 localhost bluechi-controller[680]: Heartbeat disabled since configured interval '0' is <=0 +Dec 18 08:03:03 localhost bluechi-controller[680]: Registered managed node from fd 9 as 'local' +Dec 18 08:03:03 localhost bluechi-controller[680]: Registered managed node from fd 10 as 'pi' ... ``` -Lets use `bluechictl` on the main node to list all units: +Let's use `bluechictl` on the main node to list all units: ```bash # list all units on the laptop diff --git a/doc/docs/getting_started/single_node.md b/doc/docs/getting_started/single_node.md index ec38c6ed12..9e8b04b58a 100644 --- a/doc/docs/getting_started/single_node.md +++ b/doc/docs/getting_started/single_node.md @@ -1,4 +1,5 @@ + # Setup: Single node BlueChi's two core components - the controller and the agent - can run alongside each other on the same machine. A single node setup like this is one of the quickest way to get started. This section describes how to achieve that. The diagram below depicts the desired state of the system: @@ -7,27 +8,26 @@ BlueChi's two core components - the controller and the agent - can run alongside ## Installation and configuration -First of all, lets install the controller and the agent as well as the CLI tool and the SELinux policy: +First of all, let's install the controller and the agent as well as the CLI tool and the SELinux policy: ```bash -dnf install bluechi bluechi-agent bluechi-ctl bluechi-selinux +dnf install bluechi bluechi-agent bluechi-ctl bluechi-selinux ``` Once the installation succeeded, `bluechi-controller` and `bluechi-agent` need to be configured. Both components use default settings so that a single node setup requires minimal configuration effort. -For the `bluechi-controller` configuration, the [AllowedNodeNames](../man/bluechi-controller-conf.md#allowednodenames-string) need to be adjusted in order to allow the `bluechi-agent` to register with its node name. By default, the agent will use the **hostname** it is running on. -BlueChi uses port **842** by default, which is considered a privileged port. To avoid any firewall issues for this demo, lets overwrite this setting and use the port **2020**. +For the `bluechi-controller` configuration, the [AllowedNodeNames](../man/bluechi-controller-conf.md#allowednodenames-string) need to be adjusted in order to allow the `bluechi-agent` to register with its node name. By default, the `bluechi-controller` will listen on Unix Domain Socket (UDS) `/run/bluechi/bluechi.sock` for local agents and on the TCP port **842** for remote ones. Since this is a single node setup, let's use the Unix Domain Socket as transport mechanism. -Lets create a new configuration for `bluechi-controller` in its `conf.d` directory: +First, create a new configuration for `bluechi-controller` in its `conf.d` directory: ```bash -echo -e "[bluechi-controller]\nControllerPort=2020\nAllowedNodeNames=$(hostname)\n" > /etc/bluechi/controller.conf.d/1.conf +echo -e "[bluechi-controller]\nAllowedNodeNames=$(hostname)\n" > /etc/bluechi/controller.conf.d/1.conf ``` -Since the default port has been changed, this setting has to be adjusted for the `bluechi-agent` as well: +The default connection mechanism of the `bluechi-agent` is TCP/IP. Therefore, its configuration needs to be adjusted as well: ```bash -echo -e "[bluechi-agent]\nControllerPort=2020\n" > /etc/bluechi/agent.conf.d/1.conf +echo -e "[bluechi-agent]\nControllerAddress=unix:path=/run/bluechi/bluechi.sock\n" > /etc/bluechi/agent.conf.d/1.conf ``` After running both commands, the following files should have been created: @@ -36,18 +36,17 @@ After running both commands, the following files should have been created: $ cat /etc/bluechi/controller.conf.d/1.conf [bluechi-controller] -ControllerPort=2020 AllowedNodeNames= $ cat /etc/bluechi/agent.conf.d/1.conf [bluechi-agent] -ControllerPort=2020 +ControllerAddress=unix:path=/run/bluechi/bluechi.sock ``` !!! Note - For a full list of available configuration options, please refer to [bluechi(5)](../man/bluechi-controller-conf.md) and [bluechi-agent(5)](../man/bluechi-agent-conf.md). + For a full list of available configuration options, please refer to [bluechi(5)](../man/bluechi-controller-conf.md) and [bluechi-agent(5)](../man/bluechi-agent-conf.md). ## Running BlueChi @@ -60,15 +59,17 @@ systemctl start bluechi-controller bluechi-agent Once the services are up and running, the journald logs should show that the agent successfully connected to the controller: ```bash -$ journalctl -u bluechi - -Sep 14 14:51:58 laptop systemd[1]: Started BlueChi systemd service controller daemon. -Sep 01 14:51:58 laptop bluechi[3750775]: 2023-09-14 14:51:58,685+0200 INFO ../src/controller/controller.c:924 controller_start msg="Starting bluechi 0.7.0" -Sep 01 14:51:58 laptop bluechi[3750775]: 2023-09-14 14:51:58,928+0200 INFO ../src/controller/node.c:870 node_method_register msg="Registered managed node from fd 8 as 'laptop'" +$ journalctl -u bluechi-controller +Dec 18 08:03:03 localhost systemd[1]: Started BlueChi Controller systemd service +Dec 18 08:03:03 localhost bluechi-controller[680]: Starting bluechi-controller 0.10.0-0 +Dec 17 16:13:43 localhost bluechi-controller[2539]: Waiting for connection requests on port 842... +Dec 17 16:13:43 localhost bluechi-controller[2539]: Waiting for connection requests on socket /run/bluechi/bluechi.sock... +Dec 18 08:03:03 localhost bluechi-controller[680]: Heartbeat disabled since configured interval '0' is <=0 +Dec 18 08:03:03 localhost bluechi-controller[680]: Registered managed node from fd 10 as 'local' ... ``` -Lets use `bluechictl` to list all units on the machine: +Let's use `bluechictl` to list all units on the machine: ```bash $ bluechictl list-units diff --git a/doc/docs/monitoring/peers.md b/doc/docs/monitoring/peers.md index 2ed98e6355..8a67ec620b 100644 --- a/doc/docs/monitoring/peers.md +++ b/doc/docs/monitoring/peers.md @@ -1,4 +1,5 @@ + # Peer listeners By default, only the monitor creator receives the events of the subscribed units from BlueChi. Peer listeners are other applications that did not create the monitor itself, but still want to get those messages. They can be added to any previously set up monitor via the BlueChi API. @@ -9,7 +10,7 @@ The systemd policy of BlueChi defines that only the `root` user (by default) can This section assumes at least a [single-node setup](../getting_started/single_node.md) and will use the [generated python bindings](../api/client_generation.md#typed-python-client). -First, lets start `bluechi-controller` and `bluechi-agent`: +First, let's start `bluechi-controller` and `bluechi-agent`: ```bash $ systemctl start bluechi-controller @@ -23,7 +24,7 @@ $ python create-and-listen.py laptop cow.service Monitor path: /org/eclipse/bluechi/monitor/1 ``` -It will print the path of the monitor. This path is required to attach event listener to it. Lets open a new terminal and start the listening script: +It will print the path of the monitor. This path is required to attach event listener to it. Let's open a new terminal and start the listening script: ```bash $ python only-listen.py /org/eclipse/bluechi/monitor/1 @@ -32,7 +33,7 @@ Using unique name: :1.9327 The first line in the output is the unique bus name of the application. This is the name used to add it as a peer to the previously created monitor. -Before adding it as peer, however, lets check the status and/or do start and stop operations on the unit that is monitored: +Before adding it as peer, however, let's check the status and/or do start and stop operations on the unit that is monitored: ```bash $ bluechictl status laptop cow.service @@ -53,7 +54,7 @@ Unit props changed: laptop -- cow.service ... ``` -Contrary, the `only-listen.py` should not have received anything yet. Lets change that by adding its bus name to the monitor as peer: +Contrary, the `only-listen.py` should not have received anything yet. Let's change that by adding its bus name to the monitor as peer: ```bash $ python add-peer.py /org/eclipse/bluechi/monitor/1 :1.9327 diff --git a/tests/tests/tier0/monitor-node-reconnect/test_monitor_node_reconnect.py b/tests/tests/tier0/monitor-node-reconnect/test_monitor_node_reconnect.py index 42e1fc5753..bb8e616bcc 100644 --- a/tests/tests/tier0/monitor-node-reconnect/test_monitor_node_reconnect.py +++ b/tests/tests/tier0/monitor-node-reconnect/test_monitor_node_reconnect.py @@ -22,13 +22,13 @@ def exec(ctrl: BluechiControllerMachine, nodes: Dict[str, BluechiAgentMachine]): ctrl.systemctl.stop_unit("bluechi-controller") ctrl.wait_for_unit_state_to_be("bluechi-controller", "inactive") - # lets wait a bit so the agent has at least one failing reconnect attempt + # let's wait a bit so the agent has at least one failing reconnect attempt time.sleep(1) ctrl.systemctl.start_unit("bluechi-controller") ctrl.wait_for_bluechi_controller() # since the heartbeat (incl. a try to reconnect) is going to happen - # every n milliseconds, lets wait a bit so this test is not becoming flaky + # every n milliseconds, let's wait a bit so this test is not becoming flaky time.sleep(1) result, output = ctrl.run_python(os.path.join("python", "is_node_connected.py"))