gdiplus: Handle image loading failures under some XP versions.

This commit is contained in:
Dmitry Timoshkov 2012-07-25 18:11:05 +09:00 committed by Alexandre Julliard
parent 0b40df2990
commit c67951c70a
1 changed files with 12 additions and 3 deletions

View File

@ -2702,7 +2702,13 @@ static GpImage *load_image(const BYTE *image_data, UINT image_size)
ok(refcount == 1, "expected stream refcount 1, got %d\n", refcount); ok(refcount == 1, "expected stream refcount 1, got %d\n", refcount);
status = GdipLoadImageFromStream(stream, &image); status = GdipLoadImageFromStream(stream, &image);
ok(status == Ok, "GdipLoadImageFromStream error %d\n", status); ok(status == Ok || broken(status == InvalidParameter), /* XP */
"GdipLoadImageFromStream error %d\n", status);
if (status != Ok)
{
IStream_Release(stream);
return NULL;
}
status = GdipGetImageType(image, &image_type); status = GdipGetImageType(image, &image_type);
ok(status == Ok, "GdipGetImageType error %d\n", status); ok(status == Ok, "GdipGetImageType error %d\n", status);
@ -2770,8 +2776,11 @@ static void test_image_properties(void)
for (i = 0; i < sizeof(td)/sizeof(td[0]); i++) for (i = 0; i < sizeof(td)/sizeof(td[0]); i++)
{ {
image = load_image(td[i].image_data, td[i].image_size); image = load_image(td[i].image_data, td[i].image_size);
ok(image != 0, "%u: failed to load image data\n", i); if (!image)
if (!image) continue; {
trace("%u: failed to load image data\n", i);
continue;
}
status = GdipGetImageType(image, &image_type); status = GdipGetImageType(image, &image_type);
ok(status == Ok, "%u: GdipGetImageType error %d\n", i, status); ok(status == Ok, "%u: GdipGetImageType error %d\n", i, status);