race conditions are the best bugs

This commit is contained in:
rusefi 2020-07-19 01:36:20 -04:00
parent efae2d0509
commit 4d79b34b31
3 changed files with 28 additions and 3 deletions

View File

@ -1,6 +1,9 @@
package com.rusefi; package com.rusefi;
import com.opensr5.Logger; import com.opensr5.Logger;
import com.rusefi.config.generated.Fields;
import com.rusefi.io.tcp.BinaryProtocolServer;
import com.rusefi.io.tcp.TcpIoStream;
import com.rusefi.proxy.BaseBroadcastingThread; import com.rusefi.proxy.BaseBroadcastingThread;
import com.rusefi.server.ControllerInfo; import com.rusefi.server.ControllerInfo;
import com.rusefi.server.SessionDetails; import com.rusefi.server.SessionDetails;
@ -32,7 +35,18 @@ public class MockRusEfiDevice {
Socket socket = rusEFISSLContext.getSSLSocket(LOCALHOST, serverPort); Socket socket = rusEFISSLContext.getSSLSocket(LOCALHOST, serverPort);
BaseBroadcastingThread baseBroadcastingThread = new BaseBroadcastingThread(socket, BaseBroadcastingThread baseBroadcastingThread = new BaseBroadcastingThread(socket,
sessionDetails, sessionDetails,
logger); logger) {
@Override
protected void handleCommand(BinaryProtocolServer.Packet packet, TcpIoStream stream) throws IOException {
super.handleCommand(packet, stream);
if (packet.getPacket()[0] == Fields.TS_OUTPUT_COMMAND) {
byte[] response = new byte[1 + Fields.TS_OUTPUT_SIZE];
response[0] = (byte) BinaryProtocolServer.TS_OK.charAt(0);
stream.sendPacket(response, logger);
}
}
};
baseBroadcastingThread.start(); baseBroadcastingThread.start();
} }
} }

View File

@ -50,11 +50,20 @@ public class ServerTest {
CountDownLatch allClientsDisconnected = new CountDownLatch(1); CountDownLatch allClientsDisconnected = new CountDownLatch(1);
CountDownLatch onConnected = new CountDownLatch(2); CountDownLatch onConnected = new CountDownLatch(2);
CountDownLatch allConnected = new CountDownLatch(1);
try (Backend backend = new Backend(userDetailsResolver, httpPort, logger) { try (Backend backend = new Backend(userDetailsResolver, httpPort, logger) {
@Override @Override
public void register(ControllerConnectionState clientConnectionState) { public void register(ControllerConnectionState clientConnectionState) {
super.register(clientConnectionState); super.register(clientConnectionState);
onConnected.countDown(); onConnected.countDown();
try {
allConnected.await();
} catch (InterruptedException e) {
throw new IllegalStateException(e);
}
throw new IllegalStateException();
} }
@Override @Override
@ -81,6 +90,8 @@ public class ServerTest {
List<UserDetails> onlineUsers = ProxyClient.getOnlineUsers(httpPort); List<UserDetails> onlineUsers = ProxyClient.getOnlineUsers(httpPort);
assertEquals(2, onlineUsers.size()); assertEquals(2, onlineUsers.size());
allConnected.countDown();
assertTrue("allClientsDisconnected", allClientsDisconnected.await(30, TimeUnit.SECONDS)); assertTrue("allClientsDisconnected", allClientsDisconnected.await(30, TimeUnit.SECONDS));
} }
} }

View File

@ -159,11 +159,11 @@ public class Backend implements Closeable {
try { try {
controllerConnectionState.requestControllerInfo(); controllerConnectionState.requestControllerInfo();
// IMPORTANT: has to happen before we register controller while we still have exclusive access
controllerConnectionState.getOutputs(); controllerConnectionState.getOutputs();
register(controllerConnectionState); register(controllerConnectionState);
} catch (IOException e) { } catch (Throwable e) {
close(controllerConnectionState); close(controllerConnectionState);
} }
} }