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.NonNullByDefault;
21 import org.eclipse.jdt.annotation.Nullable;
22 import org.openhab.core.io.transport.mqtt.MqttBrokerConnection;
23 import org.openhab.core.io.transport.mqtt.MqttConnectionObserver;
24 import org.openhab.core.io.transport.mqtt.MqttConnectionState;
25 import org.openhab.core.io.transport.mqtt.MqttService;
26 import org.openhab.core.io.transport.mqtt.MqttServiceObserver;
27 import org.slf4j.Logger;
28 import org.slf4j.LoggerFactory;
31 * A full implementation test, that starts the embedded MQTT broker and publishes a homeassistant MQTT discovery device
34 * @author David Graeff - Initial contribution
37 public class EmbeddedBrokerTools {
38 private final Logger logger = LoggerFactory.getLogger(EmbeddedBrokerTools.class);
39 public @Nullable MqttBrokerConnection embeddedConnection = null;
42 * Request the embedded broker connection from the {@link MqttService} and wait for a connection to be established.
44 * @throws InterruptedException
46 public MqttBrokerConnection waitForConnection(MqttService mqttService) throws InterruptedException {
47 embeddedConnection = mqttService.getBrokerConnection(Constants.CLIENTID);
48 if (embeddedConnection == null) {
49 Semaphore semaphore = new Semaphore(1);
51 MqttServiceObserver observer = new MqttServiceObserver() {
54 public void brokerAdded(String brokerID, MqttBrokerConnection broker) {
55 if (brokerID.equals(Constants.CLIENTID)) {
56 embeddedConnection = broker;
62 public void brokerRemoved(String brokerID, MqttBrokerConnection broker) {
65 mqttService.addBrokersListener(observer);
66 assertTrue(semaphore.tryAcquire(700, TimeUnit.MILLISECONDS), "Wait for embedded connection client failed");
68 MqttBrokerConnection embeddedConnection = this.embeddedConnection;
69 if (embeddedConnection == null) {
70 throw new IllegalStateException();
73 logger.warn("waitForConnection {}", embeddedConnection.connectionState());
74 Semaphore semaphore = new Semaphore(1);
76 MqttConnectionObserver mqttConnectionObserver = (state, error) -> {
77 if (state == MqttConnectionState.CONNECTED) {
81 embeddedConnection.addConnectionObserver(mqttConnectionObserver);
82 if (embeddedConnection.connectionState() == MqttConnectionState.CONNECTED) {
85 assertTrue(semaphore.tryAcquire(500, TimeUnit.MILLISECONDS), "Connection " + embeddedConnection.getClientId()
86 + " failed. State: " + embeddedConnection.connectionState());
87 return embeddedConnection;