2 * Copyright (c) 2010-2020 Contributors to the openHAB project
4 * See the NOTICE file(s) distributed with this work for additional
7 * This program and the accompanying materials are made available under the
8 * terms of the Eclipse Public License 2.0 which is available at
9 * http://www.eclipse.org/legal/epl-2.0
11 * SPDX-License-Identifier: EPL-2.0
13 package org.openhab.io.mqttembeddedbroker;
15 import static org.junit.Assert.assertTrue;
17 import java.util.concurrent.Semaphore;
18 import java.util.concurrent.TimeUnit;
20 import org.eclipse.jdt.annotation.NonNull;
21 import org.eclipse.jdt.annotation.NonNullByDefault;
22 import org.eclipse.jdt.annotation.Nullable;
23 import org.openhab.core.io.transport.mqtt.MqttBrokerConnection;
24 import org.openhab.core.io.transport.mqtt.MqttConnectionObserver;
25 import org.openhab.core.io.transport.mqtt.MqttConnectionState;
26 import org.openhab.core.io.transport.mqtt.MqttService;
27 import org.openhab.core.io.transport.mqtt.MqttServiceObserver;
28 import org.openhab.io.mqttembeddedbroker.Constants;
29 import org.slf4j.Logger;
30 import org.slf4j.LoggerFactory;
33 * A full implementation test, that starts the embedded MQTT broker and publishes a homeassistant MQTT discovery device
36 * @author David Graeff - Initial contribution
39 public class EmbeddedBrokerTools {
40 private final Logger logger = LoggerFactory.getLogger(EmbeddedBrokerTools.class);
41 public @Nullable MqttBrokerConnection embeddedConnection = null;
44 * Request the embedded broker connection from the {@link MqttService} and wait for a connection to be established.
46 * @throws InterruptedException
48 public MqttBrokerConnection waitForConnection(MqttService mqttService) throws InterruptedException {
49 embeddedConnection = mqttService.getBrokerConnection(Constants.CLIENTID);
50 if (embeddedConnection == null) {
51 Semaphore semaphore = new Semaphore(1);
53 MqttServiceObserver observer = new MqttServiceObserver() {
56 public void brokerAdded(@NonNull String brokerID, @NonNull MqttBrokerConnection broker) {
57 if (brokerID.equals(Constants.CLIENTID)) {
58 embeddedConnection = broker;
64 public void brokerRemoved(@NonNull String brokerID, @NonNull MqttBrokerConnection broker) {
68 mqttService.addBrokersListener(observer);
69 assertTrue("Wait for embedded connection client failed", semaphore.tryAcquire(700, TimeUnit.MILLISECONDS));
71 MqttBrokerConnection embeddedConnection = this.embeddedConnection;
72 if (embeddedConnection == null) {
73 throw new IllegalStateException();
76 logger.warn("waitForConnection {}", embeddedConnection.connectionState());
77 Semaphore semaphore = new Semaphore(1);
79 MqttConnectionObserver mqttConnectionObserver = (state, error) -> {
80 if (state == MqttConnectionState.CONNECTED) {
84 embeddedConnection.addConnectionObserver(mqttConnectionObserver);
85 if (embeddedConnection.connectionState() == MqttConnectionState.CONNECTED) {
88 assertTrue("Connection " + embeddedConnection.getClientId() + " failed. State: "
89 + embeddedConnection.connectionState(), semaphore.tryAcquire(500, TimeUnit.MILLISECONDS));
90 return embeddedConnection;