HADOOP-18530. ChecksumFileSystem::readVectored might return byte buffers not positioned at 0 (#5168)

Contributed by Harshit Gupta
This commit is contained in:
HarshitGupta11 2022-11-29 20:21:22 +05:30 committed by GitHub
parent 35c65005d0
commit 0ef572abed
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 13 additions and 0 deletions

View File

@ -307,9 +307,16 @@ public final class VectoredReadUtils {
FileRange request) { FileRange request) {
int offsetChange = (int) (request.getOffset() - readOffset); int offsetChange = (int) (request.getOffset() - readOffset);
int requestLength = request.getLength(); int requestLength = request.getLength();
// Create a new buffer that is backed by the original contents
// The buffer will have position 0 and the same limit as the original one
readData = readData.slice(); readData = readData.slice();
// Change the offset and the limit of the buffer as the reader wants to see
// only relevant data
readData.position(offsetChange); readData.position(offsetChange);
readData.limit(offsetChange + requestLength); readData.limit(offsetChange + requestLength);
// Create a new buffer after the limit change so that only that portion of the data is
// returned to the reader.
readData = readData.slice();
return readData; return readData;
} }

View File

@ -61,6 +61,9 @@ public class TestVectoredReadUtils extends HadoopTestBase {
.describedAs("Slicing on the same offset shouldn't " + .describedAs("Slicing on the same offset shouldn't " +
"create a new buffer") "create a new buffer")
.isEqualTo(slice); .isEqualTo(slice);
Assertions.assertThat(slice.position())
.describedAs("Slicing should return buffers starting from position 0")
.isEqualTo(0);
// try slicing a range // try slicing a range
final int offset = 100; final int offset = 100;
@ -77,6 +80,9 @@ public class TestVectoredReadUtils extends HadoopTestBase {
.describedAs("Slicing should use the same underlying " + .describedAs("Slicing should use the same underlying " +
"data") "data")
.isEqualTo(slice.array()); .isEqualTo(slice.array());
Assertions.assertThat(slice.position())
.describedAs("Slicing should return buffers starting from position 0")
.isEqualTo(0);
// test the contents of the slice // test the contents of the slice
intBuffer = slice.asIntBuffer(); intBuffer = slice.asIntBuffer();
for(int i=0; i < sliceLength / Integer.BYTES; ++i) { for(int i=0; i < sliceLength / Integer.BYTES; ++i) {