mirror of
				https://github.com/Ryujinx/SDL.git
				synced 2025-10-22 20:57:04 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			827 lines
		
	
	
		
			31 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			827 lines
		
	
	
		
			31 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /**
 | |
|  * Original code: automated SDL surface test written by Edgar Simo "bobbens"
 | |
|  * Adapted/rewritten for test lib by Andreas Schiffler
 | |
|  */
 | |
| 
 | |
| /* Supress C4996 VS compiler warnings for unlink() */
 | |
| #define _CRT_SECURE_NO_DEPRECATE
 | |
| #define _CRT_NONSTDC_NO_DEPRECATE
 | |
| 
 | |
| #include <stdio.h>
 | |
| #ifndef _MSC_VER
 | |
| #include <unistd.h>
 | |
| #endif
 | |
| #include <sys/stat.h>
 | |
| 
 | |
| #include "SDL.h"
 | |
| #include "SDL_test.h"
 | |
| 
 | |
| #ifdef __MACOSX__
 | |
| #include <unistd.h> /* For unlink() */
 | |
| #endif
 | |
| 
 | |
| /* ================= Test Case Implementation ================== */
 | |
| 
 | |
| /* Shared test surface */
 | |
| 
 | |
| static SDL_Surface *referenceSurface = NULL;
 | |
| static SDL_Surface *testSurface = NULL;
 | |
| 
 | |
| /* Helper functions for the test cases */
 | |
| 
 | |
| #define TEST_SURFACE_WIDTH testSurface->w
 | |
| #define TEST_SURFACE_HEIGHT testSurface->h
 | |
| 
 | |
| /* Fixture */
 | |
| 
 | |
| /* Create a 32-bit writable surface for blitting tests */
 | |
| void
 | |
| _surfaceSetUp(void *arg)
 | |
| {
 | |
|     int result;
 | |
|     SDL_BlendMode blendMode = SDL_BLENDMODE_NONE;
 | |
|     SDL_BlendMode currentBlendMode;
 | |
|     Uint32 rmask, gmask, bmask, amask;
 | |
| #if SDL_BYTEORDER == SDL_BIG_ENDIAN
 | |
|     rmask = 0xff000000;
 | |
|     gmask = 0x00ff0000;
 | |
|     bmask = 0x0000ff00;
 | |
|     amask = 0x000000ff;
 | |
| #else
 | |
|     rmask = 0x000000ff;
 | |
|     gmask = 0x0000ff00;
 | |
|     bmask = 0x00ff0000;
 | |
|     amask = 0xff000000;
 | |
| #endif
 | |
| 
 | |
|     referenceSurface = SDLTest_ImageBlit(); /* For size info */
 | |
|     testSurface = SDL_CreateRGBSurface(SDL_SWSURFACE, referenceSurface->w, referenceSurface->h, 32, rmask, gmask, bmask, amask);
 | |
|     SDLTest_AssertCheck(testSurface != NULL, "Check that testSurface is not NULL");
 | |
|     if (testSurface != NULL) {
 | |
|       /* Disable blend mode for target surface */
 | |
|       result = SDL_SetSurfaceBlendMode(testSurface, blendMode);
 | |
|       SDLTest_AssertCheck(result == 0, "Validate result from SDL_SetSurfaceBlendMode, expected: 0, got: %i", result);
 | |
|       result = SDL_GetSurfaceBlendMode(testSurface, ¤tBlendMode);
 | |
|       SDLTest_AssertCheck(result == 0, "Validate result from SDL_GetSurfaceBlendMode, expected: 0, got: %i", result);
 | |
|       SDLTest_AssertCheck(currentBlendMode == blendMode, "Validate blendMode, expected: %i, got: %i", blendMode, currentBlendMode);
 | |
|     }
 | |
| }
 | |
| 
 | |
| void
 | |
| _surfaceTearDown(void *arg)
 | |
