Fix a stream parsing edge case (elastic/elasticsearch#413)
BytesReference doesn't like size 0 slices Original commit: elastic/x-pack-elasticsearch@20ef0d2c1f
This commit is contained in:
parent
5d2cc13797
commit
c99ee42f0e
|
@ -159,6 +159,9 @@ public class CppLogMessageHandler implements Closeable {
|
||||||
}
|
}
|
||||||
from = nextMarker + 1;
|
from = nextMarker + 1;
|
||||||
}
|
}
|
||||||
|
if (from >= bytesRef.length()) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
return bytesRef.slice(from, bytesRef.length() - from);
|
return bytesRef.slice(from, bytesRef.length() - from);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -64,6 +64,9 @@ public class StateProcessor extends AbstractComponent {
|
||||||
persister.persistBulkState(jobId, bytesRef.slice(from, nextZeroByte - from));
|
persister.persistBulkState(jobId, bytesRef.slice(from, nextZeroByte - from));
|
||||||
from = nextZeroByte + 1;
|
from = nextZeroByte + 1;
|
||||||
}
|
}
|
||||||
|
if (from >= bytesRef.length()) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
return bytesRef.slice(from, bytesRef.length() - from);
|
return bytesRef.slice(from, bytesRef.length() - from);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -35,14 +35,17 @@ public class CppLogMessageHandlerTests extends ESTestCase {
|
||||||
+ "{\"logger\":\"controller\",\"timestamp\":1478261169065,\"level\":\"DEBUG\",\"pid\":10211,\"thread\":\"0x7fff7d2a8000\","
|
+ "{\"logger\":\"controller\",\"timestamp\":1478261169065,\"level\":\"DEBUG\",\"pid\":10211,\"thread\":\"0x7fff7d2a8000\","
|
||||||
+ "\"message\":\"Prelert controller exiting\",\"method\":\"main\",\"file\":\"Main.cc\",\"line\":147}\n";
|
+ "\"message\":\"Prelert controller exiting\",\"method\":\"main\",\"file\":\"Main.cc\",\"line\":147}\n";
|
||||||
|
|
||||||
InputStream is = new ByteArrayInputStream(testData.getBytes(StandardCharsets.UTF_8));
|
// Try different buffer sizes to smoke out edge case problems in the buffer management
|
||||||
try (CppLogMessageHandler handler = new CppLogMessageHandler(is, "_id", 100, 3)) {
|
for (int readBufSize : new int[] { 11, 42, 101, 1024, 9999 }) {
|
||||||
handler.tailStream();
|
InputStream is = new ByteArrayInputStream(testData.getBytes(StandardCharsets.UTF_8));
|
||||||
|
try (CppLogMessageHandler handler = new CppLogMessageHandler(is, "_id", readBufSize, 3)) {
|
||||||
|
handler.tailStream();
|
||||||
|
|
||||||
assertTrue(handler.hasLogStreamEnded());
|
assertTrue(handler.hasLogStreamEnded());
|
||||||
assertEquals(10211L, handler.getPid(Duration.ofMillis(1)));
|
assertEquals(10211L, handler.getPid(Duration.ofMillis(1)));
|
||||||
assertEquals("Did not understand verb 'a'\n", handler.getErrors());
|
assertEquals("Did not understand verb 'a'\n", handler.getErrors());
|
||||||
assertFalse(handler.seenFatalError());
|
assertFalse(handler.seenFatalError());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue