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.jupiter.api.Assertions.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.slf4j.Logger;
29 import org.slf4j.LoggerFactory;
32 * A full implementation test, that starts the embedded MQTT broker and publishes a homeassistant MQTT discovery device
35 * @author David Graeff - Initial contribution
38 public class EmbeddedBrokerTools {
39 private final Logger logger = LoggerFactory.getLogger(EmbeddedBrokerTools.class);
40 public @Nullable MqttBrokerConnection embeddedConnection = null;
43 * Request the embedded broker connection from the {@link MqttService} and wait for a connection to be established.
45 * @throws InterruptedException
47 public MqttBrokerConnection waitForConnection(MqttService mqttService) throws InterruptedException {
48 embeddedConnection = mqttService.getBrokerConnection(Constants.CLIENTID);
49 if (embeddedConnection == null) {
50 Semaphore semaphore = new Semaphore(1);
52 MqttServiceObserver observer = new MqttServiceObserver() {
55 public void brokerAdded(@NonNull String brokerID, @NonNull MqttBrokerConnection broker) {
56 if (brokerID.equals(Constants.CLIENTID)) {
57 embeddedConnection = broker;
63 public void brokerRemoved(@NonNull String brokerID, @NonNull MqttBrokerConnection broker) {
66 mqttService.addBrokersListener(observer);
67 assertTrue(semaphore.tryAcquire(700, TimeUnit.MILLISECONDS), "Wait for embedded connection client failed");
69 MqttBrokerConnection embeddedConnection = this.embeddedConnection;
70 if (embeddedConnection == null) {
71 throw new IllegalStateException();
74 logger.warn("waitForConnection {}", embeddedConnection.connectionState());
75 Semaphore semaphore = new Semaphore(1);
77 MqttConnectionObserver mqttConnectionObserver = (state, error) -> {
78 if (state == MqttConnectionState.CONNECTED) {
82 embeddedConnection.addConnectionObserver(mqttConnectionObserver);
83 if (embeddedConnection.connectionState() == MqttConnectionState.CONNECTED) {
86 assertTrue(semaphore.tryAcquire(500, TimeUnit.MILLISECONDS), "Connection " + embeddedConnection.getClientId()
87 + " failed. State: " + embeddedConnection.connectionState());
88 return embeddedConnection;