2014-04-20 18:15:41 +00:00
|
|
|
/*
|
|
|
|
* PROJECT: ReactOS API Tests
|
|
|
|
* LICENSE: GPLv2+ - See COPYING in the top level directory
|
|
|
|
* PURPOSE: NtQueryVolumeInformationFile tests
|
|
|
|
* PROGRAMMER: Víctor Martínez Calvo <vicmarcal@gmail.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define WIN32_NO_STATUS
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <wine/test.h>
|
|
|
|
#include <ndk/ntndk.h>
|
|
|
|
|
2015-06-16 11:33:35 +00:00
|
|
|
static
|
|
|
|
VOID
|
|
|
|
TestFileFsDeviceInformation(HANDLE handle)
|
2014-04-20 18:15:41 +00:00
|
|
|
{
|
|
|
|
IO_STATUS_BLOCK IoStatusBlock;
|
|
|
|
FILE_FS_DEVICE_INFORMATION FileFsDevice;
|
|
|
|
NTSTATUS status;
|
|
|
|
|
|
|
|
/*Testing VALID handle, with NULL IN parameters*/
|
|
|
|
SetLastError(0xdeadb33f);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, NULL, &FileFsDevice, sizeof(FILE_FS_DEVICE_INFORMATION), FileFsDeviceInformation);
|
|
|
|
ok(status == STATUS_ACCESS_VIOLATION, "Expected STATUS_ACCESS_VIOLATION, got 0x%lx\n", status);
|
|
|
|
ok(GetLastError() == 0xdeadb33f, "Expected 0xdeadb33f, got %lx\n", GetLastError());
|
|
|
|
|
|
|
|
SetLastError(0xcacacaca);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, NULL, sizeof(FILE_FS_DEVICE_INFORMATION), FileFsDeviceInformation);
|
|
|
|
ok(status == STATUS_ACCESS_VIOLATION, "Expected STATUS_ACCESS_VIOLATION, got 0x%lx\n", status);
|
|
|
|
ok(GetLastError() == 0xcacacaca, "Expected 0xcacacaca, got %lx\n", GetLastError());
|
|
|
|
|
|
|
|
SetLastError(0xdadadada);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, &FileFsDevice, 0, FileFsDeviceInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Expected STATUS_INFO_LENGTH_MISMATCH, got 0x%lx\n", status);
|
|
|
|
ok(GetLastError() == 0xdadadada, "Expected 0xdadadada, got %lx\n", GetLastError());
|
|
|
|
|
|
|
|
/*All valid, invalid FsInformationClass value.*/
|
|
|
|
SetLastError(0xdeadbeef);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, &FileFsDevice, sizeof(FILE_FS_DEVICE_INFORMATION), 0);
|
|
|
|
ok(status == STATUS_INVALID_INFO_CLASS, "Expected STATUS_INVALID_INFO_CLASS, got 0x%lx\n", status);
|
|
|
|
ok(GetLastError() == 0xdeadbeef, "Expected 0xdeadbeef, got %lx\n", GetLastError());
|
|
|
|
|
|
|
|
/*Testing NULL handle*/
|
|
|
|
SetLastError(0xdeadbeef);
|
|
|
|
status = NtQueryVolumeInformationFile(NULL, &IoStatusBlock, &FileFsDevice, sizeof(FILE_FS_DEVICE_INFORMATION), FileFsDeviceInformation);
|
|
|
|
ok(status == STATUS_INVALID_HANDLE, "Expected STATUS_INVALID_HANDLE, got 0x%lx\n", status);
|
|
|
|
ok(GetLastError() == 0xdeadbeef, "Expected 0xdeadbeef, got %lx\n", GetLastError());
|
|
|
|
|
|
|
|
/*Testing INVALID_HANDLE_VALUE*/
|
|
|
|
SetLastError(0xdeaddead);
|
|
|
|
status = NtQueryVolumeInformationFile((HANDLE)(-1), &IoStatusBlock, &FileFsDevice, sizeof(FILE_FS_DEVICE_INFORMATION), FileFsDeviceInformation);
|
|
|
|
ok(status == STATUS_OBJECT_TYPE_MISMATCH, "Expected STATUS_OBJECT_TYPE_MISMATCH, got 0x%lx\n", status);
|
|
|
|
ok(GetLastError() == 0xdeaddead, "Expected 0xdeaddead, got %lx\n", GetLastError());
|
|
|
|
|
2015-06-16 11:33:35 +00:00
|
|
|
/*Almost all NULL. Then it checks against the Length!*/
|
|
|
|
SetLastError(0xdeadbeef);
|
|
|
|
status = NtQueryVolumeInformationFile(NULL, NULL, NULL, 0, FileFsDeviceInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Expected STATUS_INFO_LENGTH_MISMATCH, got 0x%lx\n", status);
|
|
|
|
ok(GetLastError() == 0xdeadbeef, "Expected 0xdeadbeef, got %lx\n", GetLastError());
|
|
|
|
}
|
|
|
|
|
|
|
|
static
|
|
|
|
VOID
|
|
|
|
TestFileFsVolumeInformation(HANDLE handle)
|
|
|
|
{
|
|
|
|
IO_STATUS_BLOCK IoStatusBlock;
|
|
|
|
ULONG Buffer[(sizeof(FILE_FS_VOLUME_INFORMATION) + MAX_PATH * sizeof(WCHAR)) / sizeof(ULONG)];
|
|
|
|
PFILE_FS_VOLUME_INFORMATION VolumeInfo = (PFILE_FS_VOLUME_INFORMATION)Buffer;
|
|
|
|
NTSTATUS status;
|
|
|
|
|
|
|
|
status = NtQueryVolumeInformationFile(handle, NULL, NULL, 0, FileFsVolumeInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Got status 0x%lx\n", status);
|
|
|
|
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, NULL, 0, FileFsVolumeInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == 0x55555555, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(IoStatusBlock.Information == (ULONG_PTR)0x5555555555555555, "IoStatusBlock.Information = %Iu\n", IoStatusBlock.Information);
|
|
|
|
|
|
|
|
status = NtQueryVolumeInformationFile(handle, NULL, VolumeInfo, 0, FileFsVolumeInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Got status 0x%lx\n", status);
|
|
|
|
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, (PUCHAR)Buffer + 2, sizeof(FILE_FS_VOLUME_INFORMATION), FileFsVolumeInformation);
|
|
|
|
ok(status == STATUS_DATATYPE_MISALIGNMENT, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == 0x55555555, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(IoStatusBlock.Information == (ULONG_PTR)0x5555555555555555, "IoStatusBlock.Information = %Iu\n", IoStatusBlock.Information);
|
|
|
|
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, VolumeInfo, 0, FileFsVolumeInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == 0x55555555, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(IoStatusBlock.Information == (ULONG_PTR)0x5555555555555555, "IoStatusBlock.Information = %Iu\n", IoStatusBlock.Information);
|
|
|
|
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, VolumeInfo, FIELD_OFFSET(FILE_FS_VOLUME_INFORMATION, VolumeLabel), FileFsVolumeInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == 0x55555555, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(IoStatusBlock.Information == (ULONG_PTR)0x5555555555555555, "IoStatusBlock.Information = %Iu\n", IoStatusBlock.Information);
|
|
|
|
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, VolumeInfo, sizeof(FILE_FS_VOLUME_INFORMATION) - 1, FileFsVolumeInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == 0x55555555, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(IoStatusBlock.Information == (ULONG_PTR)0x5555555555555555, "IoStatusBlock.Information = %Iu\n", IoStatusBlock.Information);
|
|
|
|
|
|
|
|
RtlFillMemory(Buffer, sizeof(Buffer), 0x55);
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, VolumeInfo, sizeof(FILE_FS_VOLUME_INFORMATION), FileFsVolumeInformation);
|
|
|
|
ok(status == STATUS_SUCCESS || status == STATUS_BUFFER_OVERFLOW, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == status, "IoStatusBlock.Status = 0x%lx, expected 0x%lx\n", IoStatusBlock.Status, status);
|
|
|
|
if (status == STATUS_SUCCESS)
|
|
|
|
{
|
|
|
|
ok(VolumeInfo->VolumeLabelLength <= sizeof(FILE_FS_VOLUME_INFORMATION) - FIELD_OFFSET(FILE_FS_VOLUME_INFORMATION, VolumeLabel),
|
|
|
|
"VolumeInfo->VolumeLabelLength = %Iu\n", VolumeInfo->VolumeLabelLength);
|
|
|
|
ok(IoStatusBlock.Information >= FIELD_OFFSET(FILE_FS_VOLUME_INFORMATION, VolumeLabel),
|
|
|
|
"IoStatusBlock.Information = %Iu, expected >=%lu\n", IoStatusBlock.Information, (ULONG)FIELD_OFFSET(FILE_FS_VOLUME_INFORMATION, VolumeLabel));
|
|
|
|
ok(IoStatusBlock.Information <= sizeof(FILE_FS_VOLUME_INFORMATION),
|
|
|
|
"IoStatusBlock.Information = %Iu, expected <=%lu\n", IoStatusBlock.Information, (ULONG)sizeof(FILE_FS_VOLUME_INFORMATION));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
ok(VolumeInfo->VolumeLabelLength > sizeof(FILE_FS_VOLUME_INFORMATION) - FIELD_OFFSET(FILE_FS_VOLUME_INFORMATION, VolumeLabel),
|
|
|
|
"VolumeInfo->VolumeLabelLength = %Iu\n", VolumeInfo->VolumeLabelLength);
|
|
|
|
ok(IoStatusBlock.Information == sizeof(FILE_FS_VOLUME_INFORMATION),
|
|
|
|
"IoStatusBlock.Information = %Iu, expected %lu\n", IoStatusBlock.Information, (ULONG)sizeof(FILE_FS_VOLUME_INFORMATION));
|
|
|
|
}
|
|
|
|
ok(VolumeInfo->VolumeLabel[VolumeInfo->VolumeLabelLength / sizeof(WCHAR)] == 0x5555,
|
|
|
|
"Got %x\n", VolumeInfo->VolumeLabel[VolumeInfo->VolumeLabelLength / sizeof(WCHAR)]);
|
|
|
|
|
|
|
|
RtlFillMemory(Buffer, sizeof(Buffer), 0x55);
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, VolumeInfo, sizeof(Buffer), FileFsVolumeInformation);
|
|
|
|
ok(status == STATUS_SUCCESS, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == STATUS_SUCCESS, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
2015-06-17 06:54:17 +00:00
|
|
|
ok(IoStatusBlock.Information == FIELD_OFFSET(FILE_FS_VOLUME_INFORMATION, VolumeLabel) + VolumeInfo->VolumeLabelLength,
|
|
|
|
"IoStatusBlock.Information = %Iu, expected %lu+%lu\n", IoStatusBlock.Information, (ULONG)FIELD_OFFSET(FILE_FS_VOLUME_INFORMATION, VolumeLabel), VolumeInfo->VolumeLabelLength);
|
2015-06-16 11:33:35 +00:00
|
|
|
ok(VolumeInfo->VolumeCreationTime.QuadPart != 0x5555555555555555, "VolumeInfo->VolumeCreationTime = %I64d\n", VolumeInfo->VolumeCreationTime.QuadPart);
|
2015-06-16 11:40:51 +00:00
|
|
|
ok(VolumeInfo->VolumeSerialNumber != 0x55555555, "VolumeInfo->VolumeSerialNumber = %lu\n", VolumeInfo->VolumeSerialNumber);
|
2015-06-16 11:33:35 +00:00
|
|
|
ok(VolumeInfo->SupportsObjects == FALSE || VolumeInfo->SupportsObjects == TRUE, "VolumeInfo->SupportsObjects = %u\n", VolumeInfo->SupportsObjects);
|
|
|
|
ok(VolumeInfo->VolumeLabelLength % sizeof(WCHAR) == 0, "VolumeInfo->VolumeLabelLength = %Iu\n", VolumeInfo->VolumeLabelLength);
|
|
|
|
if (VolumeInfo->VolumeLabelLength >= sizeof(WCHAR))
|
|
|
|
ok(VolumeInfo->VolumeLabel[VolumeInfo->VolumeLabelLength / sizeof(WCHAR) - 1] != 0x5555, "Incorrect VolumeLabel or Length\n");
|
2015-06-17 06:54:17 +00:00
|
|
|
trace("VolumeLabel = %.*ls\n", (int)VolumeInfo->VolumeLabelLength / sizeof(WCHAR), VolumeInfo->VolumeLabel);
|
2015-06-16 11:33:35 +00:00
|
|
|
ok(VolumeInfo->VolumeLabel[VolumeInfo->VolumeLabelLength / sizeof(WCHAR)] == 0x5555,
|
|
|
|
"Got %x\n", VolumeInfo->VolumeLabel[VolumeInfo->VolumeLabelLength / sizeof(WCHAR)]);
|
|
|
|
}
|
|
|
|
|
2015-06-17 06:54:17 +00:00
|
|
|
static
|
|
|
|
VOID
|
|
|
|
TestFileFsAttributeInformation(HANDLE handle)
|
|
|
|
{
|
|
|
|
IO_STATUS_BLOCK IoStatusBlock;
|
|
|
|
ULONG Buffer[(sizeof(FILE_FS_ATTRIBUTE_INFORMATION) + 32 * sizeof(WCHAR)) / sizeof(ULONG)];
|
|
|
|
PFILE_FS_ATTRIBUTE_INFORMATION AttributeInfo = (PFILE_FS_ATTRIBUTE_INFORMATION)Buffer;
|
|
|
|
NTSTATUS status;
|
|
|
|
|
|
|
|
status = NtQueryVolumeInformationFile(handle, NULL, NULL, 0, FileFsAttributeInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Got status 0x%lx\n", status);
|
|
|
|
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, NULL, 0, FileFsAttributeInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == 0x55555555, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(IoStatusBlock.Information == (ULONG_PTR)0x5555555555555555, "IoStatusBlock.Information = %Iu\n", IoStatusBlock.Information);
|
|
|
|
|
|
|
|
status = NtQueryVolumeInformationFile(handle, NULL, AttributeInfo, 0, FileFsAttributeInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Got status 0x%lx\n", status);
|
|
|
|
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, (PUCHAR)Buffer + 2, sizeof(FILE_FS_ATTRIBUTE_INFORMATION), FileFsAttributeInformation);
|
|
|
|
ok(status == STATUS_DATATYPE_MISALIGNMENT, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == 0x55555555, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(IoStatusBlock.Information == (ULONG_PTR)0x5555555555555555, "IoStatusBlock.Information = %Iu\n", IoStatusBlock.Information);
|
|
|
|
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, AttributeInfo, 0, FileFsAttributeInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == 0x55555555, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(IoStatusBlock.Information == (ULONG_PTR)0x5555555555555555, "IoStatusBlock.Information = %Iu\n", IoStatusBlock.Information);
|
|
|
|
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, AttributeInfo, FIELD_OFFSET(FILE_FS_ATTRIBUTE_INFORMATION, FileSystemName), FileFsAttributeInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == 0x55555555, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(IoStatusBlock.Information == (ULONG_PTR)0x5555555555555555, "IoStatusBlock.Information = %Iu\n", IoStatusBlock.Information);
|
|
|
|
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, AttributeInfo, sizeof(FILE_FS_ATTRIBUTE_INFORMATION) - 1, FileFsAttributeInformation);
|
|
|
|
ok(status == STATUS_INFO_LENGTH_MISMATCH, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == 0x55555555, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(IoStatusBlock.Information == (ULONG_PTR)0x5555555555555555, "IoStatusBlock.Information = %Iu\n", IoStatusBlock.Information);
|
|
|
|
|
|
|
|
RtlFillMemory(Buffer, sizeof(Buffer), 0x55);
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, AttributeInfo, sizeof(FILE_FS_ATTRIBUTE_INFORMATION), FileFsAttributeInformation);
|
|
|
|
ok(status == STATUS_BUFFER_OVERFLOW, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == STATUS_BUFFER_OVERFLOW, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(AttributeInfo->FileSystemNameLength == sizeof(FILE_FS_ATTRIBUTE_INFORMATION) - FIELD_OFFSET(FILE_FS_ATTRIBUTE_INFORMATION, FileSystemName),
|
|
|
|
"AttributeInfo->FileSystemNameLength = %Iu\n", AttributeInfo->FileSystemNameLength);
|
|
|
|
ok(IoStatusBlock.Information == sizeof(FILE_FS_ATTRIBUTE_INFORMATION),
|
|
|
|
"IoStatusBlock.Information = %Iu, expected %lu\n", IoStatusBlock.Information, (ULONG)sizeof(FILE_FS_ATTRIBUTE_INFORMATION));
|
|
|
|
ok(AttributeInfo->FileSystemName[AttributeInfo->FileSystemNameLength / sizeof(WCHAR)] == 0x5555,
|
|
|
|
"Got %x\n", AttributeInfo->FileSystemName[AttributeInfo->FileSystemNameLength / sizeof(WCHAR)]);
|
|
|
|
|
|
|
|
RtlFillMemory(Buffer, sizeof(Buffer), 0x55);
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, AttributeInfo, sizeof(FILE_FS_ATTRIBUTE_INFORMATION) + 1, FileFsAttributeInformation);
|
|
|
|
ok(status == STATUS_BUFFER_OVERFLOW, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == STATUS_BUFFER_OVERFLOW, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(AttributeInfo->FileSystemNameLength == sizeof(FILE_FS_ATTRIBUTE_INFORMATION) + 1 - FIELD_OFFSET(FILE_FS_ATTRIBUTE_INFORMATION, FileSystemName),
|
|
|
|
"AttributeInfo->FileSystemNameLength = %Iu\n", AttributeInfo->FileSystemNameLength);
|
|
|
|
ok(IoStatusBlock.Information == sizeof(FILE_FS_ATTRIBUTE_INFORMATION) + 1,
|
|
|
|
"IoStatusBlock.Information = %Iu, expected %lu\n", IoStatusBlock.Information, (ULONG)sizeof(FILE_FS_ATTRIBUTE_INFORMATION));
|
|
|
|
ok((AttributeInfo->FileSystemName[AttributeInfo->FileSystemNameLength / sizeof(WCHAR)] & 0xff00) == 0x5500,
|
|
|
|
"Got %x\n", AttributeInfo->FileSystemName[AttributeInfo->FileSystemNameLength / sizeof(WCHAR)]);
|
|
|
|
ok(AttributeInfo->FileSystemName[AttributeInfo->FileSystemNameLength / sizeof(WCHAR) + 1] == 0x5555,
|
|
|
|
"Got %x\n", AttributeInfo->FileSystemName[AttributeInfo->FileSystemNameLength / sizeof(WCHAR) + 1]);
|
|
|
|
|
|
|
|
RtlFillMemory(Buffer, sizeof(Buffer), 0x55);
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, AttributeInfo, sizeof(FILE_FS_ATTRIBUTE_INFORMATION) + sizeof(WCHAR), FileFsAttributeInformation);
|
|
|
|
if (status != STATUS_SUCCESS)
|
|
|
|
{
|
|
|
|
ok(status == STATUS_BUFFER_OVERFLOW, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == STATUS_BUFFER_OVERFLOW, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(AttributeInfo->FileSystemNameLength == sizeof(FILE_FS_ATTRIBUTE_INFORMATION) + sizeof(WCHAR) - FIELD_OFFSET(FILE_FS_ATTRIBUTE_INFORMATION, FileSystemName),
|
|
|
|
"AttributeInfo->FileSystemNameLength = %Iu\n", AttributeInfo->FileSystemNameLength);
|
|
|
|
ok(IoStatusBlock.Information == sizeof(FILE_FS_ATTRIBUTE_INFORMATION) + sizeof(WCHAR),
|
|
|
|
"IoStatusBlock.Information = %Iu, expected %lu\n", IoStatusBlock.Information, (ULONG)sizeof(FILE_FS_ATTRIBUTE_INFORMATION));
|
|
|
|
ok(AttributeInfo->FileSystemName[AttributeInfo->FileSystemNameLength / sizeof(WCHAR)] == 0x5555,
|
|
|
|
"Got %x\n", AttributeInfo->FileSystemName[AttributeInfo->FileSystemNameLength / sizeof(WCHAR)]);
|
|
|
|
}
|
|
|
|
|
|
|
|
RtlFillMemory(Buffer, sizeof(Buffer), 0x55);
|
|
|
|
RtlFillMemory(&IoStatusBlock, sizeof(IoStatusBlock), 0x55);
|
|
|
|
status = NtQueryVolumeInformationFile(handle, &IoStatusBlock, AttributeInfo, sizeof(Buffer), FileFsAttributeInformation);
|
|
|
|
ok(status == STATUS_SUCCESS, "Got status 0x%lx\n", status);
|
|
|
|
ok(IoStatusBlock.Status == STATUS_SUCCESS, "IoStatusBlock.Status = 0x%lx\n", IoStatusBlock.Status);
|
|
|
|
ok(IoStatusBlock.Information == FIELD_OFFSET(FILE_FS_ATTRIBUTE_INFORMATION, FileSystemName) + AttributeInfo->FileSystemNameLength,
|
|
|
|
"IoStatusBlock.Information = %Iu, expected %lu+%lu\n", IoStatusBlock.Information, (ULONG)FIELD_OFFSET(FILE_FS_ATTRIBUTE_INFORMATION, FileSystemName), AttributeInfo->FileSystemNameLength);
|
|
|
|
ok(AttributeInfo->FileSystemAttributes != 0x55555555, "AttributeInfo->FileSystemAttributes = 0x%lx\n", AttributeInfo->FileSystemAttributes);
|
|
|
|
ok(AttributeInfo->MaximumComponentNameLength != 0x55555555, "AttributeInfo->MaximumComponentNameLength = 0x%lx\n", AttributeInfo->MaximumComponentNameLength);
|
|
|
|
ok(AttributeInfo->FileSystemNameLength % sizeof(WCHAR) == 0, "AttributeInfo->FileSystemNameLength = %Iu\n", AttributeInfo->FileSystemNameLength);
|
|
|
|
ok(!wcsncmp(AttributeInfo->FileSystemName, L"NTFS", 4) ||
|
|
|
|
!wcsncmp(AttributeInfo->FileSystemName, L"FAT", 3) ||
|
|
|
|
!wcsncmp(AttributeInfo->FileSystemName, L"FAT32", 5),
|
|
|
|
"FileSystemName = %.*ls\n", (int)AttributeInfo->FileSystemNameLength / sizeof(WCHAR), AttributeInfo->FileSystemName);
|
|
|
|
trace("FileSystemName = %.*ls\n", (int)AttributeInfo->FileSystemNameLength / sizeof(WCHAR), AttributeInfo->FileSystemName);
|
|
|
|
ok(AttributeInfo->FileSystemName[AttributeInfo->FileSystemNameLength / sizeof(WCHAR)] == 0x5555,
|
|
|
|
"Got %x\n", AttributeInfo->FileSystemName[AttributeInfo->FileSystemNameLength / sizeof(WCHAR)]);
|
|
|
|
}
|
|
|
|
|
2015-06-16 11:33:35 +00:00
|
|
|
START_TEST(NtQueryVolumeInformationFile)
|
|
|
|
{
|
|
|
|
IO_STATUS_BLOCK IoStatusBlock;
|
|
|
|
OBJECT_ATTRIBUTES attr;
|
|
|
|
HANDLE handle;
|
|
|
|
WCHAR path[MAX_PATH];
|
|
|
|
UNICODE_STRING pathW;
|
|
|
|
NTSTATUS status;
|
|
|
|
|
|
|
|
/*Store a valid Handle*/
|
|
|
|
GetWindowsDirectoryW(path, MAX_PATH);
|
|
|
|
RtlDosPathNameToNtPathName_U(path, &pathW, NULL, NULL);
|
|
|
|
|
|
|
|
InitializeObjectAttributes(&attr, &pathW, OBJ_CASE_INSENSITIVE, NULL, NULL);
|
|
|
|
status = NtOpenFile(&handle, SYNCHRONIZE|FILE_LIST_DIRECTORY, &attr, &IoStatusBlock, FILE_SHARE_READ|FILE_SHARE_WRITE, FILE_DIRECTORY_FILE|FILE_SYNCHRONOUS_IO_NONALERT);
|
2015-06-17 06:54:17 +00:00
|
|
|
ok(status == STATUS_SUCCESS, "NtOpenFile failed: 0x%lx\n", status);
|
2015-06-16 11:33:35 +00:00
|
|
|
RtlFreeUnicodeString(&pathW);
|
|
|
|
|
|
|
|
if (!NT_SUCCESS(status))
|
|
|
|
{
|
|
|
|
skip("NtOpenFile failed: 0x%lx\n", status);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-04-20 18:15:41 +00:00
|
|
|
/*Now all NULL. Priority check: FsInformationClass value!*/
|
|
|
|
SetLastError(0xcacacaca);
|
|
|
|
status = NtQueryVolumeInformationFile(NULL, NULL, NULL, 0, 0);
|
|
|
|
ok(status == STATUS_INVALID_INFO_CLASS, "Expected STATUS_INVALID_INFO_CLASS, got 0x%lx\n", status);
|
|
|
|
ok(GetLastError() == 0xcacacaca, "Expected 0xcacacaca, got %lx\n", GetLastError());
|
|
|
|
|
2015-06-16 11:33:35 +00:00
|
|
|
TestFileFsDeviceInformation(handle);
|
|
|
|
TestFileFsVolumeInformation(handle);
|
2015-06-17 06:54:17 +00:00
|
|
|
TestFileFsAttributeInformation(handle);
|
2014-04-20 18:15:41 +00:00
|
|
|
|
|
|
|
NtClose(handle);
|
|
|
|
}
|