|
35 | 35 | import org.apache.hadoop.test.HadoopTestBase; |
36 | 36 |
|
37 | 37 | import static org.apache.hadoop.fs.VectoredReadUtils.sortRanges; |
| 38 | +import static org.apache.hadoop.fs.VectoredReadUtils.validateNonOverlappingAndReturnSortedRanges; |
| 39 | +import static org.apache.hadoop.test.LambdaTestUtils.intercept; |
38 | 40 | import static org.apache.hadoop.test.MoreAsserts.assertFutureCompletedSuccessfully; |
39 | 41 | import static org.apache.hadoop.test.MoreAsserts.assertFutureFailedExceptionally; |
40 | 42 |
|
@@ -231,6 +233,36 @@ public void testSortAndMergeMoreCases() throws Exception { |
231 | 233 |
|
232 | 234 | } |
233 | 235 |
|
| 236 | + @Test |
| 237 | + public void testValidateOverlappingRanges() throws Exception { |
| 238 | + List<FileRange> input = Arrays.asList( |
| 239 | + FileRange.createFileRange(100, 100), |
| 240 | + FileRange.createFileRange(200, 100), |
| 241 | + FileRange.createFileRange(250, 100) |
| 242 | + ); |
| 243 | + |
| 244 | + intercept(UnsupportedOperationException.class, |
| 245 | + () -> validateNonOverlappingAndReturnSortedRanges(input)); |
| 246 | + |
| 247 | + List<FileRange> input1 = Arrays.asList( |
| 248 | + FileRange.createFileRange(100, 100), |
| 249 | + FileRange.createFileRange(500, 100), |
| 250 | + FileRange.createFileRange(1000, 100), |
| 251 | + FileRange.createFileRange(1000, 100) |
| 252 | + ); |
| 253 | + |
| 254 | + intercept(UnsupportedOperationException.class, |
| 255 | + () -> validateNonOverlappingAndReturnSortedRanges(input1)); |
| 256 | + |
| 257 | + List<FileRange> input2 = Arrays.asList( |
| 258 | + FileRange.createFileRange(100, 100), |
| 259 | + FileRange.createFileRange(200, 100), |
| 260 | + FileRange.createFileRange(300, 100) |
| 261 | + ); |
| 262 | + // consecutive ranges should pass. |
| 263 | + validateNonOverlappingAndReturnSortedRanges(input2); |
| 264 | + } |
| 265 | + |
234 | 266 | @Test |
235 | 267 | public void testMaxSizeZeroDisablesMering() throws Exception { |
236 | 268 | List<FileRange> randomRanges = Arrays.asList( |
|
0 commit comments