ntdll/tests: Always wait until the operation completes if returned status is STATUS_PENDING.
This commit is contained in:
parent
911adfbb23
commit
d5fd04f2f0
@ -2363,12 +2363,14 @@ static void test_read_write(void)
|
|||||||
offset.QuadPart = 0;
|
offset.QuadPart = 0;
|
||||||
status = pNtWriteFile(hfile, 0, NULL, NULL, &iob, contents, sizeof(contents), &offset, NULL);
|
status = pNtWriteFile(hfile, 0, NULL, NULL, &iob, contents, sizeof(contents), &offset, NULL);
|
||||||
ok(status == STATUS_PENDING || status == STATUS_SUCCESS /* before Vista */, "expected STATUS_PENDING or STATUS_SUCCESS, got %#x\n", status);
|
ok(status == STATUS_PENDING || status == STATUS_SUCCESS /* before Vista */, "expected STATUS_PENDING or STATUS_SUCCESS, got %#x\n", status);
|
||||||
|
if (status == STATUS_PENDING)
|
||||||
|
{
|
||||||
|
ret = WaitForSingleObject(hfile, 3000);
|
||||||
|
ok(ret == WAIT_OBJECT_0, "WaitForSingleObject error %d\n", ret);
|
||||||
|
}
|
||||||
ok(U(iob).Status == STATUS_SUCCESS, "expected STATUS_SUCCESS, got %#x\n", U(iob).Status);
|
ok(U(iob).Status == STATUS_SUCCESS, "expected STATUS_SUCCESS, got %#x\n", U(iob).Status);
|
||||||
ok(iob.Information == sizeof(contents), "expected sizeof(contents), got %lu\n", iob.Information);
|
ok(iob.Information == sizeof(contents), "expected sizeof(contents), got %lu\n", iob.Information);
|
||||||
|
|
||||||
ret = WaitForSingleObject(hfile, 3000);
|
|
||||||
ok(ret == WAIT_OBJECT_0, "WaitForSingleObject error %d\n", ret);
|
|
||||||
|
|
||||||
off = SetFilePointer(hfile, 0, NULL, FILE_CURRENT);
|
off = SetFilePointer(hfile, 0, NULL, FILE_CURRENT);
|
||||||
ok(off == 0, "expected 0, got %u\n", off);
|
ok(off == 0, "expected 0, got %u\n", off);
|
||||||
|
|
||||||
@ -2501,6 +2503,8 @@ todo_wine
|
|||||||
status = pNtReadFile(hfile, 0, NULL, NULL, &iob, buf, sizeof(buf), &offset, NULL);
|
status = pNtReadFile(hfile, 0, NULL, NULL, &iob, buf, sizeof(buf), &offset, NULL);
|
||||||
if (status == STATUS_PENDING)
|
if (status == STATUS_PENDING)
|
||||||
{
|
{
|
||||||
|
ret = WaitForSingleObject(hfile, 3000);
|
||||||
|
ok(ret == WAIT_OBJECT_0, "WaitForSingleObject error %d\n", ret);
|
||||||
ok(U(iob).Status == STATUS_END_OF_FILE, "expected STATUS_END_OF_FILE, got %#x\n", U(iob).Status);
|
ok(U(iob).Status == STATUS_END_OF_FILE, "expected STATUS_END_OF_FILE, got %#x\n", U(iob).Status);
|
||||||
ok(iob.Information == 0, "expected 0, got %lu\n", iob.Information);
|
ok(iob.Information == 0, "expected 0, got %lu\n", iob.Information);
|
||||||
}
|
}
|
||||||
@ -2520,6 +2524,8 @@ todo_wine
|
|||||||
status = pNtReadFile(hfile, 0, NULL, NULL, &iob, buf, 0, &offset, NULL);
|
status = pNtReadFile(hfile, 0, NULL, NULL, &iob, buf, 0, &offset, NULL);
|
||||||
if (status == STATUS_PENDING)
|
if (status == STATUS_PENDING)
|
||||||
{
|
{
|
||||||
|
ret = WaitForSingleObject(hfile, 3000);
|
||||||
|
ok(ret == WAIT_OBJECT_0, "WaitForSingleObject error %d\n", ret);
|
||||||
ok(U(iob).Status == STATUS_SUCCESS, "expected STATUS_SUCCESS, got %#x\n", U(iob).Status);
|
ok(U(iob).Status == STATUS_SUCCESS, "expected STATUS_SUCCESS, got %#x\n", U(iob).Status);
|
||||||
ok(iob.Information == 0, "expected 0, got %lu\n", iob.Information);
|
ok(iob.Information == 0, "expected 0, got %lu\n", iob.Information);
|
||||||
}
|
}
|
||||||
@ -2574,31 +2580,33 @@ todo_wine
|
|||||||
offset.QuadPart = (LONGLONG)-1 /* FILE_WRITE_TO_END_OF_FILE */;
|
offset.QuadPart = (LONGLONG)-1 /* FILE_WRITE_TO_END_OF_FILE */;
|
||||||
status = pNtWriteFile(hfile, 0, NULL, NULL, &iob, "DCBA", 4, &offset, NULL);
|
status = pNtWriteFile(hfile, 0, NULL, NULL, &iob, "DCBA", 4, &offset, NULL);
|
||||||
ok(status == STATUS_PENDING || status == STATUS_SUCCESS /* before Vista */, "expected STATUS_PENDING or STATUS_SUCCESS, got %#x\n", status);
|
ok(status == STATUS_PENDING || status == STATUS_SUCCESS /* before Vista */, "expected STATUS_PENDING or STATUS_SUCCESS, got %#x\n", status);
|
||||||
|
if (status == STATUS_PENDING)
|
||||||
|
{
|
||||||
|
ret = WaitForSingleObject(hfile, 3000);
|
||||||
|
ok(ret == WAIT_OBJECT_0, "WaitForSingleObject error %d\n", ret);
|
||||||
|
}
|
||||||
ok(U(iob).Status == STATUS_SUCCESS, "expected STATUS_SUCCESS, got %#x\n", U(iob).Status);
|
ok(U(iob).Status == STATUS_SUCCESS, "expected STATUS_SUCCESS, got %#x\n", U(iob).Status);
|
||||||
ok(iob.Information == 4, "expected 4, got %lu\n", iob.Information);
|
ok(iob.Information == 4, "expected 4, got %lu\n", iob.Information);
|
||||||
|
|
||||||
off = SetFilePointer(hfile, 0, NULL, FILE_CURRENT);
|
off = SetFilePointer(hfile, 0, NULL, FILE_CURRENT);
|
||||||
ok(off == 0, "expected 0, got %u\n", off);
|
ok(off == 0, "expected 0, got %u\n", off);
|
||||||
|
|
||||||
ret = WaitForSingleObject(hfile, 3000);
|
|
||||||
ok(ret == WAIT_OBJECT_0, "WaitForSingleObject error %d\n", ret);
|
|
||||||
|
|
||||||
off = SetFilePointer(hfile, 0, NULL, FILE_CURRENT);
|
|
||||||
ok(off == 0, "expected 0, got %u\n", off);
|
|
||||||
|
|
||||||
U(iob).Status = -1;
|
U(iob).Status = -1;
|
||||||
iob.Information = -1;
|
iob.Information = -1;
|
||||||
offset.QuadPart = 0;
|
offset.QuadPart = 0;
|
||||||
status = pNtReadFile(hfile, 0, NULL, NULL, &iob, buf, sizeof(buf), &offset, NULL);
|
status = pNtReadFile(hfile, 0, NULL, NULL, &iob, buf, sizeof(buf), &offset, NULL);
|
||||||
ok(status == STATUS_PENDING || status == STATUS_SUCCESS, "expected STATUS_PENDING or STATUS_SUCCESS, got %#x\n", status);
|
ok(status == STATUS_PENDING || status == STATUS_SUCCESS, "expected STATUS_PENDING or STATUS_SUCCESS, got %#x\n", status);
|
||||||
|
if (status == STATUS_PENDING)
|
||||||
|
{
|
||||||
|
ret = WaitForSingleObject(hfile, 3000);
|
||||||
|
ok(ret == WAIT_OBJECT_0, "WaitForSingleObject error %d\n", ret);
|
||||||
|
}
|
||||||
ok(U(iob).Status == STATUS_SUCCESS, "expected STATUS_SUCCESS, got %#x\n", U(iob).Status);
|
ok(U(iob).Status == STATUS_SUCCESS, "expected STATUS_SUCCESS, got %#x\n", U(iob).Status);
|
||||||
ok(iob.Information == sizeof(contents), "expected sizeof(contents), got %lu\n", iob.Information);
|
ok(iob.Information == sizeof(contents), "expected sizeof(contents), got %lu\n", iob.Information);
|
||||||
|
|
||||||
off = SetFilePointer(hfile, 0, NULL, FILE_CURRENT);
|
off = SetFilePointer(hfile, 0, NULL, FILE_CURRENT);
|
||||||
ok(off == 0, "expected 0, got %u\n", off);
|
ok(off == 0, "expected 0, got %u\n", off);
|
||||||
|
|
||||||
ret = WaitForSingleObject(hfile, 3000);
|
|
||||||
ok(ret == WAIT_OBJECT_0, "WaitForSingleObject error %d\n", ret);
|
|
||||||
ok(!memcmp(contents, buf, sizeof(contents) - 4), "file contents mismatch\n");
|
ok(!memcmp(contents, buf, sizeof(contents) - 4), "file contents mismatch\n");
|
||||||
ok(!memcmp(buf + sizeof(contents) - 4, "DCBA", 4), "file contents mismatch\n");
|
ok(!memcmp(buf + sizeof(contents) - 4, "DCBA", 4), "file contents mismatch\n");
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user