mirror of https://gitlab.com/nakst/essence
add test for resizing files
This commit is contained in:
parent
259d904418
commit
7c4f131899
|
@ -1220,6 +1220,66 @@ bool RestartTest() {
|
|||
|
||||
//////////////////////////////////////////////////////////////
|
||||
|
||||
bool ResizeFileTest() {
|
||||
int checkIndex = 0;
|
||||
|
||||
size_t dataBytes = 2 + 2 * 4096 + 2 * 262144;
|
||||
uint8_t *data = (uint8_t *) EsHeapAllocate(dataBytes, false);
|
||||
uint8_t *compare = (uint8_t *) EsHeapAllocate(dataBytes, false);
|
||||
EsFileOffset currentSize = 0;
|
||||
|
||||
// Make a list of all the file sizes that should cover the interesting cases.
|
||||
|
||||
EsFileOffset sizes[125];
|
||||
size_t sizeCount = 0;
|
||||
|
||||
for (int i = -2; i <= 2; i++) {
|
||||
for (int j = -2; j <= 2; j++) {
|
||||
for (int k = -2; k <= 2; k++) {
|
||||
EsFileOffsetDifference size = k + j * 4096 /* page size */ + i * 262144 /* active section size */;
|
||||
if (size < 0) continue;
|
||||
EsAssert(sizeCount != sizeof(sizes) / sizeof(sizes[0]));
|
||||
EsAssert((uintptr_t) size <= dataBytes);
|
||||
sizes[sizeCount++] = size;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
EsFileInformation file = EsFileOpen(EsLiteral("0:/resize.txt"), ES_FILE_WRITE | ES_NODE_FAIL_IF_FOUND);
|
||||
CHECK(file.error == ES_SUCCESS);
|
||||
|
||||
for (uintptr_t i = 0; i < sizeCount; i++) {
|
||||
for (uintptr_t j = 0; j < sizeCount; j++) {
|
||||
EsPrint("i %x, j %x\n", sizes[i], sizes[j]);
|
||||
|
||||
CHECK(ES_SUCCESS == EsFileResize(file.handle, sizes[i]));
|
||||
if (sizes[i] > currentSize) EsMemoryZero(data + currentSize, sizes[i] - currentSize);
|
||||
currentSize = sizes[i];
|
||||
CHECK(currentSize == EsFileReadSync(file.handle, 0, dataBytes, compare));
|
||||
CHECK(0 == EsMemoryCompare(data, compare, currentSize));
|
||||
|
||||
CHECK(ES_SUCCESS == EsFileResize(file.handle, sizes[j]));
|
||||
if (sizes[j] > currentSize) EsMemoryZero(data + currentSize, sizes[j] - currentSize);
|
||||
currentSize = sizes[j];
|
||||
CHECK(currentSize == EsFileReadSync(file.handle, 0, dataBytes, compare));
|
||||
CHECK(0 == EsMemoryCompare(data, compare, currentSize));
|
||||
|
||||
for (uintptr_t k = 0; k < currentSize; k++) {
|
||||
data[k] = EsRandomU8();
|
||||
}
|
||||
|
||||
EsFileWriteSync(file.handle, 0, currentSize, data);
|
||||
}
|
||||
}
|
||||
|
||||
EsHandleClose(file.handle);
|
||||
EsHeapFree(data);
|
||||
EsHeapFree(compare);
|
||||
return true;
|
||||
}
|
||||
|
||||
//////////////////////////////////////////////////////////////
|
||||
|
||||
#endif
|
||||
|
||||
const Test tests[] = {
|
||||
|
@ -1237,6 +1297,7 @@ const Test tests[] = {
|
|||
TEST(PipeTests, 60),
|
||||
TEST(POSIXSubsystemTest, 60),
|
||||
TEST(RestartTest, 600),
|
||||
TEST(ResizeFileTest, 600),
|
||||
};
|
||||
|
||||
#ifndef API_TESTS_FOR_RUNNER
|
||||
|
|
Loading…
Reference in New Issue