1
0

testautomation_surface.c 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670
  1. /**
  2. * Original code: automated SDL surface test written by Edgar Simo "bobbens"
  3. * Adapted/rewritten for test lib by Andreas Schiffler
  4. */
  5. /* Supress C4996 VS compiler warnings for unlink() */
  6. #define _CRT_SECURE_NO_DEPRECATE
  7. #define _CRT_NONSTDC_NO_DEPRECATE
  8. #include <stdio.h>
  9. #include <sys/stat.h>
  10. #include "SDL.h"
  11. #include "SDL_test.h"
  12. /* ================= Test Case Implementation ================== */
  13. /* Shared test surface */
  14. static SDL_Surface *referenceSurface = NULL;
  15. static SDL_Surface *testSurface = NULL;
  16. /* Helper functions for the test cases */
  17. #define TEST_SURFACE_WIDTH testSurface->w
  18. #define TEST_SURFACE_HEIGHT testSurface->h
  19. /* Fixture */
  20. /* Create a 32-bit writable surface for blitting tests */
  21. void
  22. _surfaceSetUp(void *arg)
  23. {
  24. int result;
  25. SDL_BlendMode blendMode = SDL_BLENDMODE_NONE;
  26. SDL_BlendMode currentBlendMode;
  27. Uint32 rmask, gmask, bmask, amask;
  28. #if SDL_BYTEORDER == SDL_BIG_ENDIAN
  29. rmask = 0xff000000;
  30. gmask = 0x00ff0000;
  31. bmask = 0x0000ff00;
  32. amask = 0x000000ff;
  33. #else
  34. rmask = 0x000000ff;
  35. gmask = 0x0000ff00;
  36. bmask = 0x00ff0000;
  37. amask = 0xff000000;
  38. #endif
  39. referenceSurface = SDLTest_ImageBlit(); /* For size info */
  40. testSurface = SDL_CreateRGBSurface(SDL_SWSURFACE, referenceSurface->w, referenceSurface->h, 32, rmask, gmask, bmask, amask);
  41. SDLTest_AssertCheck(testSurface != NULL, "Check that testSurface is not NULL");
  42. if (testSurface != NULL) {
  43. /* Disable blend mode for target surface */
  44. result = SDL_SetSurfaceBlendMode(testSurface, blendMode);
  45. SDLTest_AssertCheck(result == 0, "Validate result from SDL_SetSurfaceBlendMode, expected: 0, got: %i", result);
  46. result = SDL_GetSurfaceBlendMode(testSurface, &currentBlendMode);
  47. SDLTest_AssertCheck(result == 0, "Validate result from SDL_GetSurfaceBlendMode, expected: 0, got: %i", result);
  48. SDLTest_AssertCheck(currentBlendMode == blendMode, "Validate blendMode, expected: %i, got: %i", blendMode, currentBlendMode);
  49. }
  50. }
  51. void
  52. _surfaceTearDown(void *arg)
  53. {
  54. if (referenceSurface != NULL) {
  55. SDL_FreeSurface(referenceSurface);
  56. referenceSurface = NULL;
  57. }
  58. if (testSurface != NULL) {
  59. SDL_FreeSurface(testSurface);
  60. testSurface = NULL;
  61. }
  62. }
  63. /**
  64. * Helper that clears the test surface
  65. */
  66. void _clearTestSurface()
  67. {
  68. int ret;
  69. Uint32 color;
  70. /* Clear surface. */
  71. color = SDL_MapRGBA( testSurface->format, 0, 0, 0, 0);
  72. SDLTest_AssertPass("Call to SDL_MapRGBA()");
  73. ret = SDL_FillRect( testSurface, NULL, color);
  74. SDLTest_AssertPass("Call to SDL_FillRect()");
  75. SDLTest_AssertCheck(ret == 0, "Verify result from SDL_FillRect, expected: 0, got: %i", ret);
  76. }
  77. /**
  78. * Helper that blits in a specific blend mode, -1 for basic blitting, -2 for color mod, -3 for alpha mod, -4 for mixed blend modes.
  79. */
  80. void _testBlitBlendMode(int mode)
  81. {
  82. int ret;
  83. int i, j, ni, nj;
  84. SDL_Surface *face;
  85. SDL_Rect rect;
  86. int nmode;
  87. SDL_BlendMode bmode;
  88. int checkFailCount1;
  89. int checkFailCount2;
  90. int checkFailCount3;
  91. int checkFailCount4;
  92. /* Check test surface */
  93. SDLTest_AssertCheck(testSurface != NULL, "Verify testSurface is not NULL");
  94. if (testSurface == NULL) return;
  95. /* Create sample surface */
  96. face = SDLTest_ImageFace();
  97. SDLTest_AssertCheck(face != NULL, "Verify face surface is not NULL");
  98. if (face == NULL) return;
  99. /* Reset alpha modulation */
  100. ret = SDL_SetSurfaceAlphaMod(face, 255);
  101. SDLTest_AssertPass("Call to SDL_SetSurfaceAlphaMod()");
  102. SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SetSurfaceAlphaMod(), expected: 0, got: %i", ret);
  103. /* Reset color modulation */
  104. ret = SDL_SetSurfaceColorMod(face, 255, 255, 255);
  105. SDLTest_AssertPass("Call to SDL_SetSurfaceColorMod()");
  106. SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SetSurfaceColorMod(), expected: 0, got: %i", ret);
  107. /* Reset color key */
  108. ret = SDL_SetColorKey(face, SDL_FALSE, 0);
  109. SDLTest_AssertPass("Call to SDL_SetColorKey()");
  110. SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SetColorKey(), expected: 0, got: %i", ret);
  111. /* Clear the test surface */
  112. _clearTestSurface();
  113. /* Target rect size */
  114. rect.w = face->w;
  115. rect.h = face->h;
  116. /* Steps to take */
  117. ni = testSurface->w - face->w;
  118. nj = testSurface->h - face->h;
  119. /* Optionally set blend mode. */
  120. if (mode >= 0) {
  121. ret = SDL_SetSurfaceBlendMode( face, (SDL_BlendMode)mode );
  122. SDLTest_AssertPass("Call to SDL_SetSurfaceBlendMode()");
  123. SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SetSurfaceBlendMode(..., %i), expected: 0, got: %i", mode, ret);
  124. }
  125. /* Test blend mode. */
  126. checkFailCount1 = 0;
  127. checkFailCount2 = 0;
  128. checkFailCount3 = 0;
  129. checkFailCount4 = 0;
  130. for (j=0; j <= nj; j+=4) {
  131. for (i=0; i <= ni; i+=4) {
  132. if (mode == -2) {
  133. /* Set color mod. */
  134. ret = SDL_SetSurfaceColorMod( face, (255/nj)*j, (255/ni)*i, (255/nj)*j );
  135. if (ret != 0) checkFailCount2++;
  136. }
  137. else if (mode == -3) {
  138. /* Set alpha mod. */
  139. ret = SDL_SetSurfaceAlphaMod( face, (255/ni)*i );
  140. if (ret != 0) checkFailCount3++;
  141. }
  142. else if (mode == -4) {
  143. /* Crazy blending mode magic. */
  144. nmode = (i/4*j/4) % 4;
  145. if (nmode==0) {
  146. bmode = SDL_BLENDMODE_NONE;
  147. } else if (nmode==1) {
  148. bmode = SDL_BLENDMODE_BLEND;
  149. } else if (nmode==2) {
  150. bmode = SDL_BLENDMODE_ADD;
  151. } else if (nmode==3) {
  152. bmode = SDL_BLENDMODE_MOD;
  153. }
  154. ret = SDL_SetSurfaceBlendMode( face, bmode );
  155. if (ret != 0) checkFailCount4++;
  156. }
  157. /* Blitting. */
  158. rect.x = i;
  159. rect.y = j;
  160. ret = SDL_BlitSurface( face, NULL, testSurface, &rect );
  161. if (ret != 0) checkFailCount1++;
  162. }
  163. }
  164. SDLTest_AssertCheck(checkFailCount1 == 0, "Validate results from calls to SDL_BlitSurface, expected: 0, got: %i", checkFailCount1);
  165. SDLTest_AssertCheck(checkFailCount2 == 0, "Validate results from calls to SDL_SetSurfaceColorMod, expected: 0, got: %i", checkFailCount2);
  166. SDLTest_AssertCheck(checkFailCount3 == 0, "Validate results from calls to SDL_SetSurfaceAlphaMod, expected: 0, got: %i", checkFailCount3);
  167. SDLTest_AssertCheck(checkFailCount4 == 0, "Validate results from calls to SDL_SetSurfaceBlendMode, expected: 0, got: %i", checkFailCount4);
  168. /* Clean up */
  169. if (face != NULL) {
  170. SDL_FreeSurface(face);
  171. face = NULL;
  172. }
  173. }
  174. /* Helper to check that a file exists */
  175. void
  176. _AssertFileExist(const char *filename)
  177. {
  178. struct stat st;
  179. int ret = stat(filename, &st);
  180. SDLTest_AssertCheck(ret == 0, "Verify file '%s' exists", filename);
  181. }
  182. /* Test case functions */
  183. /**
  184. * @brief Tests sprite saving and loading
  185. */
  186. int
  187. surface_testSaveLoadBitmap(void *arg)
  188. {
  189. int ret;
  190. const char *sampleFilename = "testSaveLoadBitmap.bmp";
  191. SDL_Surface *face;
  192. SDL_Surface *rface;
  193. /* Create sample surface */
  194. face = SDLTest_ImageFace();
  195. SDLTest_AssertCheck(face != NULL, "Verify face surface is not NULL");
  196. if (face == NULL) return TEST_ABORTED;
  197. /* Delete test file; ignore errors */
  198. unlink(sampleFilename);
  199. /* Save a surface */
  200. ret = SDL_SaveBMP(face, sampleFilename);
  201. SDLTest_AssertPass("Call to SDL_SaveBMP()");
  202. SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SaveBMP, expected: 0, got: %i", ret);
  203. _AssertFileExist(sampleFilename);
  204. /* Load a surface */
  205. rface = SDL_LoadBMP(sampleFilename);
  206. SDLTest_AssertPass("Call to SDL_LoadBMP()");
  207. SDLTest_AssertCheck(rface != NULL, "Verify result from SDL_LoadBMP is not NULL");
  208. if (rface != NULL) {
  209. SDLTest_AssertCheck(face->w == rface->w, "Verify width of loaded surface, expected: %i, got: %i", face->w, rface->w);
  210. SDLTest_AssertCheck(face->h == rface->h, "Verify height of loaded surface, expected: %i, got: %i", face->h, rface->h);
  211. }
  212. /* Delete test file; ignore errors */
  213. unlink(sampleFilename);
  214. /* Clean up */
  215. if (face != NULL) {
  216. SDL_FreeSurface(face);
  217. face = NULL;
  218. }
  219. if (rface != NULL) {
  220. SDL_FreeSurface(rface);
  221. rface = NULL;
  222. }
  223. return TEST_COMPLETED;
  224. }
  225. /* !
  226. * Tests surface conversion.
  227. */
  228. int
  229. surface_testSurfaceConversion(void *arg)
  230. {
  231. SDL_Surface *rface = NULL, *face = NULL;
  232. int ret = 0;
  233. /* Create sample surface */
  234. face = SDLTest_ImageFace();
  235. SDLTest_AssertCheck(face != NULL, "Verify face surface is not NULL");
  236. if (face == NULL)
  237. return TEST_ABORTED;
  238. /* Set transparent pixel as the pixel at (0,0) */
  239. if (face->format->palette) {
  240. ret = SDL_SetColorKey(face, SDL_RLEACCEL, *(Uint8 *) face->pixels);
  241. SDLTest_AssertPass("Call to SDL_SetColorKey()");
  242. SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SetColorKey, expected: 0, got: %i", ret);
  243. }
  244. /* Convert to 32 bit to compare. */
  245. rface = SDL_ConvertSurface( face, testSurface->format, 0 );
  246. SDLTest_AssertPass("Call to SDL_ConvertSurface()");
  247. SDLTest_AssertCheck(rface != NULL, "Verify result from SDL_ConvertSurface is not NULL");
  248. /* Compare surface. */
  249. ret = SDLTest_CompareSurfaces( rface, face, 0 );
  250. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  251. /* Clean up. */
  252. if (face != NULL) {
  253. SDL_FreeSurface( face );
  254. face = NULL;
  255. }
  256. if (rface != NULL) {
  257. SDL_FreeSurface( rface );
  258. rface = NULL;
  259. }
  260. return TEST_COMPLETED;
  261. }
  262. /* !
  263. * Tests surface conversion across all pixel formats.
  264. */
  265. int
  266. surface_testCompleteSurfaceConversion(void *arg)
  267. {
  268. Uint32 pixel_formats[] = {
  269. SDL_PIXELFORMAT_INDEX8,
  270. SDL_PIXELFORMAT_RGB332,
  271. SDL_PIXELFORMAT_RGB444,
  272. SDL_PIXELFORMAT_RGB555,
  273. SDL_PIXELFORMAT_BGR555,
  274. SDL_PIXELFORMAT_ARGB4444,
  275. SDL_PIXELFORMAT_RGBA4444,
  276. SDL_PIXELFORMAT_ABGR4444,
  277. SDL_PIXELFORMAT_BGRA4444,
  278. SDL_PIXELFORMAT_ARGB1555,
  279. SDL_PIXELFORMAT_RGBA5551,
  280. SDL_PIXELFORMAT_ABGR1555,
  281. SDL_PIXELFORMAT_BGRA5551,
  282. SDL_PIXELFORMAT_RGB565,
  283. SDL_PIXELFORMAT_BGR565,
  284. SDL_PIXELFORMAT_RGB24,
  285. SDL_PIXELFORMAT_BGR24,
  286. SDL_PIXELFORMAT_RGB888,
  287. SDL_PIXELFORMAT_RGBX8888,
  288. SDL_PIXELFORMAT_BGR888,
  289. SDL_PIXELFORMAT_BGRX8888,
  290. SDL_PIXELFORMAT_ARGB8888,
  291. SDL_PIXELFORMAT_RGBA8888,
  292. SDL_PIXELFORMAT_ABGR8888,
  293. SDL_PIXELFORMAT_BGRA8888,
  294. SDL_PIXELFORMAT_ARGB2101010,
  295. };
  296. SDL_Surface *face = NULL, *cvt1, *cvt2, *final;
  297. SDL_PixelFormat *fmt1, *fmt2;
  298. int i, j, ret = 0;
  299. /* Create sample surface */
  300. face = SDLTest_ImageFace();
  301. SDLTest_AssertCheck(face != NULL, "Verify face surface is not NULL");
  302. if (face == NULL)
  303. return TEST_ABORTED;
  304. /* Set transparent pixel as the pixel at (0,0) */
  305. if (face->format->palette) {
  306. ret = SDL_SetColorKey(face, SDL_RLEACCEL, *(Uint8 *) face->pixels);
  307. SDLTest_AssertPass("Call to SDL_SetColorKey()");
  308. SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SetColorKey, expected: 0, got: %i", ret);
  309. }
  310. for ( i = 0; i < SDL_arraysize(pixel_formats); ++i ) {
  311. for ( j = 0; j < SDL_arraysize(pixel_formats); ++j ) {
  312. fmt1 = SDL_AllocFormat(pixel_formats[i]);
  313. SDL_assert(fmt1 != NULL);
  314. cvt1 = SDL_ConvertSurface(face, fmt1, 0);
  315. SDL_assert(cvt1 != NULL);
  316. fmt2 = SDL_AllocFormat(pixel_formats[j]);
  317. SDL_assert(fmt1 != NULL);
  318. cvt2 = SDL_ConvertSurface(cvt1, fmt2, 0);
  319. SDL_assert(cvt2 != NULL);
  320. if ( fmt1->BytesPerPixel == face->format->BytesPerPixel &&
  321. fmt2->BytesPerPixel == face->format->BytesPerPixel &&
  322. (fmt1->Amask != 0) == (face->format->Amask != 0) &&
  323. (fmt2->Amask != 0) == (face->format->Amask != 0) ) {
  324. final = SDL_ConvertSurface( cvt2, face->format, 0 );
  325. SDL_assert(final != NULL);
  326. /* Compare surface. */
  327. ret = SDLTest_CompareSurfaces( face, final, 0 );
  328. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  329. SDL_FreeSurface(final);
  330. }
  331. SDL_FreeSurface(cvt1);
  332. SDL_FreeFormat(fmt1);
  333. SDL_FreeSurface(cvt2);
  334. SDL_FreeFormat(fmt2);
  335. }
  336. }
  337. /* Clean up. */
  338. SDL_FreeSurface( face );
  339. return TEST_COMPLETED;
  340. }
  341. /**
  342. * @brief Tests sprite loading. A failure case.
  343. */
  344. int
  345. surface_testLoadFailure(void *arg)
  346. {
  347. SDL_Surface *face = SDL_LoadBMP("nonexistant.bmp");
  348. SDLTest_AssertCheck(face == NULL, "SDL_CreateLoadBmp");
  349. return TEST_COMPLETED;
  350. }
  351. /**
  352. * @brief Tests some blitting routines.
  353. */
  354. int
  355. surface_testBlit(void *arg)
  356. {
  357. int ret;
  358. SDL_Surface *compareSurface;
  359. /* Basic blitting */
  360. _testBlitBlendMode(-1);
  361. /* Verify result by comparing surfaces */
  362. compareSurface = SDLTest_ImageBlit();
  363. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  364. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  365. /* Clean up. */
  366. if (compareSurface != NULL) {
  367. SDL_FreeSurface( compareSurface );
  368. }
  369. return TEST_COMPLETED;
  370. }
  371. /**
  372. * @brief Tests some blitting routines with color mod
  373. */
  374. int
  375. surface_testBlitColorMod(void *arg)
  376. {
  377. int ret;
  378. SDL_Surface *compareSurface;
  379. /* Basic blitting with color mod */
  380. _testBlitBlendMode(-2);
  381. /* Verify result by comparing surfaces */
  382. compareSurface = SDLTest_ImageBlitColor();
  383. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  384. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  385. /* Clean up. */
  386. if (compareSurface != NULL) {
  387. SDL_FreeSurface( compareSurface );
  388. }
  389. return TEST_COMPLETED;
  390. }
  391. /**
  392. * @brief Tests some blitting routines with alpha mod
  393. */
  394. int
  395. surface_testBlitAlphaMod(void *arg)
  396. {
  397. int ret;
  398. SDL_Surface *compareSurface;
  399. /* Basic blitting with alpha mod */
  400. _testBlitBlendMode(-3);
  401. /* Verify result by comparing surfaces */
  402. compareSurface = SDLTest_ImageBlitAlpha();
  403. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  404. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  405. /* Clean up. */
  406. if (compareSurface != NULL) {
  407. SDL_FreeSurface( compareSurface );
  408. }
  409. return TEST_COMPLETED;
  410. }
  411. /**
  412. * @brief Tests some more blitting routines.
  413. */
  414. int
  415. surface_testBlitBlendNone(void *arg)
  416. {
  417. int ret;
  418. SDL_Surface *compareSurface;
  419. /* Basic blitting */
  420. _testBlitBlendMode(SDL_BLENDMODE_NONE);
  421. /* Verify result by comparing surfaces */
  422. compareSurface = SDLTest_ImageBlitBlendNone();
  423. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  424. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  425. /* Clean up. */
  426. if (compareSurface != NULL) {
  427. SDL_FreeSurface( compareSurface );
  428. }
  429. return TEST_COMPLETED;
  430. }
  431. /**
  432. * @brief Tests some more blitting routines.
  433. */
  434. int
  435. surface_testBlitBlendBlend(void *arg)
  436. {
  437. int ret;
  438. SDL_Surface *compareSurface;
  439. /* Blend blitting */
  440. _testBlitBlendMode(SDL_BLENDMODE_BLEND);
  441. /* Verify result by comparing surfaces */
  442. compareSurface = SDLTest_ImageBlitBlend();
  443. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  444. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  445. /* Clean up. */
  446. if (compareSurface != NULL) {
  447. SDL_FreeSurface( compareSurface );
  448. }
  449. return TEST_COMPLETED;
  450. }
  451. /**
  452. * @brief Tests some more blitting routines.
  453. */
  454. int
  455. surface_testBlitBlendAdd(void *arg)
  456. {
  457. int ret;
  458. SDL_Surface *compareSurface;
  459. /* Add blitting */
  460. _testBlitBlendMode(SDL_BLENDMODE_ADD);
  461. /* Verify result by comparing surfaces */
  462. compareSurface = SDLTest_ImageBlitBlendAdd();
  463. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  464. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  465. /* Clean up. */
  466. if (compareSurface != NULL) {
  467. SDL_FreeSurface( compareSurface );
  468. }
  469. return TEST_COMPLETED;
  470. }
  471. /**
  472. * @brief Tests some more blitting routines.
  473. */
  474. int
  475. surface_testBlitBlendMod(void *arg)
  476. {
  477. int ret;
  478. SDL_Surface *compareSurface;
  479. /* Mod blitting */
  480. _testBlitBlendMode(SDL_BLENDMODE_MOD);
  481. /* Verify result by comparing surfaces */
  482. compareSurface = SDLTest_ImageBlitBlendMod();
  483. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  484. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  485. /* Clean up. */
  486. if (compareSurface != NULL) {
  487. SDL_FreeSurface( compareSurface );
  488. }
  489. return TEST_COMPLETED;
  490. }
  491. /**
  492. * @brief Tests some more blitting routines with loop
  493. */
  494. int
  495. surface_testBlitBlendLoop(void *arg) {
  496. int ret;
  497. SDL_Surface *compareSurface;
  498. /* All blitting modes */
  499. _testBlitBlendMode(-4);
  500. /* Verify result by comparing surfaces */
  501. compareSurface = SDLTest_ImageBlitBlendAll();
  502. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  503. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  504. /* Clean up. */
  505. if (compareSurface != NULL) {
  506. SDL_FreeSurface(compareSurface);
  507. }
  508. return TEST_COMPLETED;
  509. }
  510. /* ================= Test References ================== */
  511. /* Surface test cases */
  512. static const SDLTest_TestCaseReference surfaceTest1 =
  513. { (SDLTest_TestCaseFp)surface_testSaveLoadBitmap, "surface_testSaveLoadBitmap", "Tests sprite saving and loading.", TEST_ENABLED};
  514. static const SDLTest_TestCaseReference surfaceTest2 =
  515. { (SDLTest_TestCaseFp)surface_testBlit, "surface_testBlit", "Tests basic blitting.", TEST_ENABLED};
  516. static const SDLTest_TestCaseReference surfaceTest3 =
  517. { (SDLTest_TestCaseFp)surface_testBlitBlendNone, "surface_testBlitBlendNone", "Tests blitting routines with none blending mode.", TEST_ENABLED};
  518. static const SDLTest_TestCaseReference surfaceTest4 =
  519. { (SDLTest_TestCaseFp)surface_testLoadFailure, "surface_testLoadFailure", "Tests sprite loading. A failure case.", TEST_ENABLED};
  520. static const SDLTest_TestCaseReference surfaceTest5 =
  521. { (SDLTest_TestCaseFp)surface_testSurfaceConversion, "surface_testSurfaceConversion", "Tests surface conversion.", TEST_ENABLED};
  522. static const SDLTest_TestCaseReference surfaceTest6 =
  523. { (SDLTest_TestCaseFp)surface_testCompleteSurfaceConversion, "surface_testCompleteSurfaceConversion", "Tests surface conversion across all pixel formats", TEST_ENABLED};
  524. static const SDLTest_TestCaseReference surfaceTest7 =
  525. { (SDLTest_TestCaseFp)surface_testBlitColorMod, "surface_testBlitColorMod", "Tests some blitting routines with color mod.", TEST_ENABLED};
  526. static const SDLTest_TestCaseReference surfaceTest8 =
  527. { (SDLTest_TestCaseFp)surface_testBlitAlphaMod, "surface_testBlitAlphaMod", "Tests some blitting routines with alpha mod.", TEST_ENABLED};
  528. /* TODO: rewrite test case, define new test data and re-enable; current implementation fails */
  529. static const SDLTest_TestCaseReference surfaceTest9 =
  530. { (SDLTest_TestCaseFp)surface_testBlitBlendLoop, "surface_testBlitBlendLoop", "Test blittin routines with verious blending modes", TEST_DISABLED};
  531. /* TODO: rewrite test case, define new test data and re-enable; current implementation fails */
  532. static const SDLTest_TestCaseReference surfaceTest10 =
  533. { (SDLTest_TestCaseFp)surface_testBlitBlendBlend, "surface_testBlitBlendBlend", "Tests blitting routines with blend blending mode.", TEST_DISABLED};
  534. /* TODO: rewrite test case, define new test data and re-enable; current implementation fails */
  535. static const SDLTest_TestCaseReference surfaceTest11 =
  536. { (SDLTest_TestCaseFp)surface_testBlitBlendAdd, "surface_testBlitBlendAdd", "Tests blitting routines with add blending mode.", TEST_DISABLED};
  537. static const SDLTest_TestCaseReference surfaceTest12 =
  538. { (SDLTest_TestCaseFp)surface_testBlitBlendMod, "surface_testBlitBlendMod", "Tests blitting routines with mod blending mode.", TEST_ENABLED};
  539. /* Sequence of Surface test cases */
  540. static const SDLTest_TestCaseReference *surfaceTests[] = {
  541. &surfaceTest1, &surfaceTest2, &surfaceTest3, &surfaceTest4, &surfaceTest5,
  542. &surfaceTest6, &surfaceTest7, &surfaceTest8, &surfaceTest9, &surfaceTest10,
  543. &surfaceTest11, &surfaceTest12, NULL
  544. };
  545. /* Surface test suite (global) */
  546. SDLTest_TestSuiteReference surfaceTestSuite = {
  547. "Surface",
  548. _surfaceSetUp,
  549. surfaceTests,
  550. _surfaceTearDown
  551. };