mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-25 14:55:55 +01:00
[network] Fix latency parsing on windows 10 (#8781)
Fixes #8776 Signed-off-by: Connor Petty <mistercpp2000+gitsignoff@gmail.com>
This commit is contained in:
parent
ae1d59cf99
commit
ac1e4d8a83
@ -22,6 +22,7 @@ import java.util.Set;
|
||||
import java.util.concurrent.ExecutorService;
|
||||
import java.util.concurrent.Executors;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
import java.util.concurrent.atomic.AtomicInteger;
|
||||
import java.util.stream.Collectors;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
@ -65,7 +66,7 @@ public class NetworkDiscoveryService extends AbstractDiscoveryService implements
|
||||
// TCP port 1025 (Xbox / MS-RPC)
|
||||
private Set<Integer> tcpServicePorts = Collections
|
||||
.unmodifiableSet(Stream.of(80, 548, 554, 1025).collect(Collectors.toSet()));
|
||||
private Integer scannedIPcount = 0;
|
||||
private AtomicInteger scannedIPcount = new AtomicInteger(0);
|
||||
private @Nullable ExecutorService executorService = null;
|
||||
private final NetworkBindingConfiguration configuration = new NetworkBindingConfiguration();
|
||||
private final NetworkUtils networkUtils = new NetworkUtils();
|
||||
@ -135,7 +136,7 @@ public class NetworkDiscoveryService extends AbstractDiscoveryService implements
|
||||
logger.trace("Starting Network Device Discovery");
|
||||
|
||||
final Set<String> networkIPs = networkUtils.getNetworkIPs(MAXIMUM_IPS_PER_INTERFACE);
|
||||
scannedIPcount = 0;
|
||||
scannedIPcount.set(0);
|
||||
|
||||
for (String ip : networkIPs) {
|
||||
final PresenceDetection s = new PresenceDetection(this, 2000);
|
||||
@ -152,12 +153,10 @@ public class NetworkDiscoveryService extends AbstractDiscoveryService implements
|
||||
service.execute(() -> {
|
||||
Thread.currentThread().setName("Discovery thread " + ip);
|
||||
s.performPresenceDetection(true);
|
||||
synchronized (scannedIPcount) {
|
||||
scannedIPcount += 1;
|
||||
if (scannedIPcount == networkIPs.size()) {
|
||||
logger.trace("Scan of {} IPs successful", scannedIPcount);
|
||||
stopScan();
|
||||
}
|
||||
int count = scannedIPcount.incrementAndGet();
|
||||
if (count == networkIPs.size()) {
|
||||
logger.trace("Scan of {} IPs successful", scannedIPcount);
|
||||
stopScan();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
@ -26,6 +26,7 @@ import org.slf4j.LoggerFactory;
|
||||
*/
|
||||
public class LatencyParser {
|
||||
|
||||
private static Pattern LATENCY_PATTERN = Pattern.compile(".*time=(.*) ?ms");
|
||||
private final Logger logger = LoggerFactory.getLogger(LatencyParser.class);
|
||||
|
||||
// This is how the input looks like on Mac and Linux:
|
||||
@ -47,8 +48,7 @@ public class LatencyParser {
|
||||
public Optional<Double> parseLatency(String inputLine) {
|
||||
logger.debug("Parsing latency from input {}", inputLine);
|
||||
|
||||
String pattern = ".*time=(.*) ms";
|
||||
Matcher m = Pattern.compile(pattern).matcher(inputLine);
|
||||
Matcher m = LATENCY_PATTERN.matcher(inputLine);
|
||||
if (m.find() && m.groupCount() == 1) {
|
||||
return Optional.of(Double.parseDouble(m.group(1)));
|
||||
}
|
||||
|
@ -58,4 +58,18 @@ public class LatencyParserTest {
|
||||
assertFalse(resultLatency.isPresent());
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void parseWindows10ResultFoundTest() {
|
||||
// Arrange
|
||||
LatencyParser latencyParser = new LatencyParser();
|
||||
String input = "Reply from 192.168.178.207: bytes=32 time=2ms TTL=64";
|
||||
|
||||
// Act
|
||||
Optional<Double> resultLatency = latencyParser.parseLatency(input);
|
||||
|
||||
// Assert
|
||||
assertTrue(resultLatency.isPresent());
|
||||
assertEquals(2, resultLatency.get(), 0);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user