| {
 | |
|     SDL_FreeSurface(referenceSurface);
 | |
|     referenceSurface = NULL;
 | |
|     SDL_FreeSurface(testSurface);
 | |
|     testSurface = NULL;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Helper that clears the test surface
 | |
|  */
 | |
| void _clearTestSurface()
 | |
| {
 | |
|     int ret;
 | |
|     Uint32 color;
 | |
| 
 | |
|     /* Clear surface. */
 | |
|     color = SDL_MapRGBA( testSurface->format, 0, 0, 0, 0);
 | |
|     SDLTest_AssertPass("Call to SDL_MapRGBA()");
 | |
|     ret = SDL_FillRect( testSurface, NULL, color);
 | |
|     SDLTest_AssertPass("Call to SDL_FillRect()");
 | |
|     SDLTest_AssertCheck(ret == 0, "Verify result from SDL_FillRect, expected: 0, got: %i", ret);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * 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.
 | |
|  */
 | |
| void _testBlitBlendMode(int mode)
 | |
| {
 | |
|     int ret;
 | |
|     int i, j, ni, nj;
 | |
|     SDL_Surface *face;
 | |
|     SDL_Rect rect;
 | |
|     int nmode;
 | |
|     SDL_BlendMode bmode;
 | |
|     int checkFailCount1;
 | |
|     int checkFailCount2;
 | |
|     int checkFailCount3;
 | |
|     int checkFailCount4;
 | |
| 
 | |
|     /* Check test surface */
 | |
|     SDLTest_AssertCheck(testSurface != NULL, "Verify testSurface is not NULL");
 | |
|     if (testSurface == NULL) return;
 | |
| 
 | |
|     /* Create sample surface */
 | |
|     face = SDLTest_ImageFace();
 | |
|     SDLTest_AssertCheck(face != NULL, "Verify face surface is not NULL");
 | |
|     if (face == NULL) return;
 | |
| 
 | |
|         /* Reset alpha modulation */
 | |
|     ret = SDL_SetSurfaceAlphaMod(face, 255);
 | |
|     SDLTest_AssertPass("Call to SDL_SetSurfaceAlphaMod()");
 | |
|     SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SetSurfaceAlphaMod(), expected: 0, got: %i", ret);
 | |
| 
 | |
|         /* Reset color modulation */
 | |
|     ret = SDL_SetSurfaceColorMod(face, 255, 255, 255);
 | |
|     SDLTest_AssertPass("Call to SDL_SetSurfaceColorMod()");
 | |
|     SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SetSurfaceColorMod(), expected: 0, got: %i", ret);
 | |
| 
 | |
|         /* Reset color key */
 | |
|     ret = SDL_SetColorKey(face, SDL_FALSE, 0);
 | |
|     SDLTest_AssertPass("Call to SDL_SetColorKey()");
 | |
|     SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SetColorKey(), expected: 0, got: %i", ret);
 | |
| 
 | |
|     /* Clear the test surface */
 | |
|         _clearTestSurface();
 | |
| 
 | |
|     /* Target rect size */
 | |
|     rect.w = face->w;
 | |
|     rect.h = face->h;
 | |
| 
 | |
|     /* Steps to take */
 | |
|     ni = testSurface->w - face->w;
 | |
|     nj = testSurface->h - face->h;
 | |
| 
 | |
|     /* Optionally set blend mode. */
 | |
|     if (mode >= 0) {
 | |
|         ret = SDL_SetSurfaceBlendMode( face, (SDL_BlendMode)mode );
 | |
|         SDLTest_AssertPass("Call to SDL_SetSurfaceBlendMode()");
 | |
|         SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SetSurfaceBlendMode(..., %i), expected: 0, got: %i", mode, ret);
 | |
|     }
 | |
| 
 | |
|     /* Test blend mode. */
 | |
|     checkFailCount1 = 0;
 | |
|     checkFailCount2 = 0;
 | |
|     checkFailCount3 = 0;
 | |
|     checkFailCount4 = 0;
 | |
|     for (j=0; j <= nj; j+=4) {
 | |
|       for (i=0; i <= ni; i+=4) {
 | |
|         if (mode == -2) {
 | |
|             /* Set color mod. */
 | |
|             ret = SDL_SetSurfaceColorMod( face, (255/nj)*j, (255/ni)*i, (255/nj)*j );
 | |
|             if (ret != 0) checkFailCount2++;
 | |
|         }
 | |
|         else if (mode == -3) {
 | |
|             /* Set alpha mod. */
 | |
|             ret = SDL_SetSurfaceAlphaMod( face, (255/ni)*i );
 | |
|             if (ret != 0) checkFailCount3++;
 | |
|         }
 | |
|         else if (mode == -4) {
 | |
|             /* Crazy blending mode magic. */
 | |
|             nmode = (i/4*j/4) % 4;
 | |
|             if (nmode==0) {
 | |
|                 bmode = SDL_BLENDMODE_NONE;
 | |
|             } else if (nmode==1) {
 | |
|                 bmode = SDL_BLENDMODE_BLEND;
 | |
|             } else if (nmode==2) {
 | |
|                 bmode = SDL_BLENDMODE_ADD;
 | |
|             } else if (nmode==3) {
 | |
|                 bmode = SDL_BLENDMODE_MOD;
 | |
|             } else {
 | |
|                 /* Should be impossible, but some static checkers are too imprecise and will complain */
 | |
|                 SDLTest_LogError("Invalid: nmode=%d", nmode);
 | |
|                 return;
 | |
|             }
 | |
|             ret = SDL_SetSurfaceBlendMode( face, bmode );
 | |
|             if (ret != 0) checkFailCount4++;
 | |
|         }
 | |
| 
 | |
|          /* Blitting. */
 | |
|          rect.x = i;
 | |
|          rect.y = j;
 | |
|          ret = SDL_BlitSurface( face, NULL, testSurface, &rect );
 | |
|          if (ret != 0) checkFailCount1++;
 | |
|       }
 | |
|     }
 | |
|     SDLTest_AssertCheck(checkFailCount1 == 0, "Validate results from calls to SDL_BlitSurface, expected: 0, got: %i", checkFailCount1);
 | |
|     SDLTest_AssertCheck(checkFailCount2 == 0, "Validate results from calls to SDL_SetSurfaceColorMod, expected: 0, got: %i", checkFailCount2);
 | |
|     SDLTest_AssertCheck(checkFailCount3 == 0, "Validate results from calls to SDL_SetSurfaceAlphaMod, expected: 0, got: %i", checkFailCount3);
 | |
|     SDLTest_AssertCheck(checkFailCount4 == 0, "Validate results from calls to SDL_SetSurfaceBlendMode, expected: 0, got: %i", checkFailCount4);
 | |
| 
 | |
|     /* Clean up */
 | |
|     SDL_FreeSurface(face);
 | |
|     face = NULL;
 | |
| }
 | |
| 
 | |
| /* Helper to check that a file exists */
 | |
| void
 | |
| _AssertFileExist(const char *filename)
 | |
| {
 | |
|     struct stat st;
 | |
|     int ret = stat(filename, &st);
 | |
| 
 | |
|     SDLTest_AssertCheck(ret == 0, "Verify file '%s' exists", filename);
 | |
| }
 | |
| 
 | |
| 
 | |
| /* Test case functions */
 | |
| 
 | |
| /**
 | |
|  * @brief Tests sprite saving and loading
 | |
|  */
 | |
| int
 | |
| surface_testSaveLoadBitmap(void *arg)
 | |
| {
 | |
|     int ret;
 | |
|     const char *sampleFilename = "testSaveLoadBitmap.bmp";
 | |
|     SDL_Surface *face;
 | |
|     SDL_Surface *rface;
 | |
| 
 | |
|     /* Create sample surface */
 | |
|     face = SDLTest_ImageFace();
 | |
|     SDLTest_AssertCheck(face != NULL, "Verify face surface is not NULL");
 | |
|     if (face == NULL) return TEST_ABORTED;
 | |
| 
 | |
|     /* Delete test file; ignore errors */
 | |
|     unlink(sampleFilename);
 | |
| 
 | |
|     /* Save a surface */
 | |
|     ret = SDL_SaveBMP(face, sampleFilename);
 | |
|     SDLTest_AssertPass("Call to SDL_SaveBMP()");
 | |
|     SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SaveBMP, expected: 0, got: %i", ret);
 | |
|     _AssertFileExist(sampleFilename);
 | |
| 
 | |
|     /* Load a surface */
 | |
|     rface = SDL_LoadBMP(sampleFilename);
 | |
|     SDLTest_AssertPass("Call to SDL_LoadBMP()");
 | |
|     SDLTest_AssertCheck(rface != NULL, "Verify result from SDL_LoadBMP is not NULL");
 | |
|     if (rface != NULL) {
 | |
|         SDLTest_AssertCheck(face->w == rface->w, "Verify width of loaded surface, expected: %i, got: %i", face->w, rface->w);
 | |
|         SDLTest_AssertCheck(face->h == rface->h, "Verify height of loaded surface, expected: %i, got: %i", face->h, rface->h);
 | |
|     }
 | |
| 
 | |
|     /* Delete test file; ignore errors */
 | |
|     unlink(sampleFilename);
 | |
| 
 | |
|     /* Clean up */
 | |
|     SDL_FreeSurface(face);
 | |
|     face = NULL;
 | |
|     SDL_FreeSurface(rface);
 | |
|     rface = NULL;
 | |
| 
 | |
|     return TEST_COMPLETED;
 | |
| }
 | |
| 
 | |
| /* !
 | |
|  *  Tests surface conversion.
 | |
|  */
 | |
| int
 | |
| surface_testSurfaceConversion(void *arg)
 | |
| {
 | |
|     SDL_Surface *rface = NULL, *face = NULL;
 | |
|     int ret = 0;
 | |
| 
 | |
|     /* Create sample surface */
 | |
|     face = SDLTest_ImageFace();
 | |
|     SDLTest_AssertCheck(face != NULL, "Verify face surface is not NULL");
 | |
|     if (face == NULL)
 | |
|         return TEST_ABORTED;
 | |
| 
 | |
|     /* Set transparent pixel as the pixel at (0,0) */
 | |
|     if (face->format->palette) {
 | |
|        ret = SDL_SetColorKey(face, SDL_RLEACCEL, *(Uint8 *) face->pixels);
 | |
|        SDLTest_AssertPass("Call to SDL_SetColorKey()");
 | |
|        SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SetColorKey, expected: 0, got: %i", ret);
 | |
|     }
 | |
| 
 | |
|     /* Convert to 32 bit to compare. */
 | |
|     rface = SDL_ConvertSurface( face, testSurface->format, 0 );
 | |
|     SDLTest_AssertPass("Call to SDL_ConvertSurface()");
 | |
|     SDLTest_AssertCheck(rface != NULL, "Verify result from SDL_ConvertSurface is not NULL");
 | |
| 
 | |
|     /* Compare surface. */
 | |
|     ret = SDLTest_CompareSurfaces( rface, face, 0 );
 | |
|     SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
 | |
| 
 | |
|     /* Clean up. */
 | |
|     SDL_FreeSurface(face);
 | |
|     face = NULL;
 | |
|     SDL_FreeSurface(rface);
 | |
|     rface = NULL;
 | |
| 
 | |
|     return TEST_COMPLETED;
 | |
| }
 | |
| 
 | |
| 
 | |
| /* !
 | |
|  *  Tests surface conversion across all pixel formats.
 | |
|  */
 | |
| int
 | |
| surface_testCompleteSurfaceConversion(void *arg)
 | |
| {
 | |
|     Uint32 pixel_formats[] = {
 | |
|         SDL_PIXELFORMAT_INDEX8,
 | |
|         SDL_PIXELFORMAT_RGB332,
 | |
|         SDL_PIXELFORMAT_RGB444,
 | |
|         SDL_PIXELFORMAT_BGR444,
 | |
|         SDL_PIXELFORMAT_RGB555,
 | |
|         SDL_PIXELFORMAT_BGR555,
 | |
|         SDL_PIXELFORMAT_ARGB4444,
 | |
|         SDL_PIXELFORMAT_RGBA4444,
 | |
|         SDL_PIXELFORMAT_ABGR4444,
 | |
|         SDL_PIXELFORMAT_BGRA4444,
 | |
|         SDL_PIXELFORMAT_ARGB1555,
 | |
|         SDL_PIXELFORMAT_RGBA5551,
 | |
|         SDL_PIXELFORMAT_ABGR1555,
 | |
|         SDL_PIXELFORMAT_BGRA5551,
 | |
|         SDL_PIXELFORMAT_RGB565,
 | |
|         SDL_PIXELFORMAT_BGR565,
 | |
|         SDL_PIXELFORMAT_RGB24,
 | |
|         SDL_PIXELFORMAT_BGR24,
 | |
|         SDL_PIXELFORMAT_RGB888,
 | |
|         SDL_PIXELFORMAT_RGBX8888,
 | |
|         SDL_PIXELFORMAT_BGR888,
 | |
|         SDL_PIXELFORMAT_BGRX8888,
 | |
|         SDL_PIXELFORMAT_ARGB8888,
 | |
|         SDL_PIXELFORMAT_RGBA8888,
 | |
|         SDL_PIXELFORMAT_ABGR8888,
 | |
|         SDL_PIXELFORMAT_BGRA8888,
 | |
|         SDL_PIXELFORMAT_ARGB2101010,
 | |
|     };
 | |
|     SDL_Surface *face = NULL, *cvt1, *cvt2, *final;
 | |
|     SDL_PixelFormat *fmt1, *fmt2;
 | |
|     int i, j, ret = 0;
 | |
| 
 | |
|     /* Create sample surface */
 | |
|     face = SDLTest_ImageFace();
 | |
|     SDLTest_AssertCheck(face != NULL, "Verify face surface is not NULL");
 | |
|     if (face == NULL)
 | |
|         return TEST_ABORTED;
 | |
| 
 | |
|     /* Set transparent pixel as the pixel at (0,0) */
 | |
|     if (face->format->palette) {
 | |
|        ret = SDL_SetColorKey(face, SDL_RLEACCEL, *(Uint8 *) face->pixels);
 | |
|        SDLTest_AssertPass("Call to SDL_SetColorKey()");
 | |
|        SDLTest_AssertCheck(ret == 0, "Verify result from SDL_SetColorKey, expected: 0, got: %i", ret);
 | |
|     }
 | |
| 
 | |
|     for ( i = 0; i < SDL_arraysize(pixel_formats); ++i ) {
 | |
|         for ( j = 0; j < SDL_arraysize(pixel_formats); ++j ) {
 | |
|             fmt1 = SDL_AllocFormat(pixel_formats[i]);
 | |
|             SDL_assert(fmt1 != NULL);
 | |
|             cvt1 = SDL_ConvertSurface(face, fmt1, 0);
 | |
|             SDL_assert(cvt1 != NULL);
 | |
| 
 | |
|             fmt2 = SDL_AllocFormat(pixel_formats[j]);
 | |
|             SDL_assert(fmt1 != NULL);
 | |
|             cvt2 = SDL_ConvertSurface(cvt1, fmt2, 0);
 | |
|             SDL_assert(cvt2 != NULL);
 | |
| 
 | |
|             if ( fmt1->BytesPerPixel == face->format->BytesPerPixel &&
 | |
|                  fmt2->BytesPerPixel == face->format->BytesPerPixel &&
 | |
|                  (fmt1->Amask != 0) == (face->format->Amask != 0) &&
 | |
|                  (fmt2->Amask != 0) == (face->format->Amask != 0) ) {
 | |
|                 final = SDL_ConvertSurface( cvt2, face->format, 0 );
 | |
|                 SDL_assert(final != NULL);
 | |
| 
 | |
|                 /* Compare surface. */
 | |
|                 ret = SDLTest_CompareSurfaces( face, final, 0 );
 | |
|                 SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
 | |
|                 SDL_FreeSurface(final);
 | |
|             }
 | |
| 
 | |
|             SDL_FreeSurface(cvt1);
 | |
|             SDL_FreeFormat(fmt1);
 | |
|             SDL_FreeSurface(cvt2);
 | |
|             SDL_FreeFormat(fmt2);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /* Clean up. */
 | |
|     SDL_FreeSurface( face );
 | |
| 
 | |
|     return TEST_COMPLETED;
 | |
| }
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * @brief Tests sprite loading. A failure case.
 | |
|  */
 | |
| int
 | |
| surface_testLoadFailure(void *arg)
 | |
| {
 | |
|     SDL_Surface *face = SDL_LoadBMP("nonexistant.bmp");
 | |
|     SDLTest_AssertCheck(face == NULL, "SDL_CreateLoadBmp");
 | |
| 
 | |
|     return TEST_COMPLETED;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief Tests some blitting routines.
 | |
|  */
 | |
| int
 | |
| surface_testBlit(void *arg)
 | |
| {
 | |
|    int ret;
 | |
|    SDL_Surface *compareSurface;
 | |
| 
 | |
|    /* Basic blitting */
 | |
|    _testBlitBlendMode(-1);
 | |
| 
 | |
|    /* Verify result by comparing surfaces */
 | |
|    compareSurface = SDLTest_ImageBlit();
 | |
|    ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
 | |
|    SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
 | |
| 
 | |
|    /* Clean up. */
 | |
|    SDL_FreeSurface(compareSurface);
 | |
| 
 | |
|    return TEST_COMPLETED;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief Tests some blitting routines with color mod
 | |
|  */
 | |
| int
 | |
| surface_testBlitColorMod(void *arg)
 | |
| {
 | |
|    int ret;
 | |
|    SDL_Surface *compareSurface;
 | |
| 
 | |
|    /* Basic blitting with color mod */
 | |
|    _testBlitBlendMode(-2);
 | |
| 
 | |
|    /* Verify result by comparing surfaces */
 | |
|    compareSurface = SDLTest_ImageBlitColor();
 | |
|    ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
 | |
|    SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
 | |
| 
 | |
|    /* Clean up. */
 | |
|    SDL_FreeSurface(compareSurface);
 | |
| 
 | |
|    return TEST_COMPLETED;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief Tests some blitting routines with alpha mod
 | |
|  */
 | |
| int
 | |
| surface_testBlitAlphaMod(void *arg)
 | |
| {
 | |
|    int ret;
 | |
|    SDL_Surface *compareSurface;
 | |
| 
 | |
|    /* Basic blitting with alpha mod */
 | |
|    _testBlitBlendMode(-3);
 | |
| 
 | |
|    /* Verify result by comparing surfaces */
 | |
|    compareSurface = SDLTest_ImageBlitAlpha();
 | |
|    ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
 | |
|    SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
 | |
| 
 | |
|    /* Clean up. */
 | |
|    SDL_FreeSurface(compareSurface);
 | |
| 
 | |
|    return TEST_COMPLETED;
 | |
| }
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * @brief Tests some more blitting routines.
 | |
|  */
 | |
| int
 | |
| surface_testBlitBlendNone(void *arg)
 | |
| {
 | |
|    int ret;
 | |
|    SDL_Surface *compareSurface;
 | |
| 
 | |
|    /* Basic blitting */
 | |
|    _testBlitBlendMode(SDL_BLENDMODE_NONE);
 | |
| 
 | |
|    /* Verify result by comparing surfaces */
 | |
|    compareSurface = SDLTest_ImageBlitBlendNone();
 | |
|    ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
 | |
|    SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
 | |
| 
 | |
|    /* Clean up. */
 | |
|    SDL_FreeSurface(compareSurface);
 | |
| 
 | |
|    return TEST_COMPLETED;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief Tests some more blitting routines.
 | |
|  */
 | |
| int
 | |
| surface_testBlitBlendBlend(void *arg)
 | |
| {
 | |
|    int ret;
 | |
|    SDL_Surface *compareSurface;
 | |
| 
 | |
|    /* Blend blitting */
 | |
|    _testBlitBlendMode(SDL_BLENDMODE_BLEND);
 | |
| 
 | |
|    /* Verify result by comparing surfaces */
 | |
|    compareSurface = SDLTest_ImageBlitBlend();
 | |
|    ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
 | |
|    SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
 | |
| 
 | |
|    /* Clean up. */
 | |
|    SDL_FreeSurface(compareSurface);
 | |
| 
 | |
|    return TEST_COMPLETED;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief Tests some more blitting routines.
 | |
|  */
 | |
| int
 | |
| surface_testBlitBlendAdd(void *arg)
 | |
| {
 | |
|    int ret;
 | |
|    SDL_Surface *compareSurface;
 | |
| 
 | |
|    /* Add blitting */
 | |
|    _testBlitBlendMode(SDL_BLENDMODE_ADD);
 | |
| 
 | |
|    /* Verify result by comparing surfaces */
 | |
|    compareSurface = SDLTest_ImageBlitBlendAdd();
 | |
|    ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
 | |
|    SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
 | |
| 
 | |
|    /* Clean up. */
 | |
|    SDL_FreeSurface(compareSurface);
 | |
| 
 | |
|    return TEST_COMPLETED;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief Tests some more blitting routines.
 | |
|  */
 | |
| int
 | |
| surface_testBlitBlendMod(void *arg)
 | |
| {
 | |
|    int ret;
 | |
|    SDL_Surface *compareSurface;
 | |
| 
 | |
|    /* Mod blitting */
 | |
|    _testBlitBlendMode(SDL_BLENDMODE_MOD);
 | |
| 
 | |
|    /* Verify result by comparing surfaces */
 | |
|    compareSurface = SDLTest_ImageBlitBlendMod();
 | |
|    ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
 | |
|    SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
 | |
| 
 | |
|    /* Clean up. */
 | |
|    SDL_FreeSurface(compareSurface);
 | |
| 
 | |
|    return TEST_COMPLETED;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief Tests some more blitting routines with loop
 | |
|  */
 | |
| int
 | |
| surface_testBlitBlendLoop(void *arg) {
 | |
| 
 | |
|    int ret;
 | |
|    SDL_Surface *compareSurface;
 | |
| 
 | |
|    /* All blitting modes */
 | |
|    _testBlitBlendMode(-4);
 | |
| 
 | |
|    /* Verify result by comparing surfaces */
 | |
|    compareSurface = SDLTest_ImageBlitBlendAll();
 | |
|    ret = SDLTest_CompareSurfaces( testSurface, compareSurface, 0 );
 | |
|    SDLTest_AssertCheck(ret == 0, "Validate result from SDLTest_CompareSurfaces, expected: 0, got: %i", ret);
 | |
| 
 | |
|    /* Clean up. */
 | |
|    SDL_FreeSurface(compareSurface);
 | |
| 
 | |
|    return TEST_COMPLETED;
 | |
| 
 | |
| }
 | |
| 
 | |
| int
 | |
| surface_testOverflow(void *arg)
 | |
| {
 | |
|     char buf[1024];
 | |
|     const char *expectedError;
 | |
|     SDL_Surface *surface;
 | |
| 
 | |
|     SDL_memset(buf, '\0', sizeof(buf));
 | |
| 
 | |
|     expectedError = "Parameter 'width' is invalid";
 | |
|     surface = SDL_CreateRGBSurfaceWithFormat(0, -3, 100, 8, SDL_PIXELFORMAT_INDEX8);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect negative width");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, -1, 1, 8, 4, SDL_PIXELFORMAT_INDEX8);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect negative width");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, -1, 1, 32, 4, 0xFF000000, 0x00FF0000, 0x0000FF00, 0x000000FF);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect negative width");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
| 
 | |
|     expectedError = "Parameter 'height' is invalid";
 | |
|     surface = SDL_CreateRGBSurfaceWithFormat(0, 100, -3, 8, SDL_PIXELFORMAT_INDEX8);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect negative height");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, 1, -1, 8, 4, SDL_PIXELFORMAT_INDEX8);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect negative height");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, 1, -1, 32, 4, 0xFF000000, 0x00FF0000, 0x0000FF00, 0x000000FF);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect negative height");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
| 
 | |
|     expectedError = "Parameter 'pitch' is invalid";
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, 4, 1, 8, -1, SDL_PIXELFORMAT_INDEX8);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect negative pitch");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, 1, 1, 32, -1, 0xFF000000, 0x00FF0000, 0x0000FF00, 0x000000FF);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect negative pitch");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
| 
 | |
|     /* Less than 1 byte per pixel: the pitch can legitimately be less than
 | |
|      * the width, but it must be enough to hold the appropriate number of
 | |
|      * bits per pixel. SDL_PIXELFORMAT_INDEX4* needs 1 byte per 2 pixels. */
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, 6, 1, 4, 3, SDL_PIXELFORMAT_INDEX4LSB);
 | |
|     SDLTest_AssertCheck(surface != NULL, "6px * 4 bits per px fits in 3 bytes: %s",
 | |
|                         surface != NULL ? "(success)" : SDL_GetError());
 | |
|     SDL_FreeSurface(surface);
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, 6, 1, 4, 3, 0, 0, 0, 0);
 | |
|     SDLTest_AssertCheck(surface != NULL, "6px * 4 bits per px fits in 3 bytes: %s",
 | |
|                         surface != NULL ? "(success)" : SDL_GetError());
 | |
|     SDL_FreeSurface(surface);
 | |
| 
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, 7, 1, 4, 3, SDL_PIXELFORMAT_INDEX4LSB);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect pitch < width * bpp");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, 7, 1, 4, 3, 0, 0, 0, 0);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect pitch < width * bpp");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
| 
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, 7, 1, 4, 4, SDL_PIXELFORMAT_INDEX4LSB);
 | |
|     SDLTest_AssertCheck(surface != NULL, "7px * 4 bits per px fits in 4 bytes: %s",
 | |
|                         surface != NULL ? "(success)" : SDL_GetError());
 | |
|     SDL_FreeSurface(surface);
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, 7, 1, 4, 4, 0, 0, 0, 0);
 | |
|     SDLTest_AssertCheck(surface != NULL, "7px * 4 bits per px fits in 4 bytes: %s",
 | |
|                         surface != NULL ? "(success)" : SDL_GetError());
 | |
|     SDL_FreeSurface(surface);
 | |
| 
 | |
|     /* SDL_PIXELFORMAT_INDEX1* needs 1 byte per 8 pixels. */
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, 16, 1, 1, 2, SDL_PIXELFORMAT_INDEX1LSB);
 | |
|     SDLTest_AssertCheck(surface != NULL, "16px * 1 bit per px fits in 2 bytes: %s",
 | |
|                         surface != NULL ? "(success)" : SDL_GetError());
 | |
|     SDL_FreeSurface(surface);
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, 16, 1, 1, 2, 0, 0, 0, 0);
 | |
|     SDLTest_AssertCheck(surface != NULL, "16px * 1 bit per px fits in 2 bytes: %s",
 | |
|                         surface != NULL ? "(success)" : SDL_GetError());
 | |
|     SDL_FreeSurface(surface);
 | |
| 
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, 17, 1, 1, 2, SDL_PIXELFORMAT_INDEX1LSB);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect pitch < width * bpp");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, 17, 1, 1, 2, 0, 0, 0, 0);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect pitch < width * bpp");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
| 
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, 17, 1, 1, 3, SDL_PIXELFORMAT_INDEX1LSB);
 | |
|     SDLTest_AssertCheck(surface != NULL, "17px * 1 bit per px fits in 3 bytes: %s",
 | |
|                         surface != NULL ? "(success)" : SDL_GetError());
 | |
|     SDL_FreeSurface(surface);
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, 7, 1, 1, 3, 0, 0, 0, 0);
 | |
|     SDLTest_AssertCheck(surface != NULL, "17px * 1 bit per px fits in 3 bytes: %s",
 | |
|                         surface != NULL ? "(success)" : SDL_GetError());
 | |
|     SDL_FreeSurface(surface);
 | |
| 
 | |
|     /* SDL_PIXELFORMAT_INDEX8 and SDL_PIXELFORMAT_RGB332 require 1 byte per pixel. */
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, 5, 1, 8, 5, SDL_PIXELFORMAT_RGB332);
 | |
|     SDLTest_AssertCheck(surface != NULL, "5px * 8 bits per px fits in 5 bytes: %s",
 | |
|                         surface != NULL ? "(success)" : SDL_GetError());
 | |
|     SDL_FreeSurface(surface);
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, 5, 1, 8, 5, 0, 0, 0, 0);
 | |
|     SDLTest_AssertCheck(surface != NULL, "5px * 8 bits per px fits in 5 bytes: %s",
 | |
|                         surface != NULL ? "(success)" : SDL_GetError());
 | |
|     SDL_FreeSurface(surface);
 | |
| 
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, 6, 1, 8, 5, SDL_PIXELFORMAT_RGB332);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect pitch < width * bpp");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, 6, 1, 8, 5, 0, 0, 0, 0);
 | |
|     SDLTest_AssertCheck(surface == NULL, "Should detect pitch < width * bpp");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
| 
 | |
|     /* Everything else requires more than 1 byte per pixel, and rounds up
 | |
|      * each pixel to an integer number of bytes (e.g. RGB555 is really
 | |
|      * XRGB1555, with 1 bit per pixel wasted). */
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, 3, 1, 15, 6, SDL_PIXELFORMAT_RGB555);
 | |
|     SDLTest_AssertCheck(surface != NULL, "3px * 15 (really 16) bits per px fits in 6 bytes: %s",
 | |
|                         surface != NULL ? "(success)" : SDL_GetError());
 | |
|     SDL_FreeSurface(surface);
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, 3, 1, 15, 6, 0, 0, 0, 0);
 | |
|     SDLTest_AssertCheck(surface != NULL, "5px * 15 (really 16) bits per px fits in 6 bytes: %s",
 | |
|                         surface != NULL ? "(success)" : SDL_GetError());
 | |
|     SDL_FreeSurface(surface);
 | |
| 
 | |
|     surface = SDL_CreateRGBSurfaceWithFormatFrom(buf, 4, 1, 15, 6, SDL_PIXELFORMAT_RGB555);
 | |
|     SDLTest_AssertCheck(surface == NULL, "4px * 15 (really 16) bits per px doesn't fit in 6 bytes");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|     surface = SDL_CreateRGBSurfaceFrom(buf, 4, 1, 15, 6, 0, 0, 0, 0);
 | |
|     SDLTest_AssertCheck(surface == NULL, "4px * 15 (really 16) bits per px doesn't fit in 6 bytes");
 | |
|     SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                         "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
| 
 | |
|     if (sizeof (size_t) == 4 && sizeof (int) >= 4) {
 | |
|         expectedError = "Out of memory";
 | |
|         surface = SDL_CreateRGBSurfaceWithFormat(0, SDL_MAX_SINT32, 1, 8, SDL_PIXELFORMAT_INDEX8);
 | |
|         SDLTest_AssertCheck(surface == NULL, "Should detect overflow in width + alignment");
 | |
|         SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                             "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|         surface = SDL_CreateRGBSurfaceWithFormat(0, SDL_MAX_SINT32 / 2, 1, 32, SDL_PIXELFORMAT_ARGB8888);
 | |
|         SDLTest_AssertCheck(surface == NULL, "Should detect overflow in width * bytes per pixel");
 | |
|         SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                             "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|         surface = SDL_CreateRGBSurfaceWithFormat(0, (1 << 29) - 1, (1 << 29) - 1, 8, SDL_PIXELFORMAT_INDEX8);
 | |
|         SDLTest_AssertCheck(surface == NULL, "Should detect overflow in width * height");
 | |
|         SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                             "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|         surface = SDL_CreateRGBSurfaceWithFormat(0, (1 << 15) + 1, (1 << 15) + 1, 32, SDL_PIXELFORMAT_ARGB8888);
 | |
|         SDLTest_AssertCheck(surface == NULL, "Should detect overflow in width * height * bytes per pixel");
 | |
|         SDLTest_AssertCheck(SDL_strcmp(SDL_GetError(), expectedError) == 0,
 | |
|                             "Expected \"%s\", got \"%s\"", expectedError, SDL_GetError());
 | |
|     }
 | |
|     else {
 | |
|         SDLTest_Log("Can't easily overflow size_t on this platform");
 | |
|     }
 | |
| 
 | |
|     return TEST_COMPLETED;
 | |
| }
 | |
| 
 | |
| /* ================= Test References ================== */
 | |
| 
 | |
| /* Surface test cases */
 | |
| static const SDLTest_TestCaseReference surfaceTest1 =
 | |
|         { (SDLTest_TestCaseFp)surface_testSaveLoadBitmap, "surface_testSaveLoadBitmap", "Tests sprite saving and loading.", TEST_ENABLED};
 | |
| 
 | |
| static const SDLTest_TestCaseReference surfaceTest2 =
 | |
|         { (SDLTest_TestCaseFp)surface_testBlit, "surface_testBlit", "Tests basic blitting.", TEST_ENABLED};
 | |
| 
 | |
| static const SDLTest_TestCaseReference surfaceTest3 =
 | |
|         { (SDLTest_TestCaseFp)surface_testBlitBlendNone, "surface_testBlitBlendNone", "Tests blitting routines with none blending mode.", TEST_ENABLED};
 | |
| 
 | |
| static const SDLTest_TestCaseReference surfaceTest4 =
 | |
|         { (SDLTest_TestCaseFp)surface_testLoadFailure, "surface_testLoadFailure", "Tests sprite loading. A failure case.", TEST_ENABLED};
 | |
| 
 | |
| static const SDLTest_TestCaseReference surfaceTest5 =
 | |
|         { (SDLTest_TestCaseFp)surface_testSurfaceConversion, "surface_testSurfaceConversion", "Tests surface conversion.", TEST_ENABLED};
 | |
| 
 | |
| static const SDLTest_TestCaseReference surfaceTest6 =
 | |
|         { (SDLTest_TestCaseFp)surface_testCompleteSurfaceConversion, "surface_testCompleteSurfaceConversion", "Tests surface conversion across all pixel formats", TEST_ENABLED};
 | |
| 
 | |
| static const SDLTest_TestCaseReference surfaceTest7 =
 | |
|         { (SDLTest_TestCaseFp)surface_testBlitColorMod, "surface_testBlitColorMod", "Tests some blitting routines with color mod.", TEST_ENABLED};
 | |
| 
 | |
| static const SDLTest_TestCaseReference surfaceTest8 =
 | |
|         { (SDLTest_TestCaseFp)surface_testBlitAlphaMod, "surface_testBlitAlphaMod", "Tests some blitting routines with alpha mod.", TEST_ENABLED};
 | |
| 
 | |
| /* TODO: rewrite test case, define new test data and re-enable; current implementation fails */
 | |
| static const SDLTest_TestCaseReference surfaceTest9 =
 | |
|         { (SDLTest_TestCaseFp)surface_testBlitBlendLoop, "surface_testBlitBlendLoop", "Test blitting routines with various blending modes", TEST_DISABLED};
 | |
| 
 | |
| /* TODO: rewrite test case, define new test data and re-enable; current implementation fails */
 | |
| static const SDLTest_TestCaseReference surfaceTest10 =
 | |
|         { (SDLTest_TestCaseFp)surface_testBlitBlendBlend, "surface_testBlitBlendBlend", "Tests blitting routines with blend blending mode.", TEST_DISABLED};
 | |
| 
 | |
| /* TODO: rewrite test case, define new test data and re-enable; current implementation fails */
 | |
| static const SDLTest_TestCaseReference surfaceTest11 =
 | |
|         { (SDLTest_TestCaseFp)surface_testBlitBlendAdd, "surface_testBlitBlendAdd", "Tests blitting routines with add blending mode.", TEST_DISABLED};
 | |
| 
 | |
| static const SDLTest_TestCaseReference surfaceTest12 =
 | |
|         { (SDLTest_TestCaseFp)surface_testBlitBlendMod, "surface_testBlitBlendMod", "Tests blitting routines with mod blending mode.", TEST_ENABLED};
 | |
| 
 | |
| static const SDLTest_TestCaseReference surfaceTestOverflow =
 | |
|         { surface_testOverflow, "surface_testOverflow", "Test overflow detection.", TEST_ENABLED};
 | |
| 
 | |
| /* Sequence of Surface test cases */
 | |
| static const SDLTest_TestCaseReference *surfaceTests[] =  {
 | |
|     &surfaceTest1, &surfaceTest2, &surfaceTest3, &surfaceTest4, &surfaceTest5,
 | |
|     &surfaceTest6, &surfaceTest7, &surfaceTest8, &surfaceTest9, &surfaceTest10,
 | |
|     &surfaceTest11, &surfaceTest12, &surfaceTestOverflow, NULL
 | |
| };
 | |
| 
 | |
| /* Surface test suite (global) */
 | |
| SDLTest_TestSuiteReference surfaceTestSuite = {
 | |
|     "Surface",
 | |
|     _surfaceSetUp,
 | |
|     surfaceTests,
 | |
|     _surfaceTearDown
 | |
| 
 | |
| };
 |