crypt32/tests: Fix some test failures on Win9x.
[wine] / dlls / gdiplus / tests / image.c
1 /*
2  * Unit test suite for images
3  *
4  * Copyright (C) 2007 Google (Evan Stade)
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19  */
20
21 #define COBJMACROS
22
23 #include <math.h>
24
25 #include "initguid.h"
26 #include "windows.h"
27 #include "gdiplus.h"
28 #include "wine/test.h"
29
30 #define expect(expected, got) ok(((UINT)got) == ((UINT)expected), "Expected %.8x, got %.8x\n", (UINT)expected, (UINT)got)
31 #define expectf(expected, got) ok(fabs(expected - got) < 0.0001, "Expected %.2f, got %.2f\n", expected, got)
32
33 static void expect_rawformat(REFGUID expected, GpImage *img, int line, BOOL todo)
34 {
35     GUID raw;
36     WCHAR bufferW[39];
37     char buffer[39];
38     char buffer2[39];
39     GpStatus stat;
40
41     stat = GdipGetImageRawFormat(img, &raw);
42     ok_(__FILE__, line)(stat == Ok, "GdipGetImageRawFormat failed with %d\n", stat);
43     if(stat != Ok) return;
44     StringFromGUID2(&raw, bufferW, sizeof(bufferW)/sizeof(bufferW[0]));
45     WideCharToMultiByte(CP_ACP, 0, bufferW, sizeof(bufferW)/sizeof(bufferW[0]), buffer, sizeof(buffer), NULL, NULL);
46     StringFromGUID2(expected, bufferW, sizeof(bufferW)/sizeof(bufferW[0]));
47     WideCharToMultiByte(CP_ACP, 0, bufferW, sizeof(bufferW)/sizeof(bufferW[0]), buffer2, sizeof(buffer2), NULL, NULL);
48     if(todo)
49         todo_wine ok_(__FILE__, line)(IsEqualGUID(&raw, expected), "Expected format %s, got %s\n", buffer2, buffer);
50     else
51         ok_(__FILE__, line)(IsEqualGUID(&raw, expected), "Expected format %s, got %s\n", buffer2, buffer);
52 }
53
54 static void test_bufferrawformat(void* buff, int size, REFGUID expected, int line, BOOL todo)
55 {
56     LPSTREAM stream;
57     HGLOBAL  hglob;
58     LPBYTE   data;
59     HRESULT  hres;
60     GpStatus stat;
61     GpBitmap *bmp;
62
63     hglob = GlobalAlloc (0, size);
64     data = GlobalLock (hglob);
65     memcpy(data, buff, size);
66     GlobalUnlock(hglob); data = NULL;
67
68     hres = CreateStreamOnHGlobal(hglob, TRUE, &stream);
69     ok_(__FILE__, line)(hres == S_OK, "Failed to create a stream\n");
70     if(hres != S_OK) return;
71
72     stat = GdipCreateBitmapFromStream(stream, &bmp);
73     ok_(__FILE__, line)(stat == Ok, "Failed to create a Bitmap\n");
74     if(stat != Ok){
75         IStream_Release(stream);
76         return;
77     }
78
79     expect_rawformat(expected, (GpImage*)bmp, line, todo);
80
81     GdipDisposeImage((GpImage*)bmp);
82     IStream_Release(stream);
83 }
84
85 static void test_Scan0(void)
86 {
87     GpBitmap *bm;
88     GpStatus stat;
89     BYTE buff[360];
90
91     bm = NULL;
92     stat = GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat24bppRGB, NULL, &bm);
93     expect(Ok, stat);
94     ok(NULL != bm, "Expected bitmap to be initialized\n");
95     if (stat == Ok)
96         GdipDisposeImage((GpImage*)bm);
97
98     bm = (GpBitmap*)0xdeadbeef;
99     stat = GdipCreateBitmapFromScan0(10, -10, 10, PixelFormat24bppRGB, NULL, &bm);
100     expect(InvalidParameter, stat);
101     ok( !bm, "expected null bitmap\n" );
102
103     bm = (GpBitmap*)0xdeadbeef;
104     stat = GdipCreateBitmapFromScan0(-10, 10, 10, PixelFormat24bppRGB, NULL, &bm);
105     expect(InvalidParameter, stat);
106     ok( !bm, "expected null bitmap\n" );
107
108     bm = (GpBitmap*)0xdeadbeef;
109     stat = GdipCreateBitmapFromScan0(10, 0, 10, PixelFormat24bppRGB, NULL, &bm);
110     expect(InvalidParameter, stat);
111     ok( !bm, "expected null bitmap\n" );
112
113     bm = NULL;
114     stat = GdipCreateBitmapFromScan0(10, 10, 12, PixelFormat24bppRGB, buff, &bm);
115     expect(Ok, stat);
116     ok(NULL != bm, "Expected bitmap to be initialized\n");
117     if (stat == Ok)
118         GdipDisposeImage((GpImage*)bm);
119
120     bm = (GpBitmap*) 0xdeadbeef;
121     stat = GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat24bppRGB, buff, &bm);
122     expect(InvalidParameter, stat);
123     ok( !bm, "expected null bitmap\n" );
124
125     bm = (GpBitmap*)0xdeadbeef;
126     stat = GdipCreateBitmapFromScan0(10, 10, 0, PixelFormat24bppRGB, buff, &bm);
127     expect(InvalidParameter, stat);
128     ok( bm == (GpBitmap*)0xdeadbeef, "expected deadbeef bitmap\n" );
129
130     bm = NULL;
131     stat = GdipCreateBitmapFromScan0(10, 10, -8, PixelFormat24bppRGB, buff, &bm);
132     expect(Ok, stat);
133     ok(NULL != bm, "Expected bitmap to be initialized\n");
134     if (stat == Ok)
135         GdipDisposeImage((GpImage*)bm);
136
137     bm = (GpBitmap*)0xdeadbeef;
138     stat = GdipCreateBitmapFromScan0(10, 10, -10, PixelFormat24bppRGB, buff, &bm);
139     expect(InvalidParameter, stat);
140     ok( !bm, "expected null bitmap\n" );
141 }
142
143 static void test_GetImageDimension(void)
144 {
145     GpBitmap *bm;
146     GpStatus stat;
147     const REAL WIDTH = 10.0, HEIGHT = 20.0;
148     REAL w,h;
149
150     bm = (GpBitmap*)0xdeadbeef;
151     stat = GdipCreateBitmapFromScan0(WIDTH, HEIGHT, 0, PixelFormat24bppRGB,NULL, &bm);
152     expect(Ok,stat);
153     ok((GpBitmap*)0xdeadbeef != bm, "Expected bitmap to not be 0xdeadbeef\n");
154     ok(NULL != bm, "Expected bitmap to not be NULL\n");
155
156     stat = GdipGetImageDimension(NULL,&w,&h);
157     expect(InvalidParameter, stat);
158
159     stat = GdipGetImageDimension((GpImage*)bm,NULL,&h);
160     expect(InvalidParameter, stat);
161
162     stat = GdipGetImageDimension((GpImage*)bm,&w,NULL);
163     expect(InvalidParameter, stat);
164
165     w = -1;
166     h = -1;
167     stat = GdipGetImageDimension((GpImage*)bm,&w,&h);
168     expect(Ok, stat);
169     expectf(WIDTH,  w);
170     expectf(HEIGHT, h);
171     GdipDisposeImage((GpImage*)bm);
172 }
173
174 static void test_GdipImageGetFrameDimensionsCount(void)
175 {
176     GpBitmap *bm;
177     GpStatus stat;
178     const REAL WIDTH = 10.0, HEIGHT = 20.0;
179     UINT w;
180
181     bm = (GpBitmap*)0xdeadbeef;
182     stat = GdipCreateBitmapFromScan0(WIDTH, HEIGHT, 0, PixelFormat24bppRGB,NULL, &bm);
183     expect(Ok,stat);
184     ok((GpBitmap*)0xdeadbeef != bm, "Expected bitmap to not be 0xdeadbeef\n");
185     ok(NULL != bm, "Expected bitmap to not be NULL\n");
186
187     stat = GdipImageGetFrameDimensionsCount(NULL,&w);
188     expect(InvalidParameter, stat);
189
190     stat = GdipImageGetFrameDimensionsCount((GpImage*)bm,NULL);
191     expect(InvalidParameter, stat);
192
193     w = -1;
194     stat = GdipImageGetFrameDimensionsCount((GpImage*)bm,&w);
195     expect(Ok, stat);
196     expect(1, w);
197     GdipDisposeImage((GpImage*)bm);
198 }
199
200 static void test_LoadingImages(void)
201 {
202     GpStatus stat;
203
204     stat = GdipCreateBitmapFromFile(0, 0);
205     expect(InvalidParameter, stat);
206
207     stat = GdipCreateBitmapFromFile(0, (GpBitmap**)0xdeadbeef);
208     expect(InvalidParameter, stat);
209
210     stat = GdipLoadImageFromFile(0, 0);
211     expect(InvalidParameter, stat);
212
213     stat = GdipLoadImageFromFile(0, (GpImage**)0xdeadbeef);
214     expect(InvalidParameter, stat);
215
216     stat = GdipLoadImageFromFileICM(0, 0);
217     expect(InvalidParameter, stat);
218
219     stat = GdipLoadImageFromFileICM(0, (GpImage**)0xdeadbeef);
220     expect(InvalidParameter, stat);
221 }
222
223 static void test_SavingImages(void)
224 {
225     GpStatus stat;
226     GpBitmap *bm;
227     UINT n;
228     UINT s;
229     const REAL WIDTH = 10.0, HEIGHT = 20.0;
230     REAL w, h;
231     ImageCodecInfo *codecs;
232     static const CHAR filenameA[] = "a.bmp";
233     static const WCHAR filename[] = { 'a','.','b','m','p',0 };
234
235     codecs = NULL;
236
237     stat = GdipSaveImageToFile(0, 0, 0, 0);
238     expect(InvalidParameter, stat);
239
240     bm = NULL;
241     stat = GdipCreateBitmapFromScan0(WIDTH, HEIGHT, 0, PixelFormat24bppRGB, NULL, &bm);
242     expect(Ok, stat);
243     if (!bm)
244         return;
245
246     /* invalid params */
247     stat = GdipSaveImageToFile((GpImage*)bm, 0, 0, 0);
248     expect(InvalidParameter, stat);
249
250     stat = GdipSaveImageToFile((GpImage*)bm, filename, 0, 0);
251     expect(InvalidParameter, stat);
252
253     /* encoder tests should succeed -- already tested */
254     stat = GdipGetImageEncodersSize(&n, &s);
255     if (stat != Ok || n == 0) goto cleanup;
256
257     codecs = GdipAlloc(s);
258     if (!codecs) goto cleanup;
259
260     stat = GdipGetImageEncoders(n, s, codecs);
261     if (stat != Ok) goto cleanup;
262
263     stat = GdipSaveImageToFile((GpImage*)bm, filename, &codecs[0].Clsid, 0);
264     expect(stat, Ok);
265
266     GdipDisposeImage((GpImage*)bm);
267     bm = 0;
268
269     /* re-load and check image stats */
270     stat = GdipLoadImageFromFile(filename, (GpImage**)&bm);
271     expect(stat, Ok);
272     if (stat != Ok) goto cleanup;
273
274     stat = GdipGetImageDimension((GpImage*)bm, &w, &h);
275     if (stat != Ok) goto cleanup;
276
277     expectf(WIDTH, w);
278     expectf(HEIGHT, h);
279
280  cleanup:
281     GdipFree(codecs);
282     if (bm)
283         GdipDisposeImage((GpImage*)bm);
284     ok(DeleteFileA(filenameA), "Delete failed.\n");
285 }
286
287 static void test_encoders(void)
288 {
289     GpStatus stat;
290     UINT n;
291     UINT s;
292     ImageCodecInfo *codecs;
293     int i;
294     int bmp_found;
295
296     static const CHAR bmp_format[] = "BMP";
297
298     stat = GdipGetImageEncodersSize(&n, &s);
299     expect(stat, Ok);
300
301     codecs = GdipAlloc(s);
302     if (!codecs)
303         return;
304
305     stat = GdipGetImageEncoders(n, s, NULL);
306     expect(GenericError, stat);
307
308     stat = GdipGetImageEncoders(0, s, codecs);
309     expect(GenericError, stat);
310
311     stat = GdipGetImageEncoders(n, s-1, codecs);
312     expect(GenericError, stat);
313
314     stat = GdipGetImageEncoders(n, s+1, codecs);
315     expect(GenericError, stat);
316
317     stat = GdipGetImageEncoders(n, s, codecs);
318     expect(stat, Ok);
319
320     bmp_found = FALSE;
321     for (i = 0; i < n; i++)
322         {
323             CHAR desc[32];
324
325             WideCharToMultiByte(CP_ACP, 0, codecs[i].FormatDescription, -1,
326                                 desc, 32, 0, 0);
327
328             if (CompareStringA(LOCALE_SYSTEM_DEFAULT, 0,
329                                desc, -1,
330                                bmp_format, -1) == CSTR_EQUAL) {
331                 bmp_found = TRUE;
332                 break;
333             }
334         }
335     if (!bmp_found)
336         ok(FALSE, "No BMP codec found.\n");
337
338     GdipFree(codecs);
339 }
340
341 static void test_LockBits(void)
342 {
343     GpStatus stat;
344     GpBitmap *bm;
345     GpRect rect;
346     BitmapData bd;
347     const INT WIDTH = 10, HEIGHT = 20;
348
349     bm = NULL;
350     stat = GdipCreateBitmapFromScan0(WIDTH, HEIGHT, 0, PixelFormat24bppRGB, NULL, &bm);
351     expect(Ok, stat);
352
353     rect.X = 2;
354     rect.Y = 3;
355     rect.Width = 4;
356     rect.Height = 5;
357
358     /* read-only */
359     stat = GdipBitmapLockBits(bm, &rect, ImageLockModeRead, PixelFormat24bppRGB, &bd);
360     expect(Ok, stat);
361
362     if (stat == Ok) {
363         stat = GdipBitmapUnlockBits(bm, &bd);
364         expect(Ok, stat);
365     }
366
367     /* read-only, with NULL rect -> whole bitmap lock */
368     stat = GdipBitmapLockBits(bm, NULL, ImageLockModeRead, PixelFormat24bppRGB, &bd);
369     expect(Ok, stat);
370     expect(bd.Width,  WIDTH);
371     expect(bd.Height, HEIGHT);
372
373     if (stat == Ok) {
374         stat = GdipBitmapUnlockBits(bm, &bd);
375         expect(Ok, stat);
376     }
377
378     /* read-only, consecutive */
379     stat = GdipBitmapLockBits(bm, &rect, ImageLockModeRead, PixelFormat24bppRGB, &bd);
380     expect(Ok, stat);
381
382     if (stat == Ok) {
383         stat = GdipBitmapUnlockBits(bm, &bd);
384         expect(Ok, stat);
385     }
386
387     stat = GdipDisposeImage((GpImage*)bm);
388     expect(Ok, stat);
389     stat = GdipCreateBitmapFromScan0(WIDTH, HEIGHT, 0, PixelFormat24bppRGB, NULL, &bm);
390     expect(Ok, stat);
391
392     /* read x2 */
393     stat = GdipBitmapLockBits(bm, &rect, ImageLockModeRead, PixelFormat24bppRGB, &bd);
394     expect(Ok, stat);
395     stat = GdipBitmapLockBits(bm, &rect, ImageLockModeRead, PixelFormat24bppRGB, &bd);
396     expect(WrongState, stat);
397
398     stat = GdipBitmapUnlockBits(bm, &bd);
399     expect(Ok, stat);
400
401     stat = GdipDisposeImage((GpImage*)bm);
402     expect(Ok, stat);
403     stat = GdipCreateBitmapFromScan0(WIDTH, HEIGHT, 0, PixelFormat24bppRGB, NULL, &bm);
404     expect(Ok, stat);
405
406     /* write, no modification */
407     stat = GdipBitmapLockBits(bm, &rect, ImageLockModeWrite, PixelFormat24bppRGB, &bd);
408     expect(Ok, stat);
409
410     if (stat == Ok) {
411         stat = GdipBitmapUnlockBits(bm, &bd);
412         expect(Ok, stat);
413     }
414
415     /* write, consecutive */
416     stat = GdipBitmapLockBits(bm, &rect, ImageLockModeWrite, PixelFormat24bppRGB, &bd);
417     expect(Ok, stat);
418
419     if (stat == Ok) {
420         stat = GdipBitmapUnlockBits(bm, &bd);
421         expect(Ok, stat);
422     }
423
424     stat = GdipDisposeImage((GpImage*)bm);
425     expect(Ok, stat);
426     stat = GdipCreateBitmapFromScan0(WIDTH, HEIGHT, 0, PixelFormat24bppRGB, NULL, &bm);
427     expect(Ok, stat);
428
429     /* write, modify */
430     stat = GdipBitmapLockBits(bm, &rect, ImageLockModeWrite, PixelFormat24bppRGB, &bd);
431     expect(Ok, stat);
432
433     if (stat == Ok) {
434         if (bd.Scan0)
435             ((char*)bd.Scan0)[2] = 0xff;
436
437         stat = GdipBitmapUnlockBits(bm, &bd);
438         expect(Ok, stat);
439     }
440
441     stat = GdipDisposeImage((GpImage*)bm);
442     expect(Ok, stat);
443
444     /* dispose locked */
445     stat = GdipCreateBitmapFromScan0(WIDTH, HEIGHT, 0, PixelFormat24bppRGB, NULL, &bm);
446     expect(Ok, stat);
447     stat = GdipBitmapLockBits(bm, &rect, ImageLockModeRead, PixelFormat24bppRGB, &bd);
448     expect(Ok, stat);
449     stat = GdipDisposeImage((GpImage*)bm);
450     expect(Ok, stat);
451 }
452
453 static void test_GdipCreateBitmapFromHBITMAP(void)
454 {
455     GpBitmap* gpbm = NULL;
456     HBITMAP hbm = NULL;
457     HPALETTE hpal = NULL;
458     GpStatus stat;
459     BYTE buff[1000];
460     LOGPALETTE* LogPal = NULL;
461     REAL width, height;
462     const REAL WIDTH1 = 5;
463     const REAL HEIGHT1 = 15;
464     const REAL WIDTH2 = 10;
465     const REAL HEIGHT2 = 20;
466     HDC hdc;
467     BITMAPINFO bmi;
468
469     stat = GdipCreateBitmapFromHBITMAP(NULL, NULL, NULL);
470     expect(InvalidParameter, stat);
471
472     hbm = CreateBitmap(WIDTH1, HEIGHT1, 1, 1, NULL);
473     stat = GdipCreateBitmapFromHBITMAP(hbm, NULL, NULL);
474     expect(InvalidParameter, stat);
475
476     stat = GdipCreateBitmapFromHBITMAP(hbm, NULL, &gpbm);
477     expect(Ok, stat);
478     expect(Ok, GdipGetImageDimension((GpImage*) gpbm, &width, &height));
479     expectf(WIDTH1,  width);
480     expectf(HEIGHT1, height);
481     if (stat == Ok)
482         GdipDisposeImage((GpImage*)gpbm);
483     GlobalFree(hbm);
484
485     hbm = CreateBitmap(WIDTH2, HEIGHT2, 1, 1, &buff);
486     stat = GdipCreateBitmapFromHBITMAP(hbm, NULL, &gpbm);
487     expect(Ok, stat);
488     /* raw format */
489     expect_rawformat(&ImageFormatMemoryBMP, (GpImage*)gpbm, __LINE__, TRUE);
490
491     expect(Ok, GdipGetImageDimension((GpImage*) gpbm, &width, &height));
492     expectf(WIDTH2,  width);
493     expectf(HEIGHT2, height);
494     if (stat == Ok)
495         GdipDisposeImage((GpImage*)gpbm);
496     GlobalFree(hbm);
497
498     hdc = CreateCompatibleDC(0);
499     ok(hdc != NULL, "CreateCompatibleDC failed\n");
500     bmi.bmiHeader.biSize = sizeof(bmi.bmiHeader);
501     bmi.bmiHeader.biHeight = HEIGHT1;
502     bmi.bmiHeader.biWidth = WIDTH1;
503     bmi.bmiHeader.biBitCount = 24;
504     bmi.bmiHeader.biPlanes = 1;
505     bmi.bmiHeader.biCompression = BI_RGB;
506
507     hbm = CreateDIBSection(hdc, &bmi, DIB_RGB_COLORS, NULL, NULL, 0);
508     ok(hbm != NULL, "CreateDIBSection failed\n");
509
510     stat = GdipCreateBitmapFromHBITMAP(hbm, NULL, &gpbm);
511     expect(Ok, stat);
512     expect(Ok, GdipGetImageDimension((GpImage*) gpbm, &width, &height));
513     expectf(WIDTH1,  width);
514     expectf(HEIGHT1, height);
515     if (stat == Ok)
516         GdipDisposeImage((GpImage*)gpbm);
517
518     LogPal = GdipAlloc(sizeof(LOGPALETTE));
519     ok(LogPal != NULL, "unable to allocate LOGPALETTE\n");
520     LogPal->palVersion = 0x300;
521     hpal = CreatePalette(LogPal);
522     ok(hpal != NULL, "CreatePalette failed\n");
523     GdipFree(LogPal);
524
525     stat = GdipCreateBitmapFromHBITMAP(hbm, hpal, &gpbm);
526     todo_wine
527     {
528         expect(Ok, stat);
529     }
530     if (stat == Ok)
531         GdipDisposeImage((GpImage*)gpbm);
532
533     GlobalFree(hpal);
534     GlobalFree(hbm);
535 }
536
537 static void test_GdipGetImageFlags(void)
538 {
539     GpImage *img;
540     GpStatus stat;
541     UINT flags;
542
543     img = (GpImage*)0xdeadbeef;
544
545     stat = GdipGetImageFlags(NULL, NULL);
546     expect(InvalidParameter, stat);
547
548     stat = GdipGetImageFlags(NULL, &flags);
549     expect(InvalidParameter, stat);
550
551     stat = GdipGetImageFlags(img, NULL);
552     expect(InvalidParameter, stat);
553 }
554
555 static void test_GdipCloneImage(void)
556 {
557     GpStatus stat;
558     GpRectF rectF;
559     GpUnit unit;
560     GpBitmap *bm;
561     GpImage *image_src, *image_dest = NULL;
562     const INT WIDTH = 10, HEIGHT = 20;
563
564     /* Create an image, clone it, delete the original, make sure the copy works */
565     stat = GdipCreateBitmapFromScan0(WIDTH, HEIGHT, 0, PixelFormat24bppRGB, NULL, &bm);
566     expect(Ok, stat);
567     expect_rawformat(&ImageFormatMemoryBMP, (GpImage*)bm, __LINE__, TRUE);
568
569     image_src = ((GpImage*)bm);
570     stat = GdipCloneImage(image_src, &image_dest);
571     expect(Ok, stat);
572     expect_rawformat(&ImageFormatMemoryBMP, image_dest, __LINE__, TRUE);
573
574     stat = GdipDisposeImage((GpImage*)bm);
575     expect(Ok, stat);
576     stat = GdipGetImageBounds(image_dest, &rectF, &unit);
577     expect(Ok, stat);
578
579     /* Treat FP values carefully */
580     expectf((REAL)WIDTH, rectF.Width);
581     expectf((REAL)HEIGHT, rectF.Height);
582
583     stat = GdipDisposeImage(image_dest);
584     expect(Ok, stat);
585 }
586
587 static void test_testcontrol(void)
588 {
589     GpStatus stat;
590     DWORD param;
591
592     param = 0;
593     stat = GdipTestControl(TestControlGetBuildNumber, &param);
594     expect(Ok, stat);
595     ok(param != 0, "Build number expected, got %u\n", param);
596 }
597
598 static void test_fromhicon(void)
599 {
600     static const BYTE bmp_bits[1024];
601     HBITMAP hbmMask, hbmColor;
602     ICONINFO info;
603     HICON hIcon;
604     GpStatus stat;
605     GpBitmap *bitmap = NULL;
606     UINT dim;
607     ImageType type;
608     PixelFormat format;
609
610     /* NULL */
611     stat = GdipCreateBitmapFromHICON(NULL, NULL);
612     expect(InvalidParameter, stat);
613     stat = GdipCreateBitmapFromHICON(NULL, &bitmap);
614     expect(InvalidParameter, stat);
615
616     /* color icon 1 bit */
617     hbmMask = CreateBitmap(16, 16, 1, 1, bmp_bits);
618     ok(hbmMask != 0, "CreateBitmap failed\n");
619     hbmColor = CreateBitmap(16, 16, 1, 1, bmp_bits);
620     ok(hbmColor != 0, "CreateBitmap failed\n");
621     info.fIcon = TRUE;
622     info.xHotspot = 8;
623     info.yHotspot = 8;
624     info.hbmMask = hbmMask;
625     info.hbmColor = hbmColor;
626     hIcon = CreateIconIndirect(&info);
627     ok(hIcon != 0, "CreateIconIndirect failed\n");
628     DeleteObject(hbmMask);
629     DeleteObject(hbmColor);
630
631     stat = GdipCreateBitmapFromHICON(hIcon, &bitmap);
632     expect(Ok, stat);
633     if(stat == Ok){
634        /* check attributes */
635        stat = GdipGetImageHeight((GpImage*)bitmap, &dim);
636        expect(Ok, stat);
637        expect(16, dim);
638        stat = GdipGetImageWidth((GpImage*)bitmap, &dim);
639        expect(Ok, stat);
640        expect(16, dim);
641        stat = GdipGetImageType((GpImage*)bitmap, &type);
642        expect(Ok, stat);
643        expect(ImageTypeBitmap, type);
644        stat = GdipGetImagePixelFormat((GpImage*)bitmap, &format);
645        expect(PixelFormat32bppARGB, format);
646        /* raw format */
647        expect_rawformat(&ImageFormatMemoryBMP, (GpImage*)bitmap, __LINE__, TRUE);
648        GdipDisposeImage((GpImage*)bitmap);
649     }
650     DestroyIcon(hIcon);
651
652     /* color icon 8 bpp */
653     hbmMask = CreateBitmap(16, 16, 1, 8, bmp_bits);
654     ok(hbmMask != 0, "CreateBitmap failed\n");
655     hbmColor = CreateBitmap(16, 16, 1, 8, bmp_bits);
656     ok(hbmColor != 0, "CreateBitmap failed\n");
657     info.fIcon = TRUE;
658     info.xHotspot = 8;
659     info.yHotspot = 8;
660     info.hbmMask = hbmMask;
661     info.hbmColor = hbmColor;
662     hIcon = CreateIconIndirect(&info);
663     ok(hIcon != 0, "CreateIconIndirect failed\n");
664     DeleteObject(hbmMask);
665     DeleteObject(hbmColor);
666
667     stat = GdipCreateBitmapFromHICON(hIcon, &bitmap);
668     expect(Ok, stat);
669     if(stat == Ok){
670         /* check attributes */
671         stat = GdipGetImageHeight((GpImage*)bitmap, &dim);
672         expect(Ok, stat);
673         expect(16, dim);
674         stat = GdipGetImageWidth((GpImage*)bitmap, &dim);
675         expect(Ok, stat);
676         expect(16, dim);
677         stat = GdipGetImageType((GpImage*)bitmap, &type);
678         expect(Ok, stat);
679         expect(ImageTypeBitmap, type);
680         stat = GdipGetImagePixelFormat((GpImage*)bitmap, &format);
681         expect(PixelFormat32bppARGB, format);
682         /* raw format */
683         expect_rawformat(&ImageFormatMemoryBMP, (GpImage*)bitmap, __LINE__, TRUE);
684         GdipDisposeImage((GpImage*)bitmap);
685     }
686     DestroyIcon(hIcon);
687 }
688
689 /* 1x1 pixel png */
690 static const unsigned char pngimage[285] = {
691 0x89,0x50,0x4e,0x47,0x0d,0x0a,0x1a,0x0a,0x00,0x00,0x00,0x0d,0x49,0x48,0x44,0x52,
692 0x00,0x00,0x00,0x01,0x00,0x00,0x00,0x01,0x08,0x02,0x00,0x00,0x00,0x90,0x77,0x53,
693 0xde,0x00,0x00,0x00,0x09,0x70,0x48,0x59,0x73,0x00,0x00,0x0b,0x13,0x00,0x00,0x0b,
694 0x13,0x01,0x00,0x9a,0x9c,0x18,0x00,0x00,0x00,0x07,0x74,0x49,0x4d,0x45,0x07,0xd5,
695 0x06,0x03,0x0f,0x07,0x2d,0x12,0x10,0xf0,0xfd,0x00,0x00,0x00,0x0c,0x49,0x44,0x41,
696 0x54,0x08,0xd7,0x63,0xf8,0xff,0xff,0x3f,0x00,0x05,0xfe,0x02,0xfe,0xdc,0xcc,0x59,
697 0xe7,0x00,0x00,0x00,0x00,0x49,0x45,0x4e,0x44,0xae,0x42,0x60,0x82
698 };
699 /* 1x1 pixel gif */
700 static const unsigned char gifimage[35] = {
701 0x47,0x49,0x46,0x38,0x37,0x61,0x01,0x00,0x01,0x00,0x80,0x00,0x00,0xff,0xff,0xff,
702 0xff,0xff,0xff,0x2c,0x00,0x00,0x00,0x00,0x01,0x00,0x01,0x00,0x00,0x02,0x02,0x44,
703 0x01,0x00,0x3b
704 };
705 /* 1x1 pixel bmp */
706 static const unsigned char bmpimage[66] = {
707 0x42,0x4d,0x42,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x3e,0x00,0x00,0x00,0x28,0x00,
708 0x00,0x00,0x01,0x00,0x00,0x00,0x01,0x00,0x00,0x00,0x01,0x00,0x01,0x00,0x00,0x00,
709 0x00,0x00,0x04,0x00,0x00,0x00,0x12,0x0b,0x00,0x00,0x12,0x0b,0x00,0x00,0x02,0x00,
710 0x00,0x00,0x02,0x00,0x00,0x00,0xff,0xff,0xff,0x00,0xff,0xff,0xff,0x00,0x00,0x00,
711 0x00,0x00
712 };
713 /* 1x1 pixel jpg */
714 static const unsigned char jpgimage[285] = {
715 0xff,0xd8,0xff,0xe0,0x00,0x10,0x4a,0x46,0x49,0x46,0x00,0x01,0x01,0x01,0x01,0x2c,
716 0x01,0x2c,0x00,0x00,0xff,0xdb,0x00,0x43,0x00,0x05,0x03,0x04,0x04,0x04,0x03,0x05,
717 0x04,0x04,0x04,0x05,0x05,0x05,0x06,0x07,0x0c,0x08,0x07,0x07,0x07,0x07,0x0f,0x0b,
718 0x0b,0x09,0x0c,0x11,0x0f,0x12,0x12,0x11,0x0f,0x11,0x11,0x13,0x16,0x1c,0x17,0x13,
719 0x14,0x1a,0x15,0x11,0x11,0x18,0x21,0x18,0x1a,0x1d,0x1d,0x1f,0x1f,0x1f,0x13,0x17,
720 0x22,0x24,0x22,0x1e,0x24,0x1c,0x1e,0x1f,0x1e,0xff,0xdb,0x00,0x43,0x01,0x05,0x05,
721 0x05,0x07,0x06,0x07,0x0e,0x08,0x08,0x0e,0x1e,0x14,0x11,0x14,0x1e,0x1e,0x1e,0x1e,
722 0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,
723 0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,
724 0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0x1e,0xff,0xc0,
725 0x00,0x11,0x08,0x00,0x01,0x00,0x01,0x03,0x01,0x22,0x00,0x02,0x11,0x01,0x03,0x11,
726 0x01,0xff,0xc4,0x00,0x15,0x00,0x01,0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
727 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x08,0xff,0xc4,0x00,0x14,0x10,0x01,0x00,0x00,
728 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xff,0xc4,
729 0x00,0x14,0x01,0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
730 0x00,0x00,0x00,0x00,0xff,0xc4,0x00,0x14,0x11,0x01,0x00,0x00,0x00,0x00,0x00,0x00,
731 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xff,0xda,0x00,0x0c,0x03,0x01,
732 0x00,0x02,0x11,0x03,0x11,0x00,0x3f,0x00,0xb2,0xc0,0x07,0xff,0xd9
733 };
734 static void test_getrawformat(void)
735 {
736     test_bufferrawformat((void*)pngimage, sizeof(pngimage), &ImageFormatPNG,  __LINE__, TRUE);
737     test_bufferrawformat((void*)gifimage, sizeof(gifimage), &ImageFormatGIF,  __LINE__, TRUE);
738     test_bufferrawformat((void*)bmpimage, sizeof(bmpimage), &ImageFormatBMP,  __LINE__, FALSE);
739     test_bufferrawformat((void*)jpgimage, sizeof(jpgimage), &ImageFormatJPEG, __LINE__, TRUE);
740 }
741
742 START_TEST(image)
743 {
744     struct GdiplusStartupInput gdiplusStartupInput;
745     ULONG_PTR gdiplusToken;
746
747     gdiplusStartupInput.GdiplusVersion              = 1;
748     gdiplusStartupInput.DebugEventCallback          = NULL;
749     gdiplusStartupInput.SuppressBackgroundThread    = 0;
750     gdiplusStartupInput.SuppressExternalCodecs      = 0;
751
752     GdiplusStartup(&gdiplusToken, &gdiplusStartupInput, NULL);
753
754     test_Scan0();
755     test_GetImageDimension();
756     test_GdipImageGetFrameDimensionsCount();
757     test_LoadingImages();
758     test_SavingImages();
759     test_encoders();
760     test_LockBits();
761     test_GdipCreateBitmapFromHBITMAP();
762     test_GdipGetImageFlags();
763     test_GdipCloneImage();
764     test_testcontrol();
765     test_fromhicon();
766     test_getrawformat();
767
768     GdiplusShutdown(gdiplusToken);
769 }