mirror of
https://github.com/winfsp/winfsp.git
synced 2025-04-22 16:33:02 -05:00
tst: winfsp-tests: IRP timeout testing
This commit is contained in:
parent
460c4e0c55
commit
f099fe4bff
@ -177,6 +177,7 @@
|
|||||||
<WarningLevel Condition="'$(Configuration)|$(Platform)'=='Release|x64'">TurnOffAllWarnings</WarningLevel>
|
<WarningLevel Condition="'$(Configuration)|$(Platform)'=='Release|x64'">TurnOffAllWarnings</WarningLevel>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<ClCompile Include="..\..\..\tst\winfsp-tests\mount-test.c" />
|
<ClCompile Include="..\..\..\tst\winfsp-tests\mount-test.c" />
|
||||||
|
<ClCompile Include="..\..\..\tst\winfsp-tests\timeout-test.c" />
|
||||||
<ClCompile Include="..\..\..\tst\winfsp-tests\winfsp-tests.c" />
|
<ClCompile Include="..\..\..\tst\winfsp-tests\winfsp-tests.c" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
@ -19,6 +19,9 @@
|
|||||||
<ClCompile Include="..\..\..\ext\tlib\testsuite.c">
|
<ClCompile Include="..\..\..\ext\tlib\testsuite.c">
|
||||||
<Filter>Source\tlib</Filter>
|
<Filter>Source\tlib</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\..\..\tst\winfsp-tests\timeout-test.c">
|
||||||
|
<Filter>Source</Filter>
|
||||||
|
</ClCompile>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClInclude Include="..\..\..\ext\tlib\testsuite.h">
|
<ClInclude Include="..\..\..\ext\tlib\testsuite.h">
|
||||||
|
169
tst/winfsp-tests/timeout-test.c
Normal file
169
tst/winfsp-tests/timeout-test.c
Normal file
@ -0,0 +1,169 @@
|
|||||||
|
#include <winfsp/winfsp.h>
|
||||||
|
#include <tlib/testsuite.h>
|
||||||
|
#include <process.h>
|
||||||
|
#include <strsafe.h>
|
||||||
|
|
||||||
|
extern int WinFspDiskTests;
|
||||||
|
extern int WinFspNetTests;
|
||||||
|
|
||||||
|
static unsigned __stdcall timeout_pending_dotest_thread(void *FilePath)
|
||||||
|
{
|
||||||
|
FspDebugLog(__FUNCTION__ ": \"%S\"\n", FilePath);
|
||||||
|
|
||||||
|
HANDLE Handle;
|
||||||
|
Handle = CreateFileW(FilePath,
|
||||||
|
FILE_GENERIC_READ, FILE_SHARE_READ | FILE_SHARE_WRITE, 0, CREATE_NEW, FILE_ATTRIBUTE_NORMAL, 0);
|
||||||
|
if (INVALID_HANDLE_VALUE == Handle)
|
||||||
|
return GetLastError();
|
||||||
|
CloseHandle(Handle);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void timeout_pending_dotest(PWSTR DeviceName)
|
||||||
|
{
|
||||||
|
NTSTATUS Result;
|
||||||
|
BOOL Success;
|
||||||
|
FSP_FSCTL_VOLUME_PARAMS Params = { 0 };
|
||||||
|
WCHAR VolumePath[MAX_PATH];
|
||||||
|
WCHAR FilePath[MAX_PATH];
|
||||||
|
HANDLE VolumeHandle;
|
||||||
|
HANDLE Thread;
|
||||||
|
DWORD ExitCode;
|
||||||
|
|
||||||
|
Params.SectorSize = 16384;
|
||||||
|
Params.SerialNumber = 0x12345678;
|
||||||
|
Params.IrpTimeout = FspFsctlIrpTimeoutDebug;
|
||||||
|
Result = FspFsctlCreateVolume(DeviceName, &Params, 0, VolumePath, sizeof VolumePath);
|
||||||
|
ASSERT(STATUS_SUCCESS == Result);
|
||||||
|
|
||||||
|
StringCbPrintfW(FilePath, sizeof FilePath, L"\\\\?\\GLOBALROOT%s\\file0", VolumePath);
|
||||||
|
Thread = (HANDLE)_beginthreadex(0, 0, timeout_pending_dotest_thread, FilePath, 0, 0);
|
||||||
|
ASSERT(0 != Thread);
|
||||||
|
|
||||||
|
WaitForSingleObject(Thread, INFINITE);
|
||||||
|
GetExitCodeThread(Thread, &ExitCode);
|
||||||
|
CloseHandle(Thread);
|
||||||
|
|
||||||
|
ASSERT(ERROR_OPERATION_ABORTED == ExitCode);
|
||||||
|
|
||||||
|
Result = FspFsctlOpenVolume(VolumePath, &VolumeHandle);
|
||||||
|
ASSERT(STATUS_SUCCESS == Result);
|
||||||
|
|
||||||
|
Result = FspFsctlDeleteVolume(VolumeHandle);
|
||||||
|
ASSERT(STATUS_SUCCESS == Result);
|
||||||
|
|
||||||
|
Success = CloseHandle(VolumeHandle);
|
||||||
|
ASSERT(Success);
|
||||||
|
}
|
||||||
|
|
||||||
|
void timeout_pending_test(void)
|
||||||
|
{
|
||||||
|
if (WinFspDiskTests)
|
||||||
|
timeout_pending_dotest(L"WinFsp.Disk");
|
||||||
|
if (WinFspNetTests)
|
||||||
|
timeout_pending_dotest(L"WinFsp.Net");
|
||||||
|
}
|
||||||
|
|
||||||
|
static unsigned __stdcall timeout_transact_dotest_thread(void *FilePath)
|
||||||
|
{
|
||||||
|
FspDebugLog(__FUNCTION__ ": \"%S\"\n", FilePath);
|
||||||
|
|
||||||
|
Sleep(1000);
|
||||||
|
|
||||||
|
HANDLE Handle;
|
||||||
|
Handle = CreateFileW(FilePath,
|
||||||
|
FILE_GENERIC_READ, FILE_SHARE_READ | FILE_SHARE_WRITE, 0, CREATE_NEW, FILE_ATTRIBUTE_NORMAL, 0);
|
||||||
|
if (INVALID_HANDLE_VALUE == Handle)
|
||||||
|
return GetLastError();
|
||||||
|
CloseHandle(Handle);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void timeout_transact_dotest(PWSTR DeviceName)
|
||||||
|
{
|
||||||
|
NTSTATUS Result;
|
||||||
|
BOOL Success;
|
||||||
|
FSP_FSCTL_VOLUME_PARAMS Params = { 0 };
|
||||||
|
WCHAR VolumePath[MAX_PATH];
|
||||||
|
WCHAR FilePath[MAX_PATH];
|
||||||
|
HANDLE VolumeHandle;
|
||||||
|
HANDLE Thread;
|
||||||
|
DWORD ExitCode;
|
||||||
|
|
||||||
|
Params.SectorSize = 16384;
|
||||||
|
Params.SerialNumber = 0x12345678;
|
||||||
|
Params.TransactTimeout = 2000;
|
||||||
|
Params.IrpTimeout = FspFsctlIrpTimeoutDebug;
|
||||||
|
Result = FspFsctlCreateVolume(DeviceName, &Params, 0, VolumePath, sizeof VolumePath);
|
||||||
|
ASSERT(STATUS_SUCCESS == Result);
|
||||||
|
|
||||||
|
StringCbPrintfW(FilePath, sizeof FilePath, L"\\\\?\\GLOBALROOT%s\\file0", VolumePath);
|
||||||
|
Thread = (HANDLE)_beginthreadex(0, 0, timeout_transact_dotest_thread, FilePath, 0, 0);
|
||||||
|
ASSERT(0 != Thread);
|
||||||
|
|
||||||
|
Result = FspFsctlOpenVolume(VolumePath, &VolumeHandle);
|
||||||
|
ASSERT(STATUS_SUCCESS == Result);
|
||||||
|
|
||||||
|
FSP_FSCTL_DECLSPEC_ALIGN UINT8 RequestBuf[FSP_FSCTL_TRANSACT_REQ_BUFFER_SIZEMIN];
|
||||||
|
FSP_FSCTL_DECLSPEC_ALIGN UINT8 ResponseBuf[FSP_FSCTL_TRANSACT_RSP_BUFFER_SIZEMIN];
|
||||||
|
UINT8 *RequestBufEnd;
|
||||||
|
UINT8 *ResponseBufEnd = ResponseBuf + sizeof ResponseBuf;
|
||||||
|
SIZE_T RequestBufSize;
|
||||||
|
SIZE_T ResponseBufSize;
|
||||||
|
FSP_FSCTL_TRANSACT_REQ *Request = (PVOID)RequestBuf, *NextRequest;
|
||||||
|
FSP_FSCTL_TRANSACT_RSP *Response = (PVOID)ResponseBuf;
|
||||||
|
|
||||||
|
ResponseBufSize = 0;
|
||||||
|
RequestBufSize = sizeof RequestBuf;
|
||||||
|
Result = FspFsctlTransact(VolumeHandle, ResponseBuf, ResponseBufSize, RequestBuf, &RequestBufSize);
|
||||||
|
ASSERT(STATUS_SUCCESS == Result);
|
||||||
|
|
||||||
|
RequestBufEnd = RequestBuf + RequestBufSize;
|
||||||
|
|
||||||
|
NextRequest = FspFsctlTransactConsumeRequest(Request, RequestBufEnd);
|
||||||
|
ASSERT(0 != NextRequest);
|
||||||
|
|
||||||
|
ASSERT(0 == Request->Version);
|
||||||
|
ASSERT(FSP_FSCTL_TRANSACT_REQ_SIZEMAX >= Request->Size);
|
||||||
|
ASSERT(0 != Request->Hint);
|
||||||
|
ASSERT(FspFsctlTransactCreateKind == Request->Kind);
|
||||||
|
ASSERT(FILE_CREATE == ((Request->Req.Create.CreateOptions >> 24) & 0xff));
|
||||||
|
ASSERT(FILE_ATTRIBUTE_NORMAL == Request->Req.Create.FileAttributes);
|
||||||
|
ASSERT(0 == Request->Req.Create.SecurityDescriptor.Offset);
|
||||||
|
ASSERT(0 == Request->Req.Create.SecurityDescriptor.Size);
|
||||||
|
ASSERT(0 == Request->Req.Create.AllocationSize);
|
||||||
|
ASSERT(FILE_GENERIC_READ == Request->Req.Create.DesiredAccess);
|
||||||
|
ASSERT((FILE_SHARE_READ | FILE_SHARE_WRITE) == Request->Req.Create.ShareAccess);
|
||||||
|
ASSERT(0 == Request->Req.Create.Ea.Offset);
|
||||||
|
ASSERT(0 == Request->Req.Create.Ea.Size);
|
||||||
|
ASSERT(Request->Req.Create.UserMode);
|
||||||
|
ASSERT(Request->Req.Create.HasTraversePrivilege);
|
||||||
|
ASSERT(!Request->Req.Create.OpenTargetDirectory);
|
||||||
|
ASSERT(!Request->Req.Create.CaseSensitive);
|
||||||
|
|
||||||
|
WaitForSingleObject(Thread, INFINITE);
|
||||||
|
GetExitCodeThread(Thread, &ExitCode);
|
||||||
|
CloseHandle(Thread);
|
||||||
|
|
||||||
|
ASSERT(ERROR_OPERATION_ABORTED == ExitCode);
|
||||||
|
|
||||||
|
Result = FspFsctlDeleteVolume(VolumeHandle);
|
||||||
|
ASSERT(STATUS_SUCCESS == Result);
|
||||||
|
|
||||||
|
Success = CloseHandle(VolumeHandle);
|
||||||
|
ASSERT(Success);
|
||||||
|
}
|
||||||
|
|
||||||
|
void timeout_transact_test(void)
|
||||||
|
{
|
||||||
|
if (WinFspDiskTests)
|
||||||
|
timeout_transact_dotest(L"WinFsp.Disk");
|
||||||
|
if (WinFspNetTests)
|
||||||
|
timeout_transact_dotest(L"WinFsp.Net");
|
||||||
|
}
|
||||||
|
|
||||||
|
void timeout_tests(void)
|
||||||
|
{
|
||||||
|
TEST(timeout_pending_test);
|
||||||
|
TEST(timeout_transact_test);
|
||||||
|
}
|
@ -6,6 +6,8 @@ int WinFspNetTests = 0;
|
|||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
TESTSUITE(mount_tests);
|
TESTSUITE(mount_tests);
|
||||||
|
TESTSUITE(timeout_tests);
|
||||||
|
|
||||||
tlib_run_tests(argc, argv);
|
tlib_run_tests(argc, argv);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user