testautomation_surface.c 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672
  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. /*printf("Converting %s -> %s\n", SDL_GetPixelFormatName(pixel_formats[i]), SDL_GetPixelFormatName(pixel_formats[j]));*/
  313. fmt1 = SDL_AllocFormat(pixel_formats[i]);
  314. SDL_assert(fmt1 != NULL);
  315. cvt1 = SDL_ConvertSurface(face, fmt1, 0);
  316. SDL_assert(cvt1 != NULL);
  317. fmt2 = SDL_AllocFormat(pixel_formats[j]);
  318. SDL_assert(fmt1 != NULL);
  319. cvt2 = SDL_ConvertSurface(cvt1, fmt2, 0);
  320. SDL_assert(cvt2 != NULL);
  321. if ( fmt1->BytesPerPixel == face->format->BytesPerPixel &&
  322. fmt2->BytesPerPixel == face->format->BytesPerPixel &&
  323. (fmt1->Amask != 0) == (face->format->Amask != 0) &&
  324. (fmt2->Amask != 0) == (face->format->Amask != 0) ) {
  325. final = SDL_ConvertSurface( cvt2, face->format, 0 );
  326. SDL_assert(final != NULL);
  327. /* Compare surface. */
  328. ret = SDLTest_CompareSurfaces( face, final, 0 );
  329. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  330. SDL_FreeSurface(final);
  331. }
  332. SDL_FreeSurface(cvt1);
  333. SDL_FreeFormat(fmt1);
  334. SDL_FreeSurface(cvt2);
  335. SDL_FreeFormat(fmt2);
  336. }
  337. }
  338. /* Clean up. */
  339. SDL_FreeSurface( face );
  340. return TEST_COMPLETED;
  341. }
  342. /**
  343. * @brief Tests sprite loading. A failure case.
  344. */
  345. int
  346. surface_testLoadFailure(void *arg)
  347. {
  348. SDL_Surface *face = SDL_LoadBMP("nonexistant.bmp");
  349. SDLTest_AssertCheck(face == NULL, "SDL_CreateLoadBmp");
  350. return TEST_COMPLETED;
  351. }
  352. /**
  353. * @brief Tests some blitting routines.
  354. */
  355. int
  356. surface_testBlit(void *arg)
  357. {
  358. int ret;
  359. SDL_Surface *compareSurface;
  360. /* Basic blitting */
  361. _testBlitBlendMode(-1);
  362. /* Verify result by comparing surfaces */
  363. compareSurface = SDLTest_ImageBlit();
  364. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  365. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  366. /* Clean up. */
  367. if (compareSurface != NULL) {
  368. SDL_FreeSurface( compareSurface );
  369. }
  370. return TEST_COMPLETED;
  371. }
  372. /**
  373. * @brief Tests some blitting routines with color mod
  374. */
  375. int
  376. surface_testBlitColorMod(void *arg)
  377. {
  378. int ret;
  379. SDL_Surface *compareSurface;
  380. /* Basic blitting with color mod */
  381. _testBlitBlendMode(-2);
  382. /* Verify result by comparing surfaces */
  383. compareSurface = SDLTest_ImageBlitColor();
  384. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  385. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  386. /* Clean up. */
  387. if (compareSurface != NULL) {
  388. SDL_FreeSurface( compareSurface );
  389. }
  390. return TEST_COMPLETED;
  391. }
  392. /**
  393. * @brief Tests some blitting routines with alpha mod
  394. */
  395. int
  396. surface_testBlitAlphaMod(void *arg)
  397. {
  398. int ret;
  399. SDL_Surface *compareSurface;
  400. /* Basic blitting with alpha mod */
  401. _testBlitBlendMode(-3);
  402. /* Verify result by comparing surfaces */
  403. compareSurface = SDLTest_ImageBlitAlpha();
  404. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  405. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  406. /* Clean up. */
  407. if (compareSurface != NULL) {
  408. SDL_FreeSurface( compareSurface );
  409. }
  410. return TEST_COMPLETED;
  411. }
  412. /**
  413. * @brief Tests some more blitting routines.
  414. */
  415. int
  416. surface_testBlitBlendNone(void *arg)
  417. {
  418. int ret;
  419. SDL_Surface *compareSurface;
  420. /* Basic blitting */
  421. _testBlitBlendMode(SDL_BLENDMODE_NONE);
  422. /* Verify result by comparing surfaces */
  423. compareSurface = SDLTest_ImageBlitBlendNone();
  424. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  425. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  426. /* Clean up. */
  427. if (compareSurface != NULL) {
  428. SDL_FreeSurface( compareSurface );
  429. }
  430. return TEST_COMPLETED;
  431. }
  432. /**
  433. * @brief Tests some more blitting routines.
  434. */
  435. int
  436. surface_testBlitBlendBlend(void *arg)
  437. {
  438. int ret;
  439. SDL_Surface *compareSurface;
  440. /* Blend blitting */
  441. _testBlitBlendMode(SDL_BLENDMODE_BLEND);
  442. /* Verify result by comparing surfaces */
  443. compareSurface = SDLTest_ImageBlitBlend();
  444. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  445. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  446. /* Clean up. */
  447. if (compareSurface != NULL) {
  448. SDL_FreeSurface( compareSurface );
  449. }
  450. return TEST_COMPLETED;
  451. }
  452. /**
  453. * @brief Tests some more blitting routines.
  454. */
  455. int
  456. surface_testBlitBlendAdd(void *arg)
  457. {
  458. int ret;
  459. SDL_Surface *compareSurface;
  460. /* Add blitting */
  461. _testBlitBlendMode(SDL_BLENDMODE_ADD);
  462. /* Verify result by comparing surfaces */
  463. compareSurface = SDLTest_ImageBlitBlendAdd();
  464. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  465. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  466. /* Clean up. */
  467. if (compareSurface != NULL) {
  468. SDL_FreeSurface( compareSurface );
  469. }
  470. return TEST_COMPLETED;
  471. }
  472. /**
  473. * @brief Tests some more blitting routines.
  474. */
  475. int
  476. surface_testBlitBlendMod(void *arg)
  477. {
  478. int ret;
  479. SDL_Surface *compareSurface;
  480. /* Mod blitting */
  481. _testBlitBlendMode(SDL_BLENDMODE_MOD);
  482. /* Verify result by comparing surfaces */
  483. compareSurface = SDLTest_ImageBlitBlendMod();
  484. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  485. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  486. /* Clean up. */
  487. if (compareSurface != NULL) {
  488. SDL_FreeSurface( compareSurface );
  489. }
  490. return TEST_COMPLETED;
  491. }
  492. /**
  493. * @brief Tests some more blitting routines with loop
  494. */
  495. int
  496. surface_testBlitBlendLoop(void *arg) {
  497. int ret;
  498. SDL_Surface *compareSurface;
  499. /* All blitting modes */
  500. _testBlitBlendMode(-4);
  501. /* Verify result by comparing surfaces */
  502. compareSurface = SDLTest_ImageBlitBlendAll();
  503. ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
  504. SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
  505. /* Clean up. */
  506. if (compareSurface != NULL) {
  507. SDL_FreeSurface(compareSurface);
  508. }
  509. return TEST_COMPLETED;
  510. }
  511. /* ================= Test References ================== */
  512. /* Surface test cases */
  513. static const SDLTest_TestCaseReference surfaceTest1 =
  514. { (SDLTest_TestCaseFp)surface_testSaveLoadBitmap, "surface_testSaveLoadBitmap", "Tests sprite saving and loading.", TEST_ENABLED};
  515. static const SDLTest_TestCaseReference surfaceTest2 =
  516. { (SDLTest_TestCaseFp)surface_testBlit, "surface_testBlit", "Tests basic blitting.", TEST_ENABLED};
  517. static const SDLTest_TestCaseReference surfaceTest3 =
  518. { (SDLTest_TestCaseFp)surface_testBlitBlendNone, "surface_testBlitBlendNone", "Tests blitting routines with none blending mode.", TEST_ENABLED};
  519. static const SDLTest_TestCaseReference surfaceTest4 =
  520. { (SDLTest_TestCaseFp)surface_testLoadFailure, "surface_testLoadFailure", "Tests sprite loading. A failure case.", TEST_ENABLED};
  521. static const SDLTest_TestCaseReference surfaceTest5 =
  522. { (SDLTest_TestCaseFp)surface_testSurfaceConversion, "surface_testSurfaceConversion", "Tests surface conversion.", TEST_ENABLED};
  523. static const SDLTest_TestCaseReference surfaceTest6 =
  524. { (SDLTest_TestCaseFp)surface_testCompleteSurfaceConversion, "surface_testCompleteSurfaceConversion", "Tests surface conversion across all pixel formats", TEST_ENABLED};
  525. static const SDLTest_TestCaseReference surfaceTest7 =
  526. { (SDLTest_TestCaseFp)surface_testBlitColorMod, "surface_testBlitColorMod", "Tests some blitting routines with color mod.", TEST_ENABLED};
  527. static const SDLTest_TestCaseReference surfaceTest8 =
  528. { (SDLTest_TestCaseFp)surface_testBlitAlphaMod, "surface_testBlitAlphaMod", "Tests some blitting routines with alpha mod.", TEST_ENABLED};
  529. /* TODO: rewrite test case, define new test data and re-enable; current implementation fails */
  530. static const SDLTest_TestCaseReference surfaceTest9 =
  531. { (SDLTest_TestCaseFp)surface_testBlitBlendLoop, "surface_testBlitBlendLoop", "Test blittin routines with verious blending modes", TEST_DISABLED};
  532. /* TODO: rewrite test case, define new test data and re-enable; current implementation fails */
  533. static const SDLTest_TestCaseReference surfaceTest10 =
  534. { (SDLTest_TestCaseFp)surface_testBlitBlendBlend, "surface_testBlitBlendBlend", "Tests blitting routines with blend blending mode.", TEST_DISABLED};
  535. /* TODO: rewrite test case, define new test data and re-enable; current implementation fails */
  536. static const SDLTest_TestCaseReference surfaceTest11 =
  537. { (SDLTest_TestCaseFp)surface_testBlitBlendAdd, "surface_testBlitBlendAdd", "Tests blitting routines with add blending mode.", TEST_DISABLED};
  538. static const SDLTest_TestCaseReference surfaceTest12 =
  539. { (SDLTest_TestCaseFp)surface_testBlitBlendMod, "surface_testBlitBlendMod", "Tests blitting routines with mod blending mode.", TEST_ENABLED};
  540. /* Sequence of Surface test cases */
  541. static const SDLTest_TestCaseReference *surfaceTests[] = {
  542. &surfaceTest1, &surfaceTest2, &surfaceTest3, &surfaceTest4, &surfaceTest5,
  543. &surfaceTest6, &surfaceTest7, &surfaceTest8, &surfaceTest9, &surfaceTest10,
  544. &surfaceTest11, &surfaceTest12, NULL
  545. };
  546. /* Surface test suite (global) */
  547. SDLTest_TestSuiteReference surfaceTestSuite = {
  548. "Surface",
  549. _surfaceSetUp,
  550. surfaceTests,
  551. _surfaceTearDown
  552. };