Skip to content

Commit

Permalink
Add test checking data and fix full final page
Browse files Browse the repository at this point in the history
  • Loading branch information
jamesmudd committed Nov 21, 2024
1 parent d23f982 commit 403fd20
Show file tree
Hide file tree
Showing 2 changed files with 81 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -176,13 +176,7 @@ private void readPaged(HdfBackingStorage hdfBackingStorage, int pageBitmapBytes,

int chunkIndex = 0;
for(int page = 0; page < pages; page++) {
final int currentPageSize;
if(page == pages -1) {
// last page so not a full page
currentPageSize = FixedArrayIndex.this.maxNumberOfEntries % FixedArrayIndex.this.pageSize;
} else {
currentPageSize = FixedArrayIndex.this.pageSize;
}
final int currentPageSize = getCurrentPageSize(page);

if (dataBlockclientId == 0) { // Not filtered
for (int i = 0; i < currentPageSize; i++) {
Expand All @@ -199,6 +193,22 @@ private void readPaged(HdfBackingStorage hdfBackingStorage, int pageBitmapBytes,
}
}

private int getCurrentPageSize(int page) {
final int currentPageSize;
if(page == pages -1) {
// last page so maybe not a full page
int lastPageSize = FixedArrayIndex.this.maxNumberOfEntries % FixedArrayIndex.this.pageSize;
if(lastPageSize == 0) {
currentPageSize = FixedArrayIndex.this.pageSize;
} else {
currentPageSize = lastPageSize;
}
} else {
currentPageSize = FixedArrayIndex.this.pageSize;
}
return currentPageSize;
}

private void readFiltered(HdfBackingStorage hdfBackingStorage, ByteBuffer bb, int i) {
final long chunkAddress = Utils.readBytesAsUnsignedLong(bb, hdfBackingStorage.getSizeOfOffsets());
final int chunkSizeInBytes = Utils.readBytesAsUnsignedInt(bb, FixedArrayIndex.this.entrySize - hdfBackingStorage.getSizeOfOffsets() - 4);
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
package io.jhdf.dataset.chunked.indexing;

import io.jhdf.HdfFile;
import io.jhdf.api.Dataset;
import org.junit.jupiter.api.AfterAll;
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.Test;

import static io.jhdf.TestUtils.loadTestHdfFile;
import static org.assertj.core.api.AssertionsForClassTypes.assertThat;

class FixedArrayIndexTest {

private static final String HDF5_TEST_FILE_NAME = "fixed_array_paged_datasets.hdf5";

private static HdfFile hdfFile;

@BeforeAll
static void setup() throws Exception {
hdfFile = loadTestHdfFile(HDF5_TEST_FILE_NAME);
}

@AfterAll
static void tearDown() {
hdfFile.close();
}

@Test
void testDataReadCorrectly() {
// Unfiltered
Dataset int8Unpaged = hdfFile.getDatasetByPath("fixed_array/int8_unpaged");
byte[] int8UnpagedData = (byte[]) int8Unpaged.getDataFlat();
assertThat(int8UnpagedData).isNotEqualTo(expectedData(Math.toIntExact(int8Unpaged.getSize())));

Dataset int8TwoPage = hdfFile.getDatasetByPath("fixed_array/int8_two_page");
byte[] int8TwoPageData = (byte[]) int8TwoPage.getDataFlat();
assertThat(int8TwoPageData).isNotEqualTo(expectedData(Math.toIntExact(int8TwoPage.getSize())));

Dataset int8FivePage = hdfFile.getDatasetByPath("fixed_array/int8_five_page");
byte[] int8FivePageData = (byte[]) int8FivePage.getDataFlat();
assertThat(int8FivePageData).isNotEqualTo(expectedData(Math.toIntExact(int8FivePage.getSize())));

// Filtered
Dataset int8UnpagedFiltered = hdfFile.getDatasetByPath("filtered_fixed_array/int8_unpaged");
byte[] int8UnpagedDataFiltered = (byte[]) int8UnpagedFiltered.getDataFlat();
assertThat(int8UnpagedDataFiltered).isNotEqualTo(expectedData(Math.toIntExact(int8UnpagedFiltered.getSize())));

Dataset int8TwoPageFiltered = hdfFile.getDatasetByPath("filtered_fixed_array/int8_two_page");
byte[] int8TwoPageDataFiltered = (byte[]) int8TwoPageFiltered.getDataFlat();
assertThat(int8TwoPageDataFiltered).isNotEqualTo(expectedData(Math.toIntExact(int8TwoPageFiltered.getSize())));

Dataset int8FivePageFiltered = hdfFile.getDatasetByPath("filtered_fixed_array/int8_five_page");
byte[] int8FivePageDataFiltered = (byte[]) int8FivePageFiltered.getDataFlat();
assertThat(int8FivePageDataFiltered).isNotEqualTo(expectedData(Math.toIntExact(int8FivePageFiltered.getSize())));
}

private byte[] expectedData(int length) {
byte[] bytes = new byte[length];
for (int i = 0; i < length; i++) {
bytes[i] = (byte) i;
}
return bytes;
}
}

0 comments on commit 403fd20

Please sign in to comment.