use of io.aeron.Image in project Aeron by real-logic.
the class RecordingWriterTest method onBlockShouldWriteHeaderOfThePaddingFrameAndAdvanceFilePositionByThePaddingLength.
@Test
void onBlockShouldWriteHeaderOfThePaddingFrameAndAdvanceFilePositionByThePaddingLength() throws IOException {
final int segmentOffset = 96;
final long startPosition = 7 * TERM_LENGTH + segmentOffset;
final Image image = mockImage(startPosition);
final RecordingWriter recordingWriter = new RecordingWriter(5, startPosition, SEGMENT_LENGTH, image, new Context().archiveDir(archiveDir));
recordingWriter.init();
final UnsafeBuffer termBuffer = new UnsafeBuffer(allocate(1024));
frameType(termBuffer, 0, HDR_TYPE_PAD);
frameLengthOrdered(termBuffer, 0, 1024);
frameSessionId(termBuffer, 0, 111);
final byte[] data = new byte[992];
fill(data, (byte) -1);
termBuffer.putBytes(HEADER_LENGTH, data);
recordingWriter.onBlock(termBuffer, 0, 1024, -1, -1);
recordingWriter.close();
final File segmentFile = segmentFile(5, startPosition);
assertTrue(segmentFile.exists());
assertEquals(SEGMENT_LENGTH, segmentFile.length());
final UnsafeBuffer fileBuffer = new UnsafeBuffer();
fileBuffer.wrap(readAllBytes(segmentFile.toPath()));
final byte[] preamble = new byte[segmentOffset];
fileBuffer.getBytes(0, preamble, 0, segmentOffset);
assertArrayEquals(new byte[segmentOffset], preamble);
assertEquals(HDR_TYPE_PAD, frameType(fileBuffer, segmentOffset));
assertEquals(1024, frameLength(fileBuffer, segmentOffset));
assertEquals(111, frameSessionId(fileBuffer, segmentOffset));
final byte[] fileBytes = new byte[992];
fileBuffer.getBytes(segmentOffset + HEADER_LENGTH, fileBytes, 0, 992);
assertArrayEquals(new byte[992], fileBytes);
}
use of io.aeron.Image in project Aeron by real-logic.
the class RecordingWriterTest method initShouldOpenAFileChannel.
@Test
void initShouldOpenAFileChannel() throws IOException {
final Image image = mockImage(0L);
final RecordingWriter recordingWriter = new RecordingWriter(1, 0, SEGMENT_LENGTH, image, new Context().archiveDir(archiveDir));
final File segmentFile = segmentFile(1, 0);
assertFalse(segmentFile.exists());
try {
recordingWriter.init();
assertTrue(segmentFile.exists());
} finally {
recordingWriter.close();
}
}
use of io.aeron.Image in project Aeron by real-logic.
the class EmbeddedPingPong method roundTripMessages.
private static void roundTripMessages(final FragmentHandler fragmentHandler, final Publication pingPublication, final Subscription pongSubscription, final long numMessages) {
while (!pongSubscription.isConnected()) {
Thread.yield();
}
final Image image = pongSubscription.imageAtIndex(0);
for (long i = 0; i < numMessages; i++) {
long offeredPosition;
do {
OFFER_BUFFER.putLong(0, System.nanoTime());
} while ((offeredPosition = pingPublication.offer(OFFER_BUFFER, 0, MESSAGE_LENGTH, null)) < 0L);
while (image.position() < offeredPosition) {
final int fragments = image.poll(fragmentHandler, FRAGMENT_COUNT_LIMIT);
PONG_HANDLER_IDLE_STRATEGY.idle(fragments);
}
}
}
use of io.aeron.Image in project Aeron by real-logic.
the class ClusterNodeRestartTest method launchService.
private void launchService(final AtomicLong msgCounter) {
final ClusteredService service = new StubClusteredService() {
private int nextCorrelationId = 0;
private int counterValue = 0;
public void onStart(final Cluster cluster, final Image snapshotImage) {
super.onStart(cluster, snapshotImage);
if (null != snapshotImage) {
final FragmentHandler fragmentHandler = (buffer, offset, length, header) -> {
nextCorrelationId = buffer.getInt(offset);
offset += SIZE_OF_INT;
counterValue = buffer.getInt(offset);
offset += SIZE_OF_INT;
serviceState.set(buffer.getStringAscii(offset));
};
while (true) {
final int fragments = snapshotImage.poll(fragmentHandler, 1);
if (fragments == 1 || snapshotImage.isEndOfStream()) {
break;
}
idleStrategy.idle();
}
}
}
public void onSessionMessage(final ClientSession session, final long timestamp, final DirectBuffer buffer, final int offset, final int length, final Header header) {
final int sentValue = buffer.getInt(offset + MESSAGE_VALUE_OFFSET);
assertEquals(counterValue, sentValue);
counterValue++;
serviceState.set(Integer.toString(counterValue));
msgCounter.getAndIncrement();
if (TIMER_MESSAGE_LENGTH == length) {
final long correlationId = serviceCorrelationId(nextCorrelationId++);
final long deadlineMs = timestamp + buffer.getLong(offset + TIMER_MESSAGE_DELAY_OFFSET);
while (!cluster.scheduleTimer(correlationId, deadlineMs)) {
idleStrategy.idle();
}
}
}
public void onTakeSnapshot(final ExclusivePublication snapshotPublication) {
final ExpandableArrayBuffer buffer = new ExpandableArrayBuffer();
int length = 0;
buffer.putInt(length, nextCorrelationId);
length += SIZE_OF_INT;
buffer.putInt(length, counterValue);
length += SIZE_OF_INT;
length += buffer.putStringAscii(length, Integer.toString(counterValue));
snapshotPublication.offer(buffer, 0, length);
}
};
container = ClusteredServiceContainer.launch(new ClusteredServiceContainer.Context().clusteredService(service).terminationHook(ClusterTests.NOOP_TERMINATION_HOOK).errorHandler(ClusterTests.errorHandler(0)));
}
use of io.aeron.Image in project aeron by real-logic.
the class RecordingWriterTest method onBlockShouldComputeCrcUsingTheChecksumBuffer.
@Test
void onBlockShouldComputeCrcUsingTheChecksumBuffer() throws IOException {
final Image image = mockImage(0L);
final Context ctx = new Context().archiveDir(archiveDir).recordChecksumBuffer(new UnsafeBuffer(allocateDirectAligned(512, 64))).recordChecksum(crc32());
final RecordingWriter recordingWriter = new RecordingWriter(1, 0, SEGMENT_LENGTH, image, ctx);
recordingWriter.init();
final UnsafeBuffer termBuffer = new UnsafeBuffer(allocateDirectAligned(512, 64));
frameType(termBuffer, 96, HDR_TYPE_DATA);
frameTermId(termBuffer, 96, 96);
frameLengthOrdered(termBuffer, 96, 64);
frameSessionId(termBuffer, 96, 96);
termBuffer.setMemory(96 + HEADER_LENGTH, 32, (byte) 96);
frameType(termBuffer, 160, HDR_TYPE_DATA);
frameTermId(termBuffer, 160, 160);
frameLengthOrdered(termBuffer, 160, 288);
frameSessionId(termBuffer, 160, 160);
termBuffer.setMemory(160 + HEADER_LENGTH, 256, (byte) 160);
recordingWriter.onBlock(termBuffer, 96, 352, -1, -1);
recordingWriter.close();
final File segmentFile = segmentFile(1, 0);
assertTrue(segmentFile.exists());
assertEquals(SEGMENT_LENGTH, segmentFile.length());
final UnsafeBuffer fileBuffer = new UnsafeBuffer();
fileBuffer.wrap(readAllBytes(segmentFile.toPath()));
assertEquals(HDR_TYPE_DATA, frameType(fileBuffer, 0));
assertEquals(96, frameTermId(fileBuffer, 0));
assertEquals(64, frameLength(fileBuffer, 0));
assertEquals(ctx.recordChecksum().compute(termBuffer.addressOffset(), 96 + HEADER_LENGTH, 32), frameSessionId(fileBuffer, 0));
assertEquals(HDR_TYPE_DATA, frameType(fileBuffer, 64));
assertEquals(160, frameTermId(fileBuffer, 64));
assertEquals(288, frameLength(fileBuffer, 64));
assertEquals(ctx.recordChecksum().compute(termBuffer.addressOffset(), 160 + HEADER_LENGTH, 256), frameSessionId(fileBuffer, 64));
// Ensure that the source buffer was not modified
assertEquals(96, frameSessionId(termBuffer, 96));
assertEquals(160, frameSessionId(termBuffer, 160));
}
Aggregations