mirror of
https://code.briarproject.org/briar/briar.git
synced 2026-02-17 21:29:54 +01:00
Add unit test for TimeoutInputStream.
This commit is contained in:
@@ -0,0 +1,143 @@
|
|||||||
|
package org.briarproject.bramble.io;
|
||||||
|
|
||||||
|
import org.briarproject.bramble.test.BrambleTestCase;
|
||||||
|
import org.briarproject.bramble.test.SettableClock;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.util.concurrent.CountDownLatch;
|
||||||
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
|
import java.util.concurrent.atomic.AtomicLong;
|
||||||
|
|
||||||
|
import static java.util.concurrent.TimeUnit.MINUTES;
|
||||||
|
import static java.util.concurrent.TimeUnit.SECONDS;
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertFalse;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
import static org.junit.Assert.fail;
|
||||||
|
|
||||||
|
public class TimeoutInputStreamTest extends BrambleTestCase {
|
||||||
|
|
||||||
|
private static final long TIMEOUT_MS = MINUTES.toMillis(1);
|
||||||
|
|
||||||
|
private final long now = System.currentTimeMillis();
|
||||||
|
|
||||||
|
private AtomicLong time;
|
||||||
|
private UnresponsiveInputStream in;
|
||||||
|
private AtomicBoolean listenerCalled;
|
||||||
|
private TimeoutInputStream stream;
|
||||||
|
private CountDownLatch readReturned;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
time = new AtomicLong(now);
|
||||||
|
in = new UnresponsiveInputStream();
|
||||||
|
listenerCalled = new AtomicBoolean(false);
|
||||||
|
stream = new TimeoutInputStream(new SettableClock(time), in,
|
||||||
|
TIMEOUT_MS * 1_000_000, stream -> listenerCalled.set(true));
|
||||||
|
readReturned = new CountDownLatch(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testTimeoutIsReportedIfReadDoesNotReturn() throws Exception {
|
||||||
|
startReading();
|
||||||
|
try {
|
||||||
|
// The stream should not report a timeout
|
||||||
|
assertFalse(stream.hasTimedOut());
|
||||||
|
|
||||||
|
// Time passes
|
||||||
|
time.set(now + TIMEOUT_MS);
|
||||||
|
|
||||||
|
// The stream still shouldn't report a timeout
|
||||||
|
assertFalse(stream.hasTimedOut());
|
||||||
|
|
||||||
|
// Time passes
|
||||||
|
time.set(now + TIMEOUT_MS + 1);
|
||||||
|
|
||||||
|
// The stream should report a timeout
|
||||||
|
assertTrue(stream.hasTimedOut());
|
||||||
|
|
||||||
|
// The listener should not have been called yet
|
||||||
|
assertFalse(listenerCalled.get());
|
||||||
|
|
||||||
|
// Close the stream
|
||||||
|
stream.close();
|
||||||
|
|
||||||
|
// The listener should have been called
|
||||||
|
assertTrue(listenerCalled.get());
|
||||||
|
} finally {
|
||||||
|
// Allow the read to return
|
||||||
|
in.readFinished.countDown();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testTimeoutIsNotReportedIfReadReturns() throws Exception {
|
||||||
|
startReading();
|
||||||
|
try {
|
||||||
|
// The stream should not report a timeout
|
||||||
|
assertFalse(stream.hasTimedOut());
|
||||||
|
|
||||||
|
// Time passes
|
||||||
|
time.set(now + TIMEOUT_MS);
|
||||||
|
|
||||||
|
// The stream still shouldn't report a timeout
|
||||||
|
assertFalse(stream.hasTimedOut());
|
||||||
|
|
||||||
|
// Allow the read to finish and wait for it to return
|
||||||
|
in.readFinished.countDown();
|
||||||
|
readReturned.await(10, SECONDS);
|
||||||
|
|
||||||
|
// Time passes
|
||||||
|
time.set(now + TIMEOUT_MS + 1);
|
||||||
|
|
||||||
|
// The stream should not report a timeout as the read has returned
|
||||||
|
assertFalse(stream.hasTimedOut());
|
||||||
|
|
||||||
|
// The listener should not have been called yet
|
||||||
|
assertFalse(listenerCalled.get());
|
||||||
|
|
||||||
|
// Close the stream
|
||||||
|
stream.close();
|
||||||
|
|
||||||
|
// The listener should have been called
|
||||||
|
assertTrue(listenerCalled.get());
|
||||||
|
} finally {
|
||||||
|
// Allow the read to return in case an assertion was thrown
|
||||||
|
in.readFinished.countDown();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void startReading() throws Exception {
|
||||||
|
// Start a background thread to read from the unresponsive stream
|
||||||
|
new Thread(() -> {
|
||||||
|
try {
|
||||||
|
assertEquals(123, stream.read());
|
||||||
|
readReturned.countDown();
|
||||||
|
} catch (IOException e) {
|
||||||
|
fail();
|
||||||
|
}
|
||||||
|
}).start();
|
||||||
|
// Wait for the background thread to start reading
|
||||||
|
assertTrue(in.readStarted.await(10, SECONDS));
|
||||||
|
}
|
||||||
|
|
||||||
|
private class UnresponsiveInputStream extends InputStream {
|
||||||
|
|
||||||
|
private final CountDownLatch readStarted = new CountDownLatch(1);
|
||||||
|
private final CountDownLatch readFinished = new CountDownLatch(1);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int read() throws IOException {
|
||||||
|
readStarted.countDown();
|
||||||
|
try {
|
||||||
|
readFinished.await();
|
||||||
|
return 123;
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
throw new IOException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user