From fe07d8a8081c5f2aecdcd51137f8ed2f542a00e4 Mon Sep 17 00:00:00 2001 From: Marco Thaller Date: Wed, 17 Jan 2024 18:40:40 +0100 Subject: [PATCH] Inject dependency MQTT into ApplicationEngine::InitMqttDemo This allows for easy mocking of dependency and therefore improves testability of class ApplicationEngine. Also fixes issue when building with BUILD_INTEGRATION_CURL OFF which was introduced by the complementary commit adding dependency injection of NetworkAccessManager into ApplicationEngine. --- .../application_engine/application_engine.cpp | 37 +++++++------------ .../application_engine/application_engine.h | 12 +++++- 2 files changed, 24 insertions(+), 25 deletions(-) diff --git a/demo/src/application_engine/application_engine.cpp b/demo/src/application_engine/application_engine.cpp index bc7f9d6..1df6873 100644 --- a/demo/src/application_engine/application_engine.cpp +++ b/demo/src/application_engine/application_engine.cpp @@ -3,9 +3,6 @@ #include "ftp_transfer_handle.h" #include "http_transfer_handle.h" #endif -#ifdef MOSQUITTO_AVAILABLE -#include "mqtt.h" -#endif #include ApplicationEngine &ApplicationEngine::init(const slint::ComponentHandle &appWindow) @@ -32,16 +29,21 @@ ApplicationEngine::ApplicationEngine(const slint::ComponentHandle &ap appSingleton.set_curl_available(false); #endif -#ifndef MOSQUITTO_AVAILABLE +#ifdef MOSQUITTO_AVAILABLE + MqttLib::instance().init(); + static MqttClient mqttClient = MqttClient("mecapitto", true, true); + InitMqttDemo(appWindow->global(), mqttClient); +#else appSingleton.set_mosquitto_available(false); #endif - InitMqttDemo(appWindow->global()); } ApplicationEngine::~ApplicationEngine() { - DeinitMqttDemo(); +#ifdef MOSQUITTO_AVAILABLE + MqttLib::instance().cleanup(); +#endif } void ApplicationEngine::InitCounterDemo(const CounterSingleton &uiPageCounter) @@ -53,9 +55,9 @@ void ApplicationEngine::InitCounterDemo(const CounterSingleton &uiPageCounter) uiPageCounter.on_request_increase_value(incrementCounterValue); } +#ifdef CURL_AVAILABLE void ApplicationEngine::InitHttpDemo(const HttpSingleton &httpSingleton, const INetworkAccessManager &networkAccessManager) { -#ifdef CURL_AVAILABLE httpSingleton.set_url("https://example.com"); auto startHttpQuery = [&]() { const auto url = Url(httpSingleton.get_url().data()); @@ -73,12 +75,12 @@ void ApplicationEngine::InitHttpDemo(const HttpSingleton &httpSingleton, const I networkAccessManager.registerTransfer(*httpTransfer); }; httpSingleton.on_request_http_query(startHttpQuery); -#endif } +#endif +#ifdef CURL_AVAILABLE void ApplicationEngine::InitFtpDemo(const FtpSingleton &ftpSingleton, const INetworkAccessManager &networkAccessManager) { -#ifdef CURL_AVAILABLE static File ftpFile = File("ls-lR.gz"); ftpSingleton.set_url_download("ftp://ftp-stud.hs-esslingen.de/debian/ls-lR.gz"); ftpSingleton.set_url_upload("ftp://ftp.cs.brown.edu/incoming/ls-lR.gz"); @@ -120,16 +122,12 @@ void ApplicationEngine::InitFtpDemo(const FtpSingleton &ftpSingleton, const INet ftpSingleton.set_is_uploading(true); }; ftpSingleton.on_request_ftp_upload(startFtpUpload); -#endif } +#endif -void ApplicationEngine::InitMqttDemo(const MqttSingleton &mqttSingleton) -{ #ifdef MOSQUITTO_AVAILABLE - MqttLib::instance().init(); - - static MqttClient mqttClient = MqttClient("mecapitto", true, true); - +void ApplicationEngine::InitMqttDemo(const MqttSingleton &mqttSingleton, IMqttClient &mqttClient) +{ static std::shared_ptr> mqttSubscriptionsModel(new slint::VectorModel); mqttSingleton.set_subscribed_topics(mqttSubscriptionsModel); @@ -253,12 +251,5 @@ void ApplicationEngine::InitMqttDemo(const MqttSingleton &mqttSingleton) mqttClient.publish(NULL, topic, payload.length(), payload.c_str()); }; mqttSingleton.on_request_mqtt_publish(publishMqttMessage); -#endif } - -void ApplicationEngine::DeinitMqttDemo() -{ -#ifdef MOSQUITTO_AVAILABLE - MqttLib::instance().cleanup(); #endif -} diff --git a/demo/src/application_engine/application_engine.h b/demo/src/application_engine/application_engine.h index 448dd2c..b89af9f 100644 --- a/demo/src/application_engine/application_engine.h +++ b/demo/src/application_engine/application_engine.h @@ -1,7 +1,12 @@ #pragma once #include "app_window.h" +#ifdef MOSQUITTO_AVAILABLE +#include "mqtt.h" +#endif +#ifdef CURL_AVAILABLE #include "network_access_manager.h" +#endif #include "slint.h" class ApplicationEngine @@ -20,8 +25,11 @@ class ApplicationEngine private: static void InitCounterDemo(const CounterSingleton &uiPageCounter); +#ifdef CURL_AVAILABLE static void InitHttpDemo(const HttpSingleton &httpSingleton, const INetworkAccessManager &networkAccessManager); static void InitFtpDemo(const FtpSingleton &ftpSingleton, const INetworkAccessManager &networkAccessManager); - static void InitMqttDemo(const MqttSingleton &mqttSingleton); - static void DeinitMqttDemo(); +#endif +#ifdef MOSQUITTO_AVAILABLE + static void InitMqttDemo(const MqttSingleton &mqttSingleton, IMqttClient &mqttClient); +#endif };