Fix bug 122 - SDL_RWops bug fixes: set RWops.type field, add input validation, add test coverage
This commit is contained in:
parent
ae480eecfd
commit
42a673ce23
3 changed files with 215 additions and 14 deletions
|
@ -40,6 +40,14 @@ extern "C" {
|
||||||
/* *INDENT-ON* */
|
/* *INDENT-ON* */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* RWops Types */
|
||||||
|
#define SDL_RWOPS_UNKNOWN 0 /* Unknown stream type */
|
||||||
|
#define SDL_RWOPS_WINFILE 1 /* Win32 file */
|
||||||
|
#define SDL_RWOPS_STDFILE 2 /* Stdio file */
|
||||||
|
#define SDL_RWOPS_JNIFILE 3 /* Android asset */
|
||||||
|
#define SDL_RWOPS_MEMORY 4 /* Memory stream */
|
||||||
|
#define SDL_RWOPS_MEMORY_RO 5 /* Read-Only memory stream */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is the read/write operation structure -- very basic.
|
* This is the read/write operation structure -- very basic.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -513,6 +513,7 @@ SDL_RWFromFile(const char *file, const char *mode)
|
||||||
rwops->read = Android_JNI_FileRead;
|
rwops->read = Android_JNI_FileRead;
|
||||||
rwops->write = Android_JNI_FileWrite;
|
rwops->write = Android_JNI_FileWrite;
|
||||||
rwops->close = Android_JNI_FileClose;
|
rwops->close = Android_JNI_FileClose;
|
||||||
|
rwops->type = SDL_RWOPS_JNIFILE;
|
||||||
|
|
||||||
#elif defined(__WIN32__)
|
#elif defined(__WIN32__)
|
||||||
rwops = SDL_AllocRW();
|
rwops = SDL_AllocRW();
|
||||||
|
@ -527,6 +528,7 @@ SDL_RWFromFile(const char *file, const char *mode)
|
||||||
rwops->read = windows_file_read;
|
rwops->read = windows_file_read;
|
||||||
rwops->write = windows_file_write;
|
rwops->write = windows_file_write;
|
||||||
rwops->close = windows_file_close;
|
rwops->close = windows_file_close;
|
||||||
|
rwops->type = SDL_RWOPS_WINFILE;
|
||||||
|
|
||||||
#elif HAVE_STDIO_H
|
#elif HAVE_STDIO_H
|
||||||
{
|
{
|
||||||
|
@ -570,6 +572,7 @@ SDL_RWFromFP(FILE * fp, SDL_bool autoclose)
|
||||||
rwops->close = stdio_close;
|
rwops->close = stdio_close;
|
||||||
rwops->hidden.stdio.fp = fp;
|
rwops->hidden.stdio.fp = fp;
|
||||||
rwops->hidden.stdio.autoclose = autoclose;
|
rwops->hidden.stdio.autoclose = autoclose;
|
||||||
|
rwops->type = SDL_RWOPS_STDFILE;
|
||||||
}
|
}
|
||||||
return (rwops);
|
return (rwops);
|
||||||
}
|
}
|
||||||
|
@ -585,7 +588,15 @@ SDL_RWFromFP(void * fp, SDL_bool autoclose)
|
||||||
SDL_RWops *
|
SDL_RWops *
|
||||||
SDL_RWFromMem(void *mem, int size)
|
SDL_RWFromMem(void *mem, int size)
|
||||||
{
|
{
|
||||||
SDL_RWops *rwops;
|
SDL_RWops *rwops = NULL;
|
||||||
|
if (!mem) {
|
||||||
|
SDL_InvalidParamError("mem");
|
||||||
|
return (rwops);
|
||||||
|
}
|
||||||
|
if (!size) {
|
||||||
|
SDL_InvalidParamError("size");
|
||||||
|
return (rwops);
|
||||||
|
}
|
||||||
|
|
||||||
rwops = SDL_AllocRW();
|
rwops = SDL_AllocRW();
|
||||||
if (rwops != NULL) {
|
if (rwops != NULL) {
|
||||||
|
@ -597,6 +608,7 @@ SDL_RWFromMem(void *mem, int size)
|
||||||
rwops->hidden.mem.base = (Uint8 *) mem;
|
rwops->hidden.mem.base = (Uint8 *) mem;
|
||||||
rwops->hidden.mem.here = rwops->hidden.mem.base;
|
rwops->hidden.mem.here = rwops->hidden.mem.base;
|
||||||
rwops->hidden.mem.stop = rwops->hidden.mem.base + size;
|
rwops->hidden.mem.stop = rwops->hidden.mem.base + size;
|
||||||
|
rwops->type = SDL_RWOPS_MEMORY;
|
||||||
}
|
}
|
||||||
return (rwops);
|
return (rwops);
|
||||||
}
|
}
|
||||||
|
@ -604,7 +616,15 @@ SDL_RWFromMem(void *mem, int size)
|
||||||
SDL_RWops *
|
SDL_RWops *
|
||||||
SDL_RWFromConstMem(const void *mem, int size)
|
SDL_RWFromConstMem(const void *mem, int size)
|
||||||
{
|
{
|
||||||
SDL_RWops *rwops;
|
SDL_RWops *rwops = NULL;
|
||||||
|
if (!mem) {
|
||||||
|
SDL_InvalidParamError("mem");
|
||||||
|
return (rwops);
|
||||||
|
}
|
||||||
|
if (!size) {
|
||||||
|
SDL_InvalidParamError("size");
|
||||||
|
return (rwops);
|
||||||
|
}
|
||||||
|
|
||||||
rwops = SDL_AllocRW();
|
rwops = SDL_AllocRW();
|
||||||
if (rwops != NULL) {
|
if (rwops != NULL) {
|
||||||
|
@ -616,6 +636,7 @@ SDL_RWFromConstMem(const void *mem, int size)
|
||||||
rwops->hidden.mem.base = (Uint8 *) mem;
|
rwops->hidden.mem.base = (Uint8 *) mem;
|
||||||
rwops->hidden.mem.here = rwops->hidden.mem.base;
|
rwops->hidden.mem.here = rwops->hidden.mem.base;
|
||||||
rwops->hidden.mem.stop = rwops->hidden.mem.base + size;
|
rwops->hidden.mem.stop = rwops->hidden.mem.base + size;
|
||||||
|
rwops->type = SDL_RWOPS_MEMORY_RO;
|
||||||
}
|
}
|
||||||
return (rwops);
|
return (rwops);
|
||||||
}
|
}
|
||||||
|
@ -629,6 +650,7 @@ SDL_AllocRW(void)
|
||||||
if (area == NULL) {
|
if (area == NULL) {
|
||||||
SDL_OutOfMemory();
|
SDL_OutOfMemory();
|
||||||
}
|
}
|
||||||
|
area->type = SDL_RWOPS_UNKNOWN;
|
||||||
return (area);
|
return (area);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,16 +21,18 @@
|
||||||
|
|
||||||
const char* RWopsReadTestFilename = "rwops_read";
|
const char* RWopsReadTestFilename = "rwops_read";
|
||||||
const char* RWopsWriteTestFilename = "rwops_write";
|
const char* RWopsWriteTestFilename = "rwops_write";
|
||||||
|
const char* RWopsAlphabetFilename = "rwops_alphabet";
|
||||||
|
|
||||||
static const char RWopsHelloWorldTestString[] = "Hello World!";
|
static const char RWopsHelloWorldTestString[] = "Hello World!";
|
||||||
static const char RWopsHelloWorldCompString[] = "Hello World!";
|
static const char RWopsHelloWorldCompString[] = "Hello World!";
|
||||||
|
static const char RWopsAlphabetString[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
|
||||||
|
|
||||||
/* Fixture */
|
/* Fixture */
|
||||||
|
|
||||||
void
|
void
|
||||||
RWopsSetUp(void *arg)
|
RWopsSetUp(void *arg)
|
||||||
{
|
{
|
||||||
int fileLen = SDL_strlen(RWopsHelloWorldTestString);
|
int fileLen;
|
||||||
FILE *handle;
|
FILE *handle;
|
||||||
int writtenLen;
|
int writtenLen;
|
||||||
int result;
|
int result;
|
||||||
|
@ -38,18 +40,32 @@ RWopsSetUp(void *arg)
|
||||||
/* Clean up from previous runs (if any); ignore errors */
|
/* Clean up from previous runs (if any); ignore errors */
|
||||||
remove(RWopsReadTestFilename);
|
remove(RWopsReadTestFilename);
|
||||||
remove(RWopsWriteTestFilename);
|
remove(RWopsWriteTestFilename);
|
||||||
|
remove(RWopsAlphabetFilename);
|
||||||
|
|
||||||
/* Create a test file */
|
/* Create a test file */
|
||||||
handle = fopen(RWopsReadTestFilename, "w");
|
handle = fopen(RWopsReadTestFilename, "w");
|
||||||
SDLTest_AssertCheck(handle != NULL, "Verify creation of file '%s' returned non NULL handle", RWopsReadTestFilename);
|
SDLTest_AssertCheck(handle != NULL, "Verify creation of file '%s' returned non NULL handle", RWopsReadTestFilename);
|
||||||
if (handle == NULL) return;
|
if (handle == NULL) return;
|
||||||
|
|
||||||
/* Write some known test into it */
|
/* Write some known text into it */
|
||||||
|
fileLen = SDL_strlen(RWopsHelloWorldTestString);
|
||||||
writtenLen = (int)fwrite(RWopsHelloWorldTestString, 1, fileLen, handle);
|
writtenLen = (int)fwrite(RWopsHelloWorldTestString, 1, fileLen, handle);
|
||||||
SDLTest_AssertCheck(fileLen == writtenLen, "Verify number of written bytes, expected %i, got %i", fileLen, writtenLen);
|
SDLTest_AssertCheck(fileLen == writtenLen, "Verify number of written bytes, expected %i, got %i", fileLen, writtenLen);
|
||||||
result = fclose(handle);
|
result = fclose(handle);
|
||||||
SDLTest_AssertCheck(result == 0, "Verify result from fclose, expected 0, got %i", result);
|
SDLTest_AssertCheck(result == 0, "Verify result from fclose, expected 0, got %i", result);
|
||||||
|
|
||||||
|
/* Create a second test file */
|
||||||
|
handle = fopen(RWopsAlphabetFilename, "w");
|
||||||
|
SDLTest_AssertCheck(handle != NULL, "Verify creation of file '%s' returned non NULL handle", RWopsAlphabetFilename);
|
||||||
|
if (handle == NULL) return;
|
||||||
|
|
||||||
|
/* Write alphabet text into it */
|
||||||
|
fileLen = SDL_strlen(RWopsAlphabetString);
|
||||||
|
writtenLen = (int)fwrite(RWopsAlphabetString, 1, fileLen, handle);
|
||||||
|
SDLTest_AssertCheck(fileLen == writtenLen, "Verify number of written bytes, expected %i, got %i", fileLen, writtenLen);
|
||||||
|
result = fclose(handle);
|
||||||
|
SDLTest_AssertCheck(result == 0, "Verify result from fclose, expected 0, got %i", result);
|
||||||
|
|
||||||
SDLTest_AssertPass("Creation of test file completed");
|
SDLTest_AssertPass("Creation of test file completed");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,6 +78,8 @@ RWopsTearDown(void *arg)
|
||||||
result = remove(RWopsReadTestFilename);
|
result = remove(RWopsReadTestFilename);
|
||||||
SDLTest_AssertCheck(result == 0, "Verify result from remove(%s), expected 0, got %i", RWopsReadTestFilename, result);
|
SDLTest_AssertCheck(result == 0, "Verify result from remove(%s), expected 0, got %i", RWopsReadTestFilename, result);
|
||||||
remove(RWopsWriteTestFilename);
|
remove(RWopsWriteTestFilename);
|
||||||
|
result = remove(RWopsAlphabetFilename);
|
||||||
|
SDLTest_AssertCheck(result == 0, "Verify result from remove(%s), expected 0, got %i", RWopsAlphabetFilename, result);
|
||||||
|
|
||||||
SDLTest_AssertPass("Cleanup of test files completed");
|
SDLTest_AssertPass("Cleanup of test files completed");
|
||||||
}
|
}
|
||||||
|
@ -137,6 +155,14 @@ _testGenericRWopsValidations(SDL_RWops *rw, int write)
|
||||||
"Verify seek to -1 with SDL_RWseek (RW_SEEK_END), expected %i, got %i",
|
"Verify seek to -1 with SDL_RWseek (RW_SEEK_END), expected %i, got %i",
|
||||||
sizeof(RWopsHelloWorldTestString)-2,
|
sizeof(RWopsHelloWorldTestString)-2,
|
||||||
i);
|
i);
|
||||||
|
|
||||||
|
/* Invalid whence seek */
|
||||||
|
i = SDL_RWseek( rw, 0, 999 );
|
||||||
|
SDLTest_AssertPass("Call to SDL_RWseek(...,0,invalid_whence) succeeded");
|
||||||
|
SDLTest_AssertCheck(
|
||||||
|
i == (Sint64)(-1),
|
||||||
|
"Verify seek with SDL_RWseek (invalid_whence); expected: -1, got %i",
|
||||||
|
i);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -171,6 +197,18 @@ rwops_testParamNegative (void)
|
||||||
SDLTest_AssertPass("Call to SDL_RWFromFile(\"something\", NULL) succeeded");
|
SDLTest_AssertPass("Call to SDL_RWFromFile(\"something\", NULL) succeeded");
|
||||||
SDLTest_AssertCheck(rwops == NULL, "Verify SDL_RWFromFile(\"something\", NULL) returns NULL");
|
SDLTest_AssertCheck(rwops == NULL, "Verify SDL_RWFromFile(\"something\", NULL) returns NULL");
|
||||||
|
|
||||||
|
rwops = SDL_RWFromMem((void *)NULL, 10);
|
||||||
|
SDLTest_AssertPass("Call to SDL_RWFromMem(NULL, 10) succeeded");
|
||||||
|
SDLTest_AssertCheck(rwops == NULL, "Verify SDL_RWFromMem(NULL, 10) returns NULL");
|
||||||
|
|
||||||
|
rwops = SDL_RWFromMem((void *)RWopsAlphabetString, 0);
|
||||||
|
SDLTest_AssertPass("Call to SDL_RWFromMem(data, 0) succeeded");
|
||||||
|
SDLTest_AssertCheck(rwops == NULL, "Verify SDL_RWFromMem(data, 0) returns NULL");
|
||||||
|
|
||||||
|
rwops = SDL_RWFromConstMem((const void *)RWopsAlphabetString, 0);
|
||||||
|
SDLTest_AssertPass("Call to SDL_RWFromConstMem(data, 0) succeeded");
|
||||||
|
SDLTest_AssertCheck(rwops == NULL, "Verify SDL_RWFromConstMem(data, 0) returns NULL");
|
||||||
|
|
||||||
return TEST_COMPLETED;
|
return TEST_COMPLETED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -178,13 +216,14 @@ rwops_testParamNegative (void)
|
||||||
* @brief Tests opening from memory.
|
* @brief Tests opening from memory.
|
||||||
*
|
*
|
||||||
* \sa http://wiki.libsdl.org/moin.cgi/SDL_RWFromMem
|
* \sa http://wiki.libsdl.org/moin.cgi/SDL_RWFromMem
|
||||||
* http://wiki.libsdl.org/moin.cgi/SDL_RWClose
|
* \sa http://wiki.libsdl.org/moin.cgi/SDL_RWClose
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
rwops_testMem (void)
|
rwops_testMem (void)
|
||||||
{
|
{
|
||||||
char mem[sizeof(RWopsHelloWorldTestString)];
|
char mem[sizeof(RWopsHelloWorldTestString)];
|
||||||
SDL_RWops *rw;
|
SDL_RWops *rw;
|
||||||
|
int result;
|
||||||
|
|
||||||
/* Clear buffer */
|
/* Clear buffer */
|
||||||
SDL_zero(mem);
|
SDL_zero(mem);
|
||||||
|
@ -197,12 +236,16 @@ rwops_testMem (void)
|
||||||
/* Bail out if NULL */
|
/* Bail out if NULL */
|
||||||
if (rw == NULL) return TEST_ABORTED;
|
if (rw == NULL) return TEST_ABORTED;
|
||||||
|
|
||||||
|
/* Check type */
|
||||||
|
SDLTest_AssertCheck(rw->type == SDL_RWOPS_MEMORY, "Verify RWops type is SDL_RWOPS_MEMORY; expected: %d, got: %d", SDL_RWOPS_MEMORY, rw->type);
|
||||||
|
|
||||||
/* Run generic tests */
|
/* Run generic tests */
|
||||||
_testGenericRWopsValidations(rw, 1);
|
_testGenericRWopsValidations(rw, 1);
|
||||||
|
|
||||||
/* Close */
|
/* Close */
|
||||||
SDL_RWclose(rw);
|
result = SDL_RWclose(rw);
|
||||||
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
||||||
|
SDLTest_AssertCheck(result == 0, "Verify result value is 0; got: %d", result);
|
||||||
|
|
||||||
return TEST_COMPLETED;
|
return TEST_COMPLETED;
|
||||||
}
|
}
|
||||||
|
@ -219,6 +262,7 @@ int
|
||||||
rwops_testConstMem (void)
|
rwops_testConstMem (void)
|
||||||
{
|
{
|
||||||
SDL_RWops *rw;
|
SDL_RWops *rw;
|
||||||
|
int result;
|
||||||
|
|
||||||
/* Open handle */
|
/* Open handle */
|
||||||
rw = SDL_RWFromConstMem( RWopsHelloWorldCompString, sizeof(RWopsHelloWorldCompString)-1 );
|
rw = SDL_RWFromConstMem( RWopsHelloWorldCompString, sizeof(RWopsHelloWorldCompString)-1 );
|
||||||
|
@ -228,12 +272,16 @@ rwops_testConstMem (void)
|
||||||
/* Bail out if NULL */
|
/* Bail out if NULL */
|
||||||
if (rw == NULL) return TEST_ABORTED;
|
if (rw == NULL) return TEST_ABORTED;
|
||||||
|
|
||||||
|
/* Check type */
|
||||||
|
SDLTest_AssertCheck(rw->type == SDL_RWOPS_MEMORY_RO, "Verify RWops type is SDL_RWOPS_MEMORY_RO; expected: %d, got: %d", SDL_RWOPS_MEMORY_RO, rw->type);
|
||||||
|
|
||||||
/* Run generic tests */
|
/* Run generic tests */
|
||||||
_testGenericRWopsValidations( rw, 0 );
|
_testGenericRWopsValidations( rw, 0 );
|
||||||
|
|
||||||
/* Close handle */
|
/* Close handle */
|
||||||
SDL_RWclose(rw);
|
result = SDL_RWclose(rw);
|
||||||
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
||||||
|
SDLTest_AssertCheck(result == 0, "Verify result value is 0; got: %d", result);
|
||||||
|
|
||||||
return TEST_COMPLETED;
|
return TEST_COMPLETED;
|
||||||
}
|
}
|
||||||
|
@ -250,6 +298,7 @@ int
|
||||||
rwops_testFileRead(void)
|
rwops_testFileRead(void)
|
||||||
{
|
{
|
||||||
SDL_RWops *rw;
|
SDL_RWops *rw;
|
||||||
|
int result;
|
||||||
|
|
||||||
/* Read test. */
|
/* Read test. */
|
||||||
rw = SDL_RWFromFile(RWopsReadTestFilename, "r");
|
rw = SDL_RWFromFile(RWopsReadTestFilename, "r");
|
||||||
|
@ -259,12 +308,28 @@ rwops_testFileRead(void)
|
||||||
// Bail out if NULL
|
// Bail out if NULL
|
||||||
if (rw == NULL) return TEST_ABORTED;
|
if (rw == NULL) return TEST_ABORTED;
|
||||||
|
|
||||||
|
/* Check type */
|
||||||
|
#if defined(ANDROID)
|
||||||
|
SDLTest_AssertCheck(
|
||||||
|
rw->type == SDL_RWOPS_STDFILE || rw->type == SDL_RWOPS_JNIFILE,
|
||||||
|
"Verify RWops type is SDL_RWOPS_STDFILE or SDL_RWOPS_JNIFILE; expected: %d|%d, got: %d", SDL_RWOPS_STDFILE, SDL_RWOPS_JNIFILE, rw->type);
|
||||||
|
#elif defined(__WIN32__)
|
||||||
|
SDLTest_AssertCheck(
|
||||||
|
rw->type == SDL_RWOPS_WINFILE,
|
||||||
|
"Verify RWops type is SDL_RWOPS_WINFILE; expected: %d, got: %d", SDL_RWOPS_WINFILE, rw->type);
|
||||||
|
#else
|
||||||
|
SDLTest_AssertCheck(
|
||||||
|
rw->type == SDL_RWOPS_STDFILE,
|
||||||
|
"Verify RWops type is SDL_RWOPS_STDFILE; expected: %d, got: %d", SDL_RWOPS_STDFILE, rw->type);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Run generic tests */
|
/* Run generic tests */
|
||||||
_testGenericRWopsValidations( rw, 0 );
|
_testGenericRWopsValidations( rw, 0 );
|
||||||
|
|
||||||
/* Close handle */
|
/* Close handle */
|
||||||
SDL_RWclose(rw);
|
result = SDL_RWclose(rw);
|
||||||
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
||||||
|
SDLTest_AssertCheck(result == 0, "Verify result value is 0; got: %d", result);
|
||||||
|
|
||||||
return TEST_COMPLETED;
|
return TEST_COMPLETED;
|
||||||
}
|
}
|
||||||
|
@ -280,6 +345,7 @@ int
|
||||||
rwops_testFileWrite(void)
|
rwops_testFileWrite(void)
|
||||||
{
|
{
|
||||||
SDL_RWops *rw;
|
SDL_RWops *rw;
|
||||||
|
int result;
|
||||||
|
|
||||||
/* Write test. */
|
/* Write test. */
|
||||||
rw = SDL_RWFromFile(RWopsWriteTestFilename, "w+");
|
rw = SDL_RWFromFile(RWopsWriteTestFilename, "w+");
|
||||||
|
@ -289,12 +355,28 @@ rwops_testFileWrite(void)
|
||||||
// Bail out if NULL
|
// Bail out if NULL
|
||||||
if (rw == NULL) return TEST_ABORTED;
|
if (rw == NULL) return TEST_ABORTED;
|
||||||
|
|
||||||
|
/* Check type */
|
||||||
|
#if defined(ANDROID)
|
||||||
|
SDLTest_AssertCheck(
|
||||||
|
rw->type == SDL_RWOPS_STDFILE || rw->type == SDL_RWOPS_JNIFILE,
|
||||||
|
"Verify RWops type is SDL_RWOPS_STDFILE or SDL_RWOPS_JNIFILE; expected: %d|%d, got: %d", SDL_RWOPS_STDFILE, SDL_RWOPS_JNIFILE, rw->type);
|
||||||
|
#elif defined(__WIN32__)
|
||||||
|
SDLTest_AssertCheck(
|
||||||
|
rw->type == SDL_RWOPS_WINFILE,
|
||||||
|
"Verify RWops type is SDL_RWOPS_WINFILE; expected: %d, got: %d", SDL_RWOPS_WINFILE, rw->type);
|
||||||
|
#else
|
||||||
|
SDLTest_AssertCheck(
|
||||||
|
rw->type == SDL_RWOPS_STDFILE,
|
||||||
|
"Verify RWops type is SDL_RWOPS_STDFILE; expected: %d, got: %d", SDL_RWOPS_STDFILE, rw->type);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Run generic tests */
|
/* Run generic tests */
|
||||||
_testGenericRWopsValidations( rw, 1 );
|
_testGenericRWopsValidations( rw, 1 );
|
||||||
|
|
||||||
/* Close handle */
|
/* Close handle */
|
||||||
SDL_RWclose(rw);
|
result = SDL_RWclose(rw);
|
||||||
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
||||||
|
SDLTest_AssertCheck(result == 0, "Verify result value is 0; got: %d", result);
|
||||||
|
|
||||||
return TEST_COMPLETED;
|
return TEST_COMPLETED;
|
||||||
}
|
}
|
||||||
|
@ -313,6 +395,7 @@ rwops_testFPRead(void)
|
||||||
{
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
SDL_RWops *rw;
|
SDL_RWops *rw;
|
||||||
|
int result;
|
||||||
|
|
||||||
/* Run read tests. */
|
/* Run read tests. */
|
||||||
fp = fopen(RWopsReadTestFilename, "r");
|
fp = fopen(RWopsReadTestFilename, "r");
|
||||||
|
@ -332,12 +415,18 @@ rwops_testFPRead(void)
|
||||||
return TEST_ABORTED;
|
return TEST_ABORTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Check type */
|
||||||
|
SDLTest_AssertCheck(
|
||||||
|
rw->type == SDL_RWOPS_STDFILE,
|
||||||
|
"Verify RWops type is SDL_RWOPS_STDFILE; expected: %d, got: %d", SDL_RWOPS_STDFILE, rw->type);
|
||||||
|
|
||||||
/* Run generic tests */
|
/* Run generic tests */
|
||||||
_testGenericRWopsValidations( rw, 0 );
|
_testGenericRWopsValidations( rw, 0 );
|
||||||
|
|
||||||
/* Close handle - does fclose() */
|
/* Close handle - does fclose() */
|
||||||
SDL_RWclose(rw);
|
result = SDL_RWclose(rw);
|
||||||
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
||||||
|
SDLTest_AssertCheck(result == 0, "Verify result value is 0; got: %d", result);
|
||||||
|
|
||||||
return TEST_COMPLETED;
|
return TEST_COMPLETED;
|
||||||
}
|
}
|
||||||
|
@ -356,6 +445,7 @@ rwops_testFPWrite(void)
|
||||||
{
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
SDL_RWops *rw;
|
SDL_RWops *rw;
|
||||||
|
int result;
|
||||||
|
|
||||||
/* Run write tests. */
|
/* Run write tests. */
|
||||||
fp = fopen(RWopsWriteTestFilename, "w+");
|
fp = fopen(RWopsWriteTestFilename, "w+");
|
||||||
|
@ -375,12 +465,18 @@ rwops_testFPWrite(void)
|
||||||
return TEST_ABORTED;
|
return TEST_ABORTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Check type */
|
||||||
|
SDLTest_AssertCheck(
|
||||||
|
rw->type == SDL_RWOPS_STDFILE,
|
||||||
|
"Verify RWops type is SDL_RWOPS_STDFILE; expected: %d, got: %d", SDL_RWOPS_STDFILE, rw->type);
|
||||||
|
|
||||||
/* Run generic tests */
|
/* Run generic tests */
|
||||||
_testGenericRWopsValidations( rw, 1 );
|
_testGenericRWopsValidations( rw, 1 );
|
||||||
|
|
||||||
/* Close handle - does fclose() */
|
/* Close handle - does fclose() */
|
||||||
SDL_RWclose(rw);
|
result = SDL_RWclose(rw);
|
||||||
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
||||||
|
SDLTest_AssertCheck(result == 0, "Verify result value is 0; got: %d", result);
|
||||||
|
|
||||||
return TEST_COMPLETED;
|
return TEST_COMPLETED;
|
||||||
}
|
}
|
||||||
|
@ -400,6 +496,11 @@ rwops_testAllocFree (void)
|
||||||
SDLTest_AssertCheck(rw != NULL, "Validate result from SDL_AllocRW() is not NULL");
|
SDLTest_AssertCheck(rw != NULL, "Validate result from SDL_AllocRW() is not NULL");
|
||||||
if (rw==NULL) return TEST_ABORTED;
|
if (rw==NULL) return TEST_ABORTED;
|
||||||
|
|
||||||
|
/* Check type */
|
||||||
|
SDLTest_AssertCheck(
|
||||||
|
rw->type == SDL_RWOPS_UNKNOWN,
|
||||||
|
"Verify RWops type is SDL_RWOPS_UNKNOWN; expected: %d, got: %d", SDL_RWOPS_UNKNOWN, rw->type);
|
||||||
|
|
||||||
/* Free context again */
|
/* Free context again */
|
||||||
SDL_FreeRW(rw);
|
SDL_FreeRW(rw);
|
||||||
SDLTest_AssertPass("Call to SDL_FreeRW() succeeded");
|
SDLTest_AssertPass("Call to SDL_FreeRW() succeeded");
|
||||||
|
@ -407,6 +508,72 @@ rwops_testAllocFree (void)
|
||||||
return TEST_COMPLETED;
|
return TEST_COMPLETED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Compare memory and file reads
|
||||||
|
*
|
||||||
|
* \sa http://wiki.libsdl.org/moin.cgi/SDL_RWFromMem
|
||||||
|
* \sa http://wiki.libsdl.org/moin.cgi/SDL_RWFromFile
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
rwops_testCompareRWFromMemWithRWFromFile(void)
|
||||||
|
{
|
||||||
|
int slen = 26;
|
||||||
|
char buffer_file[27];
|
||||||
|
char buffer_mem[27];
|
||||||
|
size_t rv_file;
|
||||||
|
size_t rv_mem;
|
||||||
|
Uint64 sv_file;
|
||||||
|
Uint64 sv_mem;
|
||||||
|
SDL_RWops* rwops_file;
|
||||||
|
SDL_RWops* rwops_mem;
|
||||||
|
int size;
|
||||||
|
int result;
|
||||||
|
|
||||||
|
|
||||||
|
for (size=5; size<10; size++)
|
||||||
|
{
|
||||||
|
/* Terminate buffer */
|
||||||
|
buffer_file[slen] = 0;
|
||||||
|
buffer_mem[slen] = 0;
|
||||||
|
|
||||||
|
/* Read/seek from memory */
|
||||||
|
rwops_mem = SDL_RWFromMem((void *)RWopsAlphabetString, slen);
|
||||||
|
SDLTest_AssertPass("Call to SDL_RWFromMem()");
|
||||||
|
rv_mem = SDL_RWread(rwops_mem, buffer_mem, size, 6);
|
||||||
|
SDLTest_AssertPass("Call to SDL_RWread(mem, size=%d)", size);
|
||||||
|
sv_mem = SDL_RWseek(rwops_mem, 0, SEEK_END);
|
||||||
|
SDLTest_AssertPass("Call to SDL_RWseek(mem,SEEK_END)");
|
||||||
|
result = SDL_RWclose(rwops_mem);
|
||||||
|
SDLTest_AssertPass("Call to SDL_RWclose(mem)");
|
||||||
|
SDLTest_AssertCheck(result == 0, "Verify result value is 0; got: %d", result);
|
||||||
|
|
||||||
|
/* Read/see from file */
|
||||||
|
rwops_file = SDL_RWFromFile(RWopsAlphabetFilename, "r");
|
||||||
|
SDLTest_AssertPass("Call to SDL_RWFromFile()");
|
||||||
|
rv_file = SDL_RWread(rwops_file, buffer_file, size, 6);
|
||||||
|
SDLTest_AssertPass("Call to SDL_RWread(file, size=%d)", size);
|
||||||
|
sv_file = SDL_RWseek(rwops_file, 0, SEEK_END);
|
||||||
|
SDLTest_AssertPass("Call to SDL_RWseek(file,SEEK_END)");
|
||||||
|
result = SDL_RWclose(rwops_file);
|
||||||
|
SDLTest_AssertPass("Call to SDL_RWclose(file)");
|
||||||
|
SDLTest_AssertCheck(result == 0, "Verify result value is 0; got: %d", result);
|
||||||
|
|
||||||
|
/* Compare */
|
||||||
|
SDLTest_AssertCheck(rv_mem == rv_file, "Verify returned read blocks matches for mem and file reads; got: rv_mem=%d rv_file=%d", rv_mem, rv_file);
|
||||||
|
SDLTest_AssertCheck(sv_mem == sv_file, "Verify SEEK_END position matches for mem and file seeks; got: sv_mem=%llu sv_file=%llu", sv_mem, sv_file);
|
||||||
|
SDLTest_AssertCheck(buffer_mem[slen] == 0, "Verify mem buffer termination; expected: 0, got: %d", buffer_mem[slen]);
|
||||||
|
SDLTest_AssertCheck(buffer_file[slen] == 0, "Verify file buffer termination; expected: 0, got: %d", buffer_file[slen]);
|
||||||
|
SDLTest_AssertCheck(
|
||||||
|
SDL_strncmp(buffer_mem, RWopsAlphabetString, slen) == 0,
|
||||||
|
"Verify mem buffer contain alphabet string; expected: %s, got: %s", RWopsAlphabetString, buffer_mem);
|
||||||
|
SDLTest_AssertCheck(
|
||||||
|
SDL_strncmp(buffer_file, RWopsAlphabetString, slen) == 0,
|
||||||
|
"Verify file buffer contain alphabet string; expected: %s, got: %s", RWopsAlphabetString, buffer_file);
|
||||||
|
}
|
||||||
|
|
||||||
|
return TEST_COMPLETED;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Tests writing and reading from file using endian aware functions.
|
* @brief Tests writing and reading from file using endian aware functions.
|
||||||
*
|
*
|
||||||
|
@ -435,6 +602,7 @@ rwops_testFileWriteReadEndian(void)
|
||||||
Uint16 LE16test;
|
Uint16 LE16test;
|
||||||
Uint32 LE32test;
|
Uint32 LE32test;
|
||||||
Uint64 LE64test;
|
Uint64 LE64test;
|
||||||
|
int cresult;
|
||||||
|
|
||||||
for (mode = 0; mode < 3; mode++) {
|
for (mode = 0; mode < 3; mode++) {
|
||||||
|
|
||||||
|
@ -523,9 +691,9 @@ rwops_testFileWriteReadEndian(void)
|
||||||
SDLTest_AssertCheck(LE64test == LE64value, "Validate return value from SDL_ReadLE64, expected: %llu, got: %llu", LE64value, LE64test);
|
SDLTest_AssertCheck(LE64test == LE64value, "Validate return value from SDL_ReadLE64, expected: %llu, got: %llu", LE64value, LE64test);
|
||||||
|
|
||||||
/* Close handle */
|
/* Close handle */
|
||||||
SDL_RWclose(rw);
|
cresult = SDL_RWclose(rw);
|
||||||
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
SDLTest_AssertPass("Call to SDL_RWclose() succeeded");
|
||||||
|
SDLTest_AssertCheck(cresult == 0, "Verify result value is 0; got: %d", cresult);
|
||||||
}
|
}
|
||||||
|
|
||||||
return TEST_COMPLETED;
|
return TEST_COMPLETED;
|
||||||
|
@ -562,10 +730,13 @@ static const SDLTest_TestCaseReference rwopsTest8 =
|
||||||
static const SDLTest_TestCaseReference rwopsTest9 =
|
static const SDLTest_TestCaseReference rwopsTest9 =
|
||||||
{ (SDLTest_TestCaseFp)rwops_testFileWriteReadEndian, "rwops_testFileWriteReadEndian", "Test writing and reading via the Endian aware functions", TEST_ENABLED };
|
{ (SDLTest_TestCaseFp)rwops_testFileWriteReadEndian, "rwops_testFileWriteReadEndian", "Test writing and reading via the Endian aware functions", TEST_ENABLED };
|
||||||
|
|
||||||
|
static const SDLTest_TestCaseReference rwopsTest10 =
|
||||||
|
{ (SDLTest_TestCaseFp)rwops_testCompareRWFromMemWithRWFromFile, "rwops_testCompareRWFromMemWithRWFromFile", "Compare RWFromMem and RWFromFile RWops for read and seek", TEST_ENABLED };
|
||||||
|
|
||||||
/* Sequence of RWops test cases */
|
/* Sequence of RWops test cases */
|
||||||
static const SDLTest_TestCaseReference *rwopsTests[] = {
|
static const SDLTest_TestCaseReference *rwopsTests[] = {
|
||||||
&rwopsTest1, &rwopsTest2, &rwopsTest3, &rwopsTest4, &rwopsTest5, &rwopsTest6,
|
&rwopsTest1, &rwopsTest2, &rwopsTest3, &rwopsTest4, &rwopsTest5, &rwopsTest6,
|
||||||
&rwopsTest7, &rwopsTest8, &rwopsTest9, NULL
|
&rwopsTest7, &rwopsTest8, &rwopsTest9, &rwopsTest10, NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
/* RWops test suite (global) */
|
/* RWops test suite (global) */
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue