ole32: Fix the HMETAFILEPICT user marshaling test to use the size
derived from the return value of HMETAFILEPICT_UserMarshal instead of the value returned by HMETAFILEPICT_UserSize, as the latter over-estimates the size on Windows. Remove some unnecessary casts.
This commit is contained in:
parent
00982465c4
commit
307ab51793
|
@ -204,7 +204,7 @@ static void test_marshal_HENHMETAFILE(void)
|
||||||
|
|
||||||
size = HENHMETAFILE_UserSize(&flags, 0, &hemf);
|
size = HENHMETAFILE_UserSize(&flags, 0, &hemf);
|
||||||
ok(size == 8, "size should be 8 bytes, not %d\n", size);
|
ok(size == 8, "size should be 8 bytes, not %d\n", size);
|
||||||
buffer = (unsigned char *)HeapAlloc(GetProcessHeap(), 0, size);
|
buffer = HeapAlloc(GetProcessHeap(), 0, size);
|
||||||
HENHMETAFILE_UserMarshal(&flags, buffer, &hemf);
|
HENHMETAFILE_UserMarshal(&flags, buffer, &hemf);
|
||||||
wirehemf = buffer;
|
wirehemf = buffer;
|
||||||
ok(*(DWORD *)wirehemf == WDT_REMOTE_CALL, "wirestgm + 0x0 should be WDT_REMOTE_CALL instead of 0x%08x\n", *(DWORD *)wirehemf);
|
ok(*(DWORD *)wirehemf == WDT_REMOTE_CALL, "wirestgm + 0x0 should be WDT_REMOTE_CALL instead of 0x%08x\n", *(DWORD *)wirehemf);
|
||||||
|
@ -239,7 +239,7 @@ static void test_marshal_HMETAFILE(void)
|
||||||
|
|
||||||
size = HMETAFILE_UserSize(&flags, 0, &hmf);
|
size = HMETAFILE_UserSize(&flags, 0, &hmf);
|
||||||
ok(size > 20, "size should be at least 20 bytes, not %d\n", size);
|
ok(size > 20, "size should be at least 20 bytes, not %d\n", size);
|
||||||
buffer = (unsigned char *)HeapAlloc(GetProcessHeap(), 0, size);
|
buffer = HeapAlloc(GetProcessHeap(), 0, size);
|
||||||
HMETAFILE_UserMarshal(&flags, buffer, &hmf);
|
HMETAFILE_UserMarshal(&flags, buffer, &hmf);
|
||||||
wirehmf = buffer;
|
wirehmf = buffer;
|
||||||
ok(*(DWORD *)wirehmf == WDT_REMOTE_CALL, "wirestgm + 0x0 should be WDT_REMOTE_CALL instead of 0x%08x\n", *(DWORD *)wirehmf);
|
ok(*(DWORD *)wirehmf == WDT_REMOTE_CALL, "wirestgm + 0x0 should be WDT_REMOTE_CALL instead of 0x%08x\n", *(DWORD *)wirehmf);
|
||||||
|
@ -266,7 +266,7 @@ static void test_marshal_HMETAFILE(void)
|
||||||
|
|
||||||
size = HMETAFILE_UserSize(&flags, 0, &hmf);
|
size = HMETAFILE_UserSize(&flags, 0, &hmf);
|
||||||
ok(size == 8, "size should be 8 bytes, not %d\n", size);
|
ok(size == 8, "size should be 8 bytes, not %d\n", size);
|
||||||
buffer = (unsigned char *)HeapAlloc(GetProcessHeap(), 0, size);
|
buffer = HeapAlloc(GetProcessHeap(), 0, size);
|
||||||
HMETAFILE_UserMarshal(&flags, buffer, &hmf);
|
HMETAFILE_UserMarshal(&flags, buffer, &hmf);
|
||||||
wirehmf = buffer;
|
wirehmf = buffer;
|
||||||
ok(*(DWORD *)wirehmf == WDT_REMOTE_CALL, "wirestgm + 0x0 should be WDT_REMOTE_CALL instead of 0x%08x\n", *(DWORD *)wirehmf);
|
ok(*(DWORD *)wirehmf == WDT_REMOTE_CALL, "wirestgm + 0x0 should be WDT_REMOTE_CALL instead of 0x%08x\n", *(DWORD *)wirehmf);
|
||||||
|
@ -286,7 +286,7 @@ static void test_marshal_HMETAFILE(void)
|
||||||
|
|
||||||
static void test_marshal_HMETAFILEPICT(void)
|
static void test_marshal_HMETAFILEPICT(void)
|
||||||
{
|
{
|
||||||
unsigned char *buffer;
|
unsigned char *buffer, *buffer_end;
|
||||||
ULONG size;
|
ULONG size;
|
||||||
ULONG flags = MAKELONG(MSHCTX_DIFFERENTMACHINE, NDR_LOCAL_DATA_REPRESENTATION);
|
ULONG flags = MAKELONG(MSHCTX_DIFFERENTMACHINE, NDR_LOCAL_DATA_REPRESENTATION);
|
||||||
HMETAFILEPICT hmfp;
|
HMETAFILEPICT hmfp;
|
||||||
|
@ -305,8 +305,8 @@ static void test_marshal_HMETAFILEPICT(void)
|
||||||
size = HMETAFILEPICT_UserSize(&flags, 0, &hmfp);
|
size = HMETAFILEPICT_UserSize(&flags, 0, &hmfp);
|
||||||
ok(size > 20, "size should be at least 20 bytes, not %d\n", size);
|
ok(size > 20, "size should be at least 20 bytes, not %d\n", size);
|
||||||
trace("size is %d\n", size);
|
trace("size is %d\n", size);
|
||||||
buffer = (unsigned char *)HeapAlloc(GetProcessHeap(), 0, size);
|
buffer = HeapAlloc(GetProcessHeap(), 0, size);
|
||||||
HMETAFILEPICT_UserMarshal(&flags, buffer, &hmfp);
|
buffer_end = HMETAFILEPICT_UserMarshal(&flags, buffer, &hmfp);
|
||||||
wirehmfp = buffer;
|
wirehmfp = buffer;
|
||||||
ok(*(DWORD *)wirehmfp == WDT_REMOTE_CALL, "wirestgm + 0x0 should be WDT_REMOTE_CALL instead of 0x%08x\n", *(DWORD *)wirehmfp);
|
ok(*(DWORD *)wirehmfp == WDT_REMOTE_CALL, "wirestgm + 0x0 should be WDT_REMOTE_CALL instead of 0x%08x\n", *(DWORD *)wirehmfp);
|
||||||
wirehmfp += sizeof(DWORD);
|
wirehmfp += sizeof(DWORD);
|
||||||
|
@ -326,12 +326,12 @@ static void test_marshal_HMETAFILEPICT(void)
|
||||||
ok(*(DWORD *)wirehmfp == (DWORD)(DWORD_PTR)pmfp->hMF, "wirestgm + 0x1c should be pmfp->hMF instead of 0x%08x\n", *(DWORD *)wirehmfp);
|
ok(*(DWORD *)wirehmfp == (DWORD)(DWORD_PTR)pmfp->hMF, "wirestgm + 0x1c should be pmfp->hMF instead of 0x%08x\n", *(DWORD *)wirehmfp);
|
||||||
GlobalUnlock(hmfp);
|
GlobalUnlock(hmfp);
|
||||||
wirehmfp += sizeof(DWORD);
|
wirehmfp += sizeof(DWORD);
|
||||||
todo_wine {
|
/* Note use (buffer_end - buffer) instead of size here, because size is an
|
||||||
ok(*(DWORD *)wirehmfp == (size - 0x34), "wirestgm + 0x20 should be size - 0x34 instead of 0x%08x\n", *(DWORD *)wirehmfp);
|
* overestimate with native */
|
||||||
|
ok(*(DWORD *)wirehmfp == (buffer_end - buffer - 0x28), "wirestgm + 0x20 should be size - 0x34 instead of 0x%08x\n", *(DWORD *)wirehmfp);
|
||||||
wirehmfp += sizeof(DWORD);
|
wirehmfp += sizeof(DWORD);
|
||||||
ok(*(DWORD *)wirehmfp == (size - 0x34), "wirestgm + 0x24 should be size - 0x34 instead of 0x%08x\n", *(DWORD *)wirehmfp);
|
ok(*(DWORD *)wirehmfp == (buffer_end - buffer - 0x28), "wirestgm + 0x24 should be size - 0x34 instead of 0x%08x\n", *(DWORD *)wirehmfp);
|
||||||
wirehmfp += sizeof(DWORD);
|
wirehmfp += sizeof(DWORD);
|
||||||
}
|
|
||||||
ok(*(WORD *)wirehmfp == 1, "wirehmfp + 0x28 should be 1 instead of 0x%08x\n", *(DWORD *)wirehmfp);
|
ok(*(WORD *)wirehmfp == 1, "wirehmfp + 0x28 should be 1 instead of 0x%08x\n", *(DWORD *)wirehmfp);
|
||||||
wirehmfp += sizeof(DWORD);
|
wirehmfp += sizeof(DWORD);
|
||||||
/* ... rest of data not tested - refer to tests for GetMetaFileBits
|
/* ... rest of data not tested - refer to tests for GetMetaFileBits
|
||||||
|
|
Loading…
Reference in New Issue