00cc9309cb
de6e324bdseparate emu thread10d3daf86Roms List improvements95d202f37Let's make the rom list process on a separate thread so the emulator doesnt take ages to load.fc306967fWow the ROM Header was just completely busted. Game list view works nowbad1691eefuck this shit2b59e5f46game list in progressd26417b83remappable inputs in progressac4af8106inpute72abc240update readme430139dc9Qt6 frontend3080d4d45Fix this small bug too08cd13b85Cop0 unused functions do not actually pose a threat (as per manual). They don't do anything, so shall we.61bb4fb44make idle loop detection a little more specific with where the load goesb037de4c3SAZDFsdff12e81e73eneed to figure out why n64-systemtest loops indefinitely at some address that appears to be valid (i think it's me not invalidating the cache properly)204f0e13bidle skipping seems to work!cb8bb634asdkfjlasdf58e5c89c1Fix compilation issue on my machine (no idea)24fb2898eattempting more serious idle skipping214719577Place rsp.Step inside cached interpreter. Gains about 3 more fpsbb97dcc23mmmmm920b77d38wjkhasdfjhkasdf430ccdab4it's a start...4f42a673aCached interpreter plays Mario 64. Start looking into RSP as wellc9a030787idle skipping works!5fbda03cenew idea366637abaIdle skipping... maybe?609fa2fb0Cache instructions implemented but broken lmao. Commented out for nowe140a6d12- Stop using inheritance for CPU, instead use composition. - Introduce KAIZEN_JIT_ENABLED optional define instead of relying on __aarch64__ and the like. - More cache work68e613057prep cache impl811b4d809fix clang formatfda755f7didkd5024ebbfsmall MI refactor in preparation of (eventually) implementing the RDRAM interface properly694b45341Merge commit '206dcdedf195fb320913584180edb12c7731e396' as 'external/SDL'206dcdedfSquashed 'external/SDL/' content from commit 4d17b99d0a4d16e1cb4need to update sdl848b19920Fix compilation errordb61b5299Merge commit 'e94a94559f28e49678fbcf72199a5258137b0fe9' as 'external/imgui'e94a94559Squashed 'external/imgui/' content from commit 02e9b8cac52edb3757need to update imguic1a705e86Emulate weird JALR behaviour4b4c32f4bFix exception for "unusable COP1" in 4 instructions i missed accidentally (again)df5828142Bug putting 0s in the log everywheref8b580048Make isviewer a sink to file8241e9735Fix exception for "unusable COP1" in 4 instructions i missed accidentallyb29715f20small changesd9a620bc1make use of my new small utility library0d1aa938eAdd 'external/ircolib/' from commit 'ce3cd726c8df8388d554abf8bb55d55020eb4450'e64eb40b3Fuck git git-subtree-dir: external/ircolib git-subtree-split:de6e324bde
929 lines
34 KiB
C
929 lines
34 KiB
C
|
|
/**
|
|
* Automated SDL_IOStream test.
|
|
*
|
|
* Original code written by Edgar Simo "bobbens"
|
|
* Ported by Markus Kauppila (markus.kauppila@gmail.com)
|
|
* Updated and extended for SDL_test by aschiffler at ferzkopp dot net
|
|
*
|
|
* Released under Public Domain.
|
|
*/
|
|
|
|
/* quiet windows compiler warnings */
|
|
#if defined(_MSC_VER) && !defined(_CRT_SECURE_NO_WARNINGS)
|
|
#define _CRT_SECURE_NO_WARNINGS
|
|
#endif
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <SDL3/SDL.h>
|
|
#include <SDL3/SDL_test.h>
|
|
#include "testautomation_suites.h"
|
|
|
|
/* ================= Test Case Implementation ================== */
|
|
|
|
static const char *IOStreamReadTestFilename = "iostrm_read";
|
|
static const char *IOStreamWriteTestFilename = "iostrm_write";
|
|
static const char *IOStreamAlphabetFilename = "iostrm_alphabet";
|
|
|
|
static const char IOStreamHelloWorldTestString[] = "Hello World!";
|
|
static const char IOStreamHelloWorldCompString[] = "Hello World!";
|
|
static const char IOStreamAlphabetString[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
|
|
|
|
/* Fixture */
|
|
|
|
static void SDLCALL IOStreamSetUp(void **arg)
|
|
{
|
|
size_t fileLen;
|
|
SDL_IOStream *handle;
|
|
size_t writtenLen;
|
|
bool result;
|
|
|
|
/* Clean up from previous runs (if any); ignore errors */
|
|
SDL_RemovePath(IOStreamReadTestFilename);
|
|
SDL_RemovePath(IOStreamWriteTestFilename);
|
|
SDL_RemovePath(IOStreamAlphabetFilename);
|
|
|
|
/* Create a test file */
|
|
handle = SDL_IOFromFile(IOStreamReadTestFilename, "w");
|
|
SDLTest_AssertCheck(handle != NULL, "Verify creation of file '%s' returned non NULL handle", IOStreamReadTestFilename);
|
|
if (handle == NULL) {
|
|
return;
|
|
}
|
|
|
|
/* Write some known text into it */
|
|
fileLen = SDL_strlen(IOStreamHelloWorldTestString);
|
|
writtenLen = SDL_WriteIO(handle, IOStreamHelloWorldTestString, fileLen);
|
|
SDLTest_AssertCheck(fileLen == writtenLen, "Verify number of written bytes, expected %i, got %i", (int)fileLen, (int)writtenLen);
|
|
result = SDL_CloseIO(handle);
|
|
SDLTest_AssertCheck(result == true, "Verify result from SDL_CloseIO, expected true, got %s", result ? "true" : "false");
|
|
|
|
/* Create a second test file */
|
|
handle = SDL_IOFromFile(IOStreamAlphabetFilename, "w");
|
|
SDLTest_AssertCheck(handle != NULL, "Verify creation of file '%s' returned non NULL handle", IOStreamAlphabetFilename);
|
|
if (handle == NULL) {
|
|
return;
|
|
}
|
|
|
|
/* Write alphabet text into it */
|
|
fileLen = SDL_strlen(IOStreamAlphabetString);
|
|
writtenLen = SDL_WriteIO(handle, IOStreamAlphabetString, fileLen);
|
|
SDLTest_AssertCheck(fileLen == writtenLen, "Verify number of written bytes, expected %i, got %i", (int)fileLen, (int)writtenLen);
|
|
result = SDL_CloseIO(handle);
|
|
SDLTest_AssertCheck(result == true, "Verify result from SDL_CloseIO, expected true, got %s", result ? "true" : "false");
|
|
|
|
SDLTest_AssertPass("Creation of test file completed");
|
|
}
|
|
|
|
static void SDLCALL IOStreamTearDown(void *arg)
|
|
{
|
|
int result;
|
|
|
|
/* Remove the created files to clean up; ignore errors for write filename */
|
|
result = remove(IOStreamReadTestFilename);
|
|
SDLTest_AssertCheck(result == 0, "Verify result from remove(%s), expected 0, got %i", IOStreamReadTestFilename, result);
|
|
(void)remove(IOStreamWriteTestFilename);
|
|
result = remove(IOStreamAlphabetFilename);
|
|
SDLTest_AssertCheck(result == 0, "Verify result from remove(%s), expected 0, got %i", IOStreamAlphabetFilename, result);
|
|
|
|
SDLTest_AssertPass("Cleanup of test files completed");
|
|
}
|
|
|
|
/**
|
|
* Makes sure parameters work properly. Local helper function.
|
|
*
|
|
* \sa SDL_SeekIO
|
|
* \sa SDL_ReadIO
|
|
*/
|
|
static void testGenericIOStreamValidations(SDL_IOStream *rw, bool write)
|
|
{
|
|
char buf[sizeof(IOStreamHelloWorldTestString)];
|
|
Sint64 i;
|
|
size_t s;
|
|
int seekPos = SDLTest_RandomIntegerInRange(4, 8);
|
|
|
|
/* Clear buffer */
|
|
SDL_zeroa(buf);
|
|
|
|
/* Set to start. */
|
|
i = SDL_SeekIO(rw, 0, SDL_IO_SEEK_SET);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO succeeded");
|
|
SDLTest_AssertCheck(i == (Sint64)0, "Verify seek to 0 with SDL_SeekIO (SDL_IO_SEEK_SET), expected 0, got %" SDL_PRIs64, i);
|
|
|
|
/* Test write */
|
|
s = SDL_WriteIO(rw, IOStreamHelloWorldTestString, sizeof(IOStreamHelloWorldTestString) - 1);
|
|
SDLTest_AssertPass("Call to SDL_WriteIO succeeded");
|
|
if (write) {
|
|
SDLTest_AssertCheck(s == sizeof(IOStreamHelloWorldTestString) - 1, "Verify result of writing with SDL_WriteIO, expected %i, got %i", (int)sizeof(IOStreamHelloWorldTestString) - 1, (int)s);
|
|
} else {
|
|
SDLTest_AssertCheck(s == 0, "Verify result of writing with SDL_WriteIO, expected: 0, got %i", (int)s);
|
|
}
|
|
|
|
/* Test seek to random position */
|
|
i = SDL_SeekIO(rw, seekPos, SDL_IO_SEEK_SET);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO succeeded");
|
|
SDLTest_AssertCheck(i == (Sint64)seekPos, "Verify seek to %i with SDL_SeekIO (SDL_IO_SEEK_SET), expected %i, got %" SDL_PRIs64, seekPos, seekPos, i);
|
|
|
|
/* Test seek back to start */
|
|
i = SDL_SeekIO(rw, 0, SDL_IO_SEEK_SET);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO succeeded");
|
|
SDLTest_AssertCheck(i == (Sint64)0, "Verify seek to 0 with SDL_SeekIO (SDL_IO_SEEK_SET), expected 0, got %" SDL_PRIs64, i);
|
|
|
|
/* Test read */
|
|
s = SDL_ReadIO(rw, buf, sizeof(IOStreamHelloWorldTestString) - 1);
|
|
SDLTest_AssertPass("Call to SDL_ReadIO succeeded");
|
|
SDLTest_AssertCheck(
|
|
s == (sizeof(IOStreamHelloWorldTestString) - 1),
|
|
"Verify result from SDL_ReadIO, expected %i, got %i",
|
|
(int)(sizeof(IOStreamHelloWorldTestString) - 1),
|
|
(int)s);
|
|
SDLTest_AssertCheck(
|
|
SDL_memcmp(buf, IOStreamHelloWorldTestString, sizeof(IOStreamHelloWorldTestString) - 1) == 0,
|
|
"Verify read bytes match expected string, expected '%s', got '%s'", IOStreamHelloWorldTestString, buf);
|
|
|
|
/* Test seek back to start */
|
|
i = SDL_SeekIO(rw, 0, SDL_IO_SEEK_SET);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO succeeded");
|
|
SDLTest_AssertCheck(i == (Sint64)0, "Verify seek to 0 with SDL_SeekIO (SDL_IO_SEEK_SET), expected 0, got %" SDL_PRIs64, i);
|
|
|
|
/* Test printf */
|
|
s = SDL_IOprintf(rw, "%s", IOStreamHelloWorldTestString);
|
|
SDLTest_AssertPass("Call to SDL_IOprintf succeeded");
|
|
if (write) {
|
|
SDLTest_AssertCheck(s == sizeof(IOStreamHelloWorldTestString) - 1, "Verify result of writing with SDL_IOprintf, expected %i, got %i", (int)sizeof(IOStreamHelloWorldTestString) - 1, (int)s);
|
|
} else {
|
|
SDLTest_AssertCheck(s == 0, "Verify result of writing with SDL_WriteIO, expected: 0, got %i", (int)s);
|
|
}
|
|
|
|
/* Test seek back to start */
|
|
i = SDL_SeekIO(rw, 0, SDL_IO_SEEK_SET);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO succeeded");
|
|
SDLTest_AssertCheck(i == (Sint64)0, "Verify seek to 0 with SDL_SeekIO (SDL_IO_SEEK_SET), expected 0, got %" SDL_PRIs64, i);
|
|
|
|
/* Test read */
|
|
s = SDL_ReadIO(rw, buf, sizeof(IOStreamHelloWorldTestString) - 1);
|
|
SDLTest_AssertPass("Call to SDL_ReadIO succeeded");
|
|
SDLTest_AssertCheck(
|
|
s == (sizeof(IOStreamHelloWorldTestString) - 1),
|
|
"Verify result from SDL_ReadIO, expected %i, got %i",
|
|
(int)(sizeof(IOStreamHelloWorldTestString) - 1),
|
|
(int)s);
|
|
SDLTest_AssertCheck(
|
|
SDL_memcmp(buf, IOStreamHelloWorldTestString, sizeof(IOStreamHelloWorldTestString) - 1) == 0,
|
|
"Verify read bytes match expected string, expected '%s', got '%s'", IOStreamHelloWorldTestString, buf);
|
|
|
|
/* More seek tests. */
|
|
i = SDL_SeekIO(rw, -4, SDL_IO_SEEK_CUR);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO(...,-4,SDL_IO_SEEK_CUR) succeeded");
|
|
SDLTest_AssertCheck(
|
|
i == (Sint64)(sizeof(IOStreamHelloWorldTestString) - 5),
|
|
"Verify seek to -4 with SDL_SeekIO (SDL_IO_SEEK_CUR), expected %i, got %i",
|
|
(int)(sizeof(IOStreamHelloWorldTestString) - 5),
|
|
(int)i);
|
|
|
|
i = SDL_SeekIO(rw, -1, SDL_IO_SEEK_END);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO(...,-1,SDL_IO_SEEK_END) succeeded");
|
|
SDLTest_AssertCheck(
|
|
i == (Sint64)(sizeof(IOStreamHelloWorldTestString) - 2),
|
|
"Verify seek to -1 with SDL_SeekIO (SDL_IO_SEEK_END), expected %i, got %i",
|
|
(int)(sizeof(IOStreamHelloWorldTestString) - 2),
|
|
(int)i);
|
|
|
|
/* Invalid whence seek */
|
|
i = SDL_SeekIO(rw, 0, (SDL_IOWhence)999);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO(...,0,invalid_whence) succeeded");
|
|
SDLTest_AssertCheck(
|
|
i == (Sint64)(-1),
|
|
"Verify seek with SDL_SeekIO (invalid_whence); expected: -1, got %i",
|
|
(int)i);
|
|
}
|
|
|
|
/**
|
|
* Makes sure parameters work properly. Local helper function.
|
|
*
|
|
* \sa SDL_SeekIO
|
|
* \sa SDL_ReadIO
|
|
*/
|
|
static void testEmptyIOStreamValidations(SDL_IOStream *rw, bool write)
|
|
{
|
|
char con[sizeof(IOStreamHelloWorldTestString)];
|
|
char buf[sizeof(IOStreamHelloWorldTestString)];
|
|
Sint64 i;
|
|
size_t s;
|
|
int seekPos = SDLTest_RandomIntegerInRange(4, 8);
|
|
|
|
/* Clear control & buffer */
|
|
SDL_zeroa(con);
|
|
SDL_zeroa(buf);
|
|
|
|
/* Set to start. */
|
|
i = SDL_SeekIO(rw, 0, SDL_IO_SEEK_SET);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO succeeded");
|
|
SDLTest_AssertCheck(i == (Sint64)0, "Verify seek to 0 with SDL_SeekIO (SDL_IO_SEEK_SET), expected 0, got %" SDL_PRIs64, i);
|
|
|
|
/* Test write */
|
|
s = SDL_WriteIO(rw, IOStreamHelloWorldTestString, sizeof(IOStreamHelloWorldTestString) - 1);
|
|
SDLTest_AssertPass("Call to SDL_WriteIO succeeded");
|
|
if (write) {
|
|
SDLTest_AssertCheck(s == 0, "Verify result of writing with SDL_WriteIO, expected 0, got %i", (int)s);
|
|
} else {
|
|
SDLTest_AssertCheck(s == 0, "Verify result of writing with SDL_WriteIO, expected 0, got %i", (int)s);
|
|
}
|
|
|
|
/* Test seek to random position */
|
|
i = SDL_SeekIO(rw, seekPos, SDL_IO_SEEK_SET);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO succeeded");
|
|
SDLTest_AssertCheck(i == 0, "Verify seek to %i with SDL_SeekIO (SDL_IO_SEEK_SET), expected 0, got %" SDL_PRIs64, seekPos, i);
|
|
|
|
/* Test seek back to start */
|
|
i = SDL_SeekIO(rw, 0, SDL_IO_SEEK_SET);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO succeeded");
|
|
SDLTest_AssertCheck(i == (Sint64)0, "Verify seek to 0 with SDL_SeekIO (SDL_IO_SEEK_SET), expected 0, got %" SDL_PRIs64, i);
|
|
|
|
/* Test read */
|
|
s = SDL_ReadIO(rw, buf, sizeof(IOStreamHelloWorldTestString) - 1);
|
|
SDLTest_AssertPass("Call to SDL_ReadIO succeeded");
|
|
SDLTest_AssertCheck(s == 0, "Verify result from SDL_ReadIO, expected 0, got %i", (int)s);
|
|
SDLTest_AssertCheck(
|
|
SDL_memcmp(buf, con, sizeof(IOStreamHelloWorldTestString) - 1) == 0,
|
|
"Verify that buffer remains unchanged, expected '%s', got '%s'", con, buf);
|
|
|
|
/* Test seek back to start */
|
|
i = SDL_SeekIO(rw, 0, SDL_IO_SEEK_SET);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO succeeded");
|
|
SDLTest_AssertCheck(i == (Sint64)0, "Verify seek to 0 with SDL_SeekIO (SDL_IO_SEEK_SET), expected 0, got %" SDL_PRIs64, i);
|
|
|
|
/* Test printf */
|
|
s = SDL_IOprintf(rw, "%s", IOStreamHelloWorldTestString);
|
|
SDLTest_AssertPass("Call to SDL_IOprintf succeeded");
|
|
if (write) {
|
|
SDLTest_AssertCheck(s == 0, "Verify result of writing with SDL_IOprintf, expected 0, got %i", (int)s);
|
|
} else {
|
|
SDLTest_AssertCheck(s == 0, "Verify result of writing with SDL_WriteIO, expected 0, got %i", (int)s);
|
|
}
|
|
|
|
/* Test seek back to start */
|
|
i = SDL_SeekIO(rw, 0, SDL_IO_SEEK_SET);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO succeeded");
|
|
SDLTest_AssertCheck(i == (Sint64)0, "Verify seek to 0 with SDL_SeekIO (SDL_IO_SEEK_SET), expected 0, got %" SDL_PRIs64, i);
|
|
|
|
/* Test read */
|
|
s = SDL_ReadIO(rw, buf, sizeof(IOStreamHelloWorldTestString) - 1);
|
|
SDLTest_AssertPass("Call to SDL_ReadIO succeeded");
|
|
SDLTest_AssertCheck(
|
|
s == 0,
|
|
"Verify result from SDL_ReadIO, expected 0, got %i",
|
|
(int)s);
|
|
SDLTest_AssertCheck(
|
|
SDL_memcmp(buf, con, sizeof(IOStreamHelloWorldTestString) - 1) == 0,
|
|
"Verify that buffer remains unchanged, expected '%s', got '%s'", con, buf);
|
|
|
|
/* More seek tests. */
|
|
i = SDL_SeekIO(rw, -4, SDL_IO_SEEK_CUR);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO(...,-4,SDL_IO_SEEK_CUR) succeeded");
|
|
SDLTest_AssertCheck(
|
|
i == 0,
|
|
"Verify seek to -4 with SDL_SeekIO (SDL_IO_SEEK_CUR), expected 0, got %i",
|
|
(int)i);
|
|
|
|
i = SDL_SeekIO(rw, -1, SDL_IO_SEEK_END);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO(...,-1,SDL_IO_SEEK_END) succeeded");
|
|
SDLTest_AssertCheck(
|
|
i == 0,
|
|
"Verify seek to -1 with SDL_SeekIO (SDL_IO_SEEK_END), expected 0, got %i",
|
|
(int)i);
|
|
|
|
/* Invalid whence seek */
|
|
i = SDL_SeekIO(rw, 0, (SDL_IOWhence)999);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO(...,0,invalid_whence) succeeded");
|
|
SDLTest_AssertCheck(
|
|
i == (Sint64)(-1),
|
|
"Verify seek with SDL_SeekIO (invalid_whence); expected: -1, got %i",
|
|
(int)i);
|
|
}
|
|
|
|
/**
|
|
* Negative test for SDL_IOFromFile parameters
|
|
*
|
|
* \sa SDL_IOFromFile
|
|
*
|
|
*/
|
|
static int SDLCALL iostrm_testParamNegative(void *arg)
|
|
{
|
|
SDL_IOStream *iostrm;
|
|
|
|
/* These should all fail. */
|
|
iostrm = SDL_IOFromFile(NULL, NULL);
|
|
SDLTest_AssertPass("Call to SDL_IOFromFile(NULL, NULL) succeeded");
|
|
SDLTest_AssertCheck(iostrm == NULL, "Verify SDL_IOFromFile(NULL, NULL) returns NULL");
|
|
|
|
iostrm = SDL_IOFromFile(NULL, "ab+");
|
|
SDLTest_AssertPass("Call to SDL_IOFromFile(NULL, \"ab+\") succeeded");
|
|
SDLTest_AssertCheck(iostrm == NULL, "Verify SDL_IOFromFile(NULL, \"ab+\") returns NULL");
|
|
|
|
iostrm = SDL_IOFromFile(NULL, "sldfkjsldkfj");
|
|
SDLTest_AssertPass("Call to SDL_IOFromFile(NULL, \"sldfkjsldkfj\") succeeded");
|
|
SDLTest_AssertCheck(iostrm == NULL, "Verify SDL_IOFromFile(NULL, \"sldfkjsldkfj\") returns NULL");
|
|
|
|
iostrm = SDL_IOFromFile("something", "");
|
|
SDLTest_AssertPass("Call to SDL_IOFromFile(\"something\", \"\") succeeded");
|
|
SDLTest_AssertCheck(iostrm == NULL, "Verify SDL_IOFromFile(\"something\", \"\") returns NULL");
|
|
|
|
iostrm = SDL_IOFromFile("something", NULL);
|
|
SDLTest_AssertPass("Call to SDL_IOFromFile(\"something\", NULL) succeeded");
|
|
SDLTest_AssertCheck(iostrm == NULL, "Verify SDL_IOFromFile(\"something\", NULL) returns NULL");
|
|
|
|
iostrm = SDL_IOFromMem(NULL, 10);
|
|
SDLTest_AssertPass("Call to SDL_IOFromMem(NULL, 10) succeeded");
|
|
SDLTest_AssertCheck(iostrm == NULL, "Verify SDL_IOFromMem(NULL, 10) returns NULL");
|
|
|
|
return TEST_COMPLETED;
|
|
}
|
|
|
|
/**
|
|
* Tests opening from memory.
|
|
*
|
|
* \sa SDL_IOFromMem
|
|
* \sa SDL_CloseIO
|
|
*/
|
|
static int SDLCALL iostrm_testMem(void *arg)
|
|
{
|
|
char mem[sizeof(IOStreamHelloWorldTestString)];
|
|
SDL_IOStream *rw;
|
|
int result;
|
|
|
|
/* Clear buffer */
|
|
SDL_zeroa(mem);
|
|
|
|
/* Open */
|
|
rw = SDL_IOFromMem(mem, sizeof(IOStreamHelloWorldTestString) - 1);
|
|
SDLTest_AssertPass("Call to SDL_IOFromMem() succeeded");
|
|
SDLTest_AssertCheck(rw != NULL, "Verify opening memory with SDL_IOFromMem does not return NULL");
|
|
|
|
/* Bail out if NULL */
|
|
if (rw == NULL) {
|
|
return TEST_ABORTED;
|
|
}
|
|
|
|
/* Run generic tests */
|
|
testGenericIOStreamValidations(rw, true);
|
|
|
|
/* Close */
|
|
result = SDL_CloseIO(rw);
|
|
SDLTest_AssertPass("Call to SDL_CloseIO() succeeded");
|
|
SDLTest_AssertCheck(result == true, "Verify result value is true; got: %d", result);
|
|
|
|
return TEST_COMPLETED;
|
|
}
|
|
|
|
/**
|
|
* Tests opening from memory.
|
|
*
|
|
* \sa SDL_IOFromConstMem
|
|
* \sa SDL_CloseIO
|
|
*/
|
|
static int SDLCALL iostrm_testConstMem(void *arg)
|
|
{
|
|
SDL_IOStream *rw;
|
|
int result;
|
|
|
|
/* Open handle */
|
|
rw = SDL_IOFromConstMem(IOStreamHelloWorldCompString, sizeof(IOStreamHelloWorldCompString) - 1);
|
|
SDLTest_AssertPass("Call to SDL_IOFromConstMem() succeeded");
|
|
SDLTest_AssertCheck(rw != NULL, "Verify opening memory with SDL_IOFromConstMem does not return NULL");
|
|
|
|
/* Bail out if NULL */
|
|
if (rw == NULL) {
|
|
return TEST_ABORTED;
|
|
}
|
|
|
|
/* Run generic tests */
|
|
testGenericIOStreamValidations(rw, false);
|
|
|
|
/* Close handle */
|
|
result = SDL_CloseIO(rw);
|
|
SDLTest_AssertPass("Call to SDL_CloseIO() succeeded");
|
|
SDLTest_AssertCheck(result == true, "Verify result value is true; got: %d", result);
|
|
|
|
return TEST_COMPLETED;
|
|
}
|
|
|
|
/**
|
|
* Tests opening nothing.
|
|
*
|
|
* \sa SDL_IOFromMem
|
|
* \sa SDL_CloseIO
|
|
*/
|
|
static int SDLCALL iostrm_testMemEmpty(void *arg)
|
|
{
|
|
char mem[sizeof(IOStreamHelloWorldTestString)];
|
|
SDL_IOStream *rw;
|
|
int result;
|
|
|
|
/* Clear buffer */
|
|
SDL_zeroa(mem);
|
|
|
|
/* Open empty */
|
|
rw = SDL_IOFromMem(mem, 0);
|
|
SDLTest_AssertPass("Call to SDL_IOFromMem() succeeded");
|
|
SDLTest_AssertCheck(rw != NULL, "Verify opening memory with SDL_IOFromMem does not return NULL");
|
|
|
|
/* Bail out if NULL */
|
|
if (rw == NULL) {
|
|
return TEST_ABORTED;
|
|
}
|
|
|
|
/* Run generic tests */
|
|
testEmptyIOStreamValidations(rw, true);
|
|
|
|
/* Close */
|
|
result = SDL_CloseIO(rw);
|
|
SDLTest_AssertPass("Call to SDL_CloseIO() succeeded");
|
|
SDLTest_AssertCheck(result == true, "Verify result value is true; got: %d", result);
|
|
|
|
return TEST_COMPLETED;
|
|
}
|
|
|
|
/**
|
|
* Tests opening nothing.
|
|
*
|
|
* \sa SDL_IOFromMem
|
|
* \sa SDL_CloseIO
|
|
*/
|
|
static int SDLCALL iostrm_testConstMemEmpty(void *arg)
|
|
{
|
|
SDL_IOStream *rw;
|
|
int result;
|
|
|
|
/* Open handle */
|
|
rw = SDL_IOFromConstMem(IOStreamHelloWorldCompString, 0);
|
|
SDLTest_AssertPass("Call to SDL_IOFromConstMem() succeeded");
|
|
SDLTest_AssertCheck(rw != NULL, "Verify opening memory with SDL_IOFromConstMem does not return NULL");
|
|
|
|
/* Bail out if NULL */
|
|
if (rw == NULL) {
|
|
return TEST_ABORTED;
|
|
}
|
|
|
|
/* Run generic tests */
|
|
testEmptyIOStreamValidations(rw, false);
|
|
|
|
/* Close handle */
|
|
result = SDL_CloseIO(rw);
|
|
SDLTest_AssertPass("Call to SDL_CloseIO() succeeded");
|
|
SDLTest_AssertCheck(result == true, "Verify result value is true; got: %d", result);
|
|
|
|
return TEST_COMPLETED;
|
|
}
|
|
|
|
static int free_call_count;
|
|
void SDLCALL test_free(void* mem) {
|
|
free_call_count++;
|
|
SDL_free(mem);
|
|
}
|
|
|
|
static int SDLCALL iostrm_testMemWithFree(void *arg)
|
|
{
|
|
void *mem;
|
|
SDL_IOStream *rw;
|
|
int result;
|
|
|
|
/* Allocate some memory */
|
|
mem = SDL_malloc(sizeof(IOStreamHelloWorldCompString) - 1);
|
|
if (mem == NULL) {
|
|
return TEST_ABORTED;
|
|
}
|
|
|
|
/* Open handle */
|
|
rw = SDL_IOFromMem(mem, sizeof(IOStreamHelloWorldCompString) - 1);
|
|
SDLTest_AssertPass("Call to SDL_IOFromMem() succeeded");
|
|
SDLTest_AssertCheck(rw != NULL, "Verify opening memory with SDL_IOFromMem does not return NULL");
|
|
|
|
/* Bail out if NULL */
|
|
if (rw == NULL) {
|
|
return TEST_ABORTED;
|
|
}
|
|
|
|
/* Set the free function */
|
|
free_call_count = 0;
|
|
result = SDL_SetPointerProperty(SDL_GetIOProperties(rw), SDL_PROP_IOSTREAM_MEMORY_FREE_FUNC_POINTER, test_free);
|
|
SDLTest_AssertPass("Call to SDL_SetPointerProperty() succeeded");
|
|
SDLTest_AssertCheck(result == true, "Verify result value is true; got %d", result);
|
|
|
|
/* Run generic tests */
|
|
testGenericIOStreamValidations(rw, true);
|
|
|
|
/* Close handle */
|
|
result = SDL_CloseIO(rw);
|
|
SDLTest_AssertPass("Call to SDL_CloseIO() succeeded");
|
|
SDLTest_AssertCheck(result == true, "Verify result value is true; got: %d", result);
|
|
SDLTest_AssertCheck(free_call_count == 1, "Verify the custom free function was called once; call count: %d", free_call_count);
|
|
|
|
return TEST_COMPLETED;
|
|
}
|
|
|
|
/**
|
|
* Tests dynamic memory
|
|
*
|
|
* \sa SDL_IOFromDynamicMem
|
|
* \sa SDL_CloseIO
|
|
*/
|
|
static int SDLCALL iostrm_testDynamicMem(void *arg)
|
|
{
|
|
SDL_IOStream *rw;
|
|
SDL_PropertiesID props;
|
|
char *mem;
|
|
int result;
|
|
|
|
/* Open */
|
|
rw = SDL_IOFromDynamicMem();
|
|
SDLTest_AssertPass("Call to SDL_IOFromDynamicMem() succeeded");
|
|
SDLTest_AssertCheck(rw != NULL, "Verify opening memory with SDL_IOFromDynamicMem does not return NULL");
|
|
|
|
/* Bail out if NULL */
|
|
if (rw == NULL) {
|
|
return TEST_ABORTED;
|
|
}
|
|
|
|
/* Set the chunk size to 1 byte */
|
|
props = SDL_GetIOProperties(rw);
|
|
SDL_SetNumberProperty(props, SDL_PROP_IOSTREAM_DYNAMIC_CHUNKSIZE_NUMBER, 1);
|
|
|
|
/* Run generic tests */
|
|
testGenericIOStreamValidations(rw, true);
|
|
|
|
/* Get the dynamic memory and verify it */
|
|
mem = (char *)SDL_GetPointerProperty(props, SDL_PROP_IOSTREAM_DYNAMIC_MEMORY_POINTER, NULL);
|
|
SDLTest_AssertPass("Call to SDL_GetPointerProperty(props, SDL_PROP_IOSTREAM_DYNAMIC_MEMORY_POINTER, NULL) succeeded");
|
|
SDLTest_AssertCheck(mem != NULL, "Verify memory value is not NULL");
|
|
mem[SDL_GetIOSize(rw)] = '\0';
|
|
SDLTest_AssertCheck(SDL_strcmp(mem, IOStreamHelloWorldTestString) == 0, "Verify memory value is correct");
|
|
|
|
/* Take the memory and free it ourselves */
|
|
SDL_SetPointerProperty(props, SDL_PROP_IOSTREAM_DYNAMIC_MEMORY_POINTER, NULL);
|
|
SDL_free(mem);
|
|
|
|
/* Close */
|
|
result = SDL_CloseIO(rw);
|
|
SDLTest_AssertPass("Call to SDL_CloseIO() succeeded");
|
|
SDLTest_AssertCheck(result == true, "Verify result value is true; got: %d", result);
|
|
|
|
return TEST_COMPLETED;
|
|
}
|
|
|
|
/**
|
|
* Tests reading from file.
|
|
*
|
|
* \sa SDL_IOFromFile
|
|
* \sa SDL_CloseIO
|
|
*/
|
|
static int SDLCALL iostrm_testFileRead(void *arg)
|
|
{
|
|
SDL_IOStream *rw;
|
|
int result;
|
|
|
|
/* Read test. */
|
|
rw = SDL_IOFromFile(IOStreamReadTestFilename, "r");
|
|
SDLTest_AssertPass("Call to SDL_IOFromFile(..,\"r\") succeeded");
|
|
SDLTest_AssertCheck(rw != NULL, "Verify opening file with SDL_IOFromFile in read mode does not return NULL");
|
|
|
|
/* Bail out if NULL */
|
|
if (rw == NULL) {
|
|
return TEST_ABORTED;
|
|
}
|
|
|
|
/* Run generic tests */
|
|
testGenericIOStreamValidations(rw, false);
|
|
|
|
/* Close handle */
|
|
result = SDL_CloseIO(rw);
|
|
SDLTest_AssertPass("Call to SDL_CloseIO() succeeded");
|
|
SDLTest_AssertCheck(result == true, "Verify result value is true; got: %d", result);
|
|
|
|
return TEST_COMPLETED;
|
|
}
|
|
|
|
/**
|
|
* Tests writing from file.
|
|
*
|
|
* \sa SDL_IOFromFile
|
|
* \sa SDL_CloseIO
|
|
*/
|
|
static int SDLCALL iostrm_testFileWrite(void *arg)
|
|
{
|
|
SDL_IOStream *rw;
|
|
int result;
|
|
|
|
/* Write test. */
|
|
rw = SDL_IOFromFile(IOStreamWriteTestFilename, "w+x");
|
|
SDLTest_AssertPass("Call to SDL_IOFromFile(..,\"w+x\") succeeded");
|
|
SDLTest_AssertCheck(rw != NULL, "Verify opening file with SDL_IOFromFile in exclusive write mode does not return NULL");
|
|
|
|
/* Bail out if NULL */
|
|
if (rw == NULL) {
|
|
return TEST_ABORTED;
|
|
}
|
|
|
|
/* Run generic tests */
|
|
testGenericIOStreamValidations(rw, true);
|
|
|
|
/* Close handle */
|
|
result = SDL_CloseIO(rw);
|
|
SDLTest_AssertPass("Call to SDL_CloseIO() succeeded");
|
|
SDLTest_AssertCheck(result == true, "Verify result value is true; got: %d", result);
|
|
|
|
/* Exclusively opening an existing file should fail. */
|
|
rw = SDL_IOFromFile(IOStreamWriteTestFilename, "wx");
|
|
SDLTest_AssertPass("Call to SDL_IOFromFile(..,\"wx\") succeeded");
|
|
SDLTest_AssertCheck(rw == NULL, "Verify opening existing file with SDL_IOFromFile in exclusive write mode returns NULL");
|
|
|
|
return TEST_COMPLETED;
|
|
}
|
|
|
|
/**
|
|
* Tests alloc and free RW context.
|
|
*
|
|
* \sa SDL_OpenIO
|
|
* \sa SDL_CloseIO
|
|
*/
|
|
static int SDLCALL iostrm_testAllocFree(void *arg)
|
|
{
|
|
/* Allocate context */
|
|
SDL_IOStreamInterface iface;
|
|
SDL_IOStream *rw;
|
|
|
|
SDL_INIT_INTERFACE(&iface);
|
|
rw = SDL_OpenIO(&iface, NULL);
|
|
SDLTest_AssertPass("Call to SDL_OpenIO() succeeded");
|
|
SDLTest_AssertCheck(rw != NULL, "Validate result from SDL_OpenIO() is not NULL");
|
|
if (rw == NULL) {
|
|
return TEST_ABORTED;
|
|
}
|
|
|
|
/* Free context again */
|
|
SDL_CloseIO(rw);
|
|
SDLTest_AssertPass("Call to SDL_CloseIO() succeeded");
|
|
|
|
return TEST_COMPLETED;
|
|
}
|
|
|
|
/**
|
|
* Compare memory and file reads
|
|
*
|
|
* \sa SDL_IOFromMem
|
|
* \sa SDL_IOFromFile
|
|
*/
|
|
static int SDLCALL iostrm_testCompareRWFromMemWithRWFromFile(void *arg)
|
|
{
|
|
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_IOStream *iostrm_file;
|
|
SDL_IOStream *iostrm_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 */
|
|
iostrm_mem = SDL_IOFromMem((void *)IOStreamAlphabetString, slen);
|
|
SDLTest_AssertPass("Call to SDL_IOFromMem()");
|
|
rv_mem = SDL_ReadIO(iostrm_mem, buffer_mem, size * 6);
|
|
SDLTest_AssertPass("Call to SDL_ReadIO(mem, size=%d)", size * 6);
|
|
sv_mem = SDL_SeekIO(iostrm_mem, 0, SEEK_END);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO(mem,SEEK_END)");
|
|
result = SDL_CloseIO(iostrm_mem);
|
|
SDLTest_AssertPass("Call to SDL_CloseIO(mem)");
|
|
SDLTest_AssertCheck(result == true, "Verify result value is true; got: %d", result);
|
|
|
|
/* Read/see from file */
|
|
iostrm_file = SDL_IOFromFile(IOStreamAlphabetFilename, "r");
|
|
SDLTest_AssertPass("Call to SDL_IOFromFile()");
|
|
rv_file = SDL_ReadIO(iostrm_file, buffer_file, size * 6);
|
|
SDLTest_AssertPass("Call to SDL_ReadIO(file, size=%d)", size * 6);
|
|
sv_file = SDL_SeekIO(iostrm_file, 0, SEEK_END);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO(file,SEEK_END)");
|
|
result = SDL_CloseIO(iostrm_file);
|
|
SDLTest_AssertPass("Call to SDL_CloseIO(file)");
|
|
SDLTest_AssertCheck(result == true, "Verify result value is true; 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", (int)rv_mem, (int)rv_file);
|
|
SDLTest_AssertCheck(sv_mem == sv_file, "Verify SEEK_END position matches for mem and file seeks; got: sv_mem=%d sv_file=%d", (int)sv_mem, (int)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, IOStreamAlphabetString, slen) == 0,
|
|
"Verify mem buffer contain alphabet string; expected: %s, got: %s", IOStreamAlphabetString, buffer_mem);
|
|
SDLTest_AssertCheck(
|
|
SDL_strncmp(buffer_file, IOStreamAlphabetString, slen) == 0,
|
|
"Verify file buffer contain alphabet string; expected: %s, got: %s", IOStreamAlphabetString, buffer_file);
|
|
}
|
|
|
|
return TEST_COMPLETED;
|
|
}
|
|
|
|
/**
|
|
* Tests writing and reading from file using endian aware functions.
|
|
*
|
|
* \sa SDL_IOFromFile
|
|
* \sa SDL_CloseIO
|
|
* \sa SDL_ReadU16BE
|
|
* \sa SDL_WriteU16BE
|
|
*/
|
|
static int SDLCALL iostrm_testFileWriteReadEndian(void *arg)
|
|
{
|
|
SDL_IOStream *rw;
|
|
Sint64 result;
|
|
int mode;
|
|
Uint16 BE16value;
|
|
Uint32 BE32value;
|
|
Uint64 BE64value;
|
|
Uint16 LE16value;
|
|
Uint32 LE32value;
|
|
Uint64 LE64value;
|
|
Uint16 BE16test;
|
|
Uint32 BE32test;
|
|
Uint64 BE64test;
|
|
Uint16 LE16test;
|
|
Uint32 LE32test;
|
|
Uint64 LE64test;
|
|
bool bresult;
|
|
int cresult;
|
|
|
|
for (mode = 0; mode < 3; mode++) {
|
|
|
|
/* Create test data */
|
|
switch (mode) {
|
|
default:
|
|
case 0:
|
|
SDLTest_Log("All 0 values");
|
|
BE16value = 0;
|
|
BE32value = 0;
|
|
BE64value = 0;
|
|
LE16value = 0;
|
|
LE32value = 0;
|
|
LE64value = 0;
|
|
break;
|
|
case 1:
|
|
SDLTest_Log("All 1 values");
|
|
BE16value = 1;
|
|
BE32value = 1;
|
|
BE64value = 1;
|
|
LE16value = 1;
|
|
LE32value = 1;
|
|
LE64value = 1;
|
|
break;
|
|
case 2:
|
|
SDLTest_Log("Random values");
|
|
BE16value = SDLTest_RandomUint16();
|
|
BE32value = SDLTest_RandomUint32();
|
|
BE64value = SDLTest_RandomUint64();
|
|
LE16value = SDLTest_RandomUint16();
|
|
LE32value = SDLTest_RandomUint32();
|
|
LE64value = SDLTest_RandomUint64();
|
|
break;
|
|
}
|
|
|
|
/* Write test. */
|
|
rw = SDL_IOFromFile(IOStreamWriteTestFilename, "w+");
|
|
SDLTest_AssertPass("Call to SDL_IOFromFile(..,\"w+\")");
|
|
SDLTest_AssertCheck(rw != NULL, "Verify opening file with SDL_IOFromFile in write mode does not return NULL");
|
|
|
|
/* Bail out if NULL */
|
|
if (rw == NULL) {
|
|
return TEST_ABORTED;
|
|
}
|
|
|
|
/* Write test data */
|
|
bresult = SDL_WriteU16BE(rw, BE16value);
|
|
SDLTest_AssertPass("Call to SDL_WriteU16BE()");
|
|
SDLTest_AssertCheck(bresult == true, "Validate object written, expected: true, got: false");
|
|
bresult = SDL_WriteU32BE(rw, BE32value);
|
|
SDLTest_AssertPass("Call to SDL_WriteU32BE()");
|
|
SDLTest_AssertCheck(bresult == true, "Validate object written, expected: true, got: false");
|
|
bresult = SDL_WriteU64BE(rw, BE64value);
|
|
SDLTest_AssertPass("Call to SDL_WriteU64BE()");
|
|
SDLTest_AssertCheck(bresult == true, "Validate object written, expected: true, got: false");
|
|
bresult = SDL_WriteU16LE(rw, LE16value);
|
|
SDLTest_AssertPass("Call to SDL_WriteU16LE()");
|
|
SDLTest_AssertCheck(bresult == true, "Validate object written, expected: true, got: false");
|
|
bresult = SDL_WriteU32LE(rw, LE32value);
|
|
SDLTest_AssertPass("Call to SDL_WriteU32LE()");
|
|
SDLTest_AssertCheck(bresult == true, "Validate object written, expected: true, got: false");
|
|
bresult = SDL_WriteU64LE(rw, LE64value);
|
|
SDLTest_AssertPass("Call to SDL_WriteU64LE()");
|
|
SDLTest_AssertCheck(bresult == true, "Validate object written, expected: true, got: false");
|
|
|
|
/* Test seek to start */
|
|
result = SDL_SeekIO(rw, 0, SDL_IO_SEEK_SET);
|
|
SDLTest_AssertPass("Call to SDL_SeekIO succeeded");
|
|
SDLTest_AssertCheck(result == 0, "Verify result from position 0 with SDL_SeekIO, expected 0, got %i", (int)result);
|
|
|
|
/* Read test data */
|
|
bresult = SDL_ReadU16BE(rw, &BE16test);
|
|
SDLTest_AssertPass("Call to SDL_ReadU16BE()");
|
|
SDLTest_AssertCheck(bresult == true, "Validate object read, expected: true, got: false");
|
|
SDLTest_AssertCheck(BE16test == BE16value, "Validate object read from SDL_ReadU16BE, expected: %hu, got: %hu", BE16value, BE16test);
|
|
bresult = SDL_ReadU32BE(rw, &BE32test);
|
|
SDLTest_AssertPass("Call to SDL_ReadU32BE()");
|
|
SDLTest_AssertCheck(bresult == true, "Validate object read, expected: true, got: false");
|
|
SDLTest_AssertCheck(BE32test == BE32value, "Validate object read from SDL_ReadU32BE, expected: %" SDL_PRIu32 ", got: %" SDL_PRIu32, BE32value, BE32test);
|
|
bresult = SDL_ReadU64BE(rw, &BE64test);
|
|
SDLTest_AssertPass("Call to SDL_ReadU64BE()");
|
|
SDLTest_AssertCheck(bresult == true, "Validate object read, expected: true, got: false");
|
|
SDLTest_AssertCheck(BE64test == BE64value, "Validate object read from SDL_ReadU64BE, expected: %" SDL_PRIu64 ", got: %" SDL_PRIu64, BE64value, BE64test);
|
|
bresult = SDL_ReadU16LE(rw, &LE16test);
|
|
SDLTest_AssertPass("Call to SDL_ReadU16LE()");
|
|
SDLTest_AssertCheck(bresult == true, "Validate object read, expected: true, got: false");
|
|
SDLTest_AssertCheck(LE16test == LE16value, "Validate object read from SDL_ReadU16LE, expected: %hu, got: %hu", LE16value, LE16test);
|
|
bresult = SDL_ReadU32LE(rw, &LE32test);
|
|
SDLTest_AssertPass("Call to SDL_ReadU32LE()");
|
|
SDLTest_AssertCheck(bresult == true, "Validate object read, expected: true, got: false");
|
|
SDLTest_AssertCheck(LE32test == LE32value, "Validate object read from SDL_ReadU32LE, expected: %" SDL_PRIu32 ", got: %" SDL_PRIu32, LE32value, LE32test);
|
|
bresult = SDL_ReadU64LE(rw, &LE64test);
|
|
SDLTest_AssertPass("Call to SDL_ReadU64LE()");
|
|
SDLTest_AssertCheck(bresult == true, "Validate object read, expected: true, got: false");
|
|
SDLTest_AssertCheck(LE64test == LE64value, "Validate object read from SDL_ReadU64LE, expected: %" SDL_PRIu64 ", got: %" SDL_PRIu64, LE64value, LE64test);
|
|
|
|
/* Close handle */
|
|
cresult = SDL_CloseIO(rw);
|
|
SDLTest_AssertPass("Call to SDL_CloseIO() succeeded");
|
|
SDLTest_AssertCheck(cresult == true, "Verify result value is true; got: %d", cresult);
|
|
}
|
|
|
|
return TEST_COMPLETED;
|
|
}
|
|
|
|
/* ================= Test References ================== */
|
|
|
|
/* IOStream test cases */
|
|
static const SDLTest_TestCaseReference iostrmTest1 = {
|
|
iostrm_testParamNegative, "iostrm_testParamNegative", "Negative test for SDL_IOFromFile parameters", TEST_ENABLED
|
|
};
|
|
|
|
static const SDLTest_TestCaseReference iostrmTest2 = {
|
|
iostrm_testMem, "iostrm_testMem", "Tests opening from memory", TEST_ENABLED
|
|
};
|
|
|
|
static const SDLTest_TestCaseReference iostrmTest3 = {
|
|
iostrm_testConstMem, "iostrm_testConstMem", "Tests opening from (const) memory", TEST_ENABLED
|
|
};
|
|
|
|
static const SDLTest_TestCaseReference iostrmTest4 = {
|
|
iostrm_testDynamicMem, "iostrm_testDynamicMem", "Tests opening dynamic memory", TEST_ENABLED
|
|
};
|
|
|
|
static const SDLTest_TestCaseReference iostrmTest5 = {
|
|
iostrm_testFileRead, "iostrm_testFileRead", "Tests reading from a file", TEST_ENABLED
|
|
};
|
|
|
|
static const SDLTest_TestCaseReference iostrmTest6 = {
|
|
iostrm_testFileWrite, "iostrm_testFileWrite", "Test writing to a file", TEST_ENABLED
|
|
};
|
|
|
|
static const SDLTest_TestCaseReference iostrmTest7 = {
|
|
iostrm_testAllocFree, "iostrm_testAllocFree", "Test alloc and free of RW context", TEST_ENABLED
|
|
};
|
|
|
|
static const SDLTest_TestCaseReference iostrmTest8 = {
|
|
iostrm_testFileWriteReadEndian, "iostrm_testFileWriteReadEndian", "Test writing and reading via the Endian aware functions", TEST_ENABLED
|
|
};
|
|
|
|
static const SDLTest_TestCaseReference iostrmTest9 = {
|
|
iostrm_testCompareRWFromMemWithRWFromFile, "iostrm_testCompareRWFromMemWithRWFromFile", "Compare RWFromMem and RWFromFile IOStream for read and seek", TEST_ENABLED
|
|
};
|
|
|
|
static const SDLTest_TestCaseReference iostrmTest10 = {
|
|
iostrm_testMemWithFree, "iostrm_testMemWithFree", "Tests opening from memory with free on close", TEST_ENABLED
|
|
};
|
|
|
|
static const SDLTest_TestCaseReference iostrmTest11 = {
|
|
iostrm_testMemEmpty, "iostrm_testMemEmpty", "Tests opening empty memory stream", TEST_ENABLED
|
|
};
|
|
|
|
static const SDLTest_TestCaseReference iostrmTest12 = {
|
|
iostrm_testConstMemEmpty, "iostrm_testConstMemEmpty", "Tests opening empty (const) memory stream", TEST_ENABLED
|
|
};
|
|
|
|
/* Sequence of IOStream test cases */
|
|
static const SDLTest_TestCaseReference *iostrmTests[] = {
|
|
&iostrmTest1, &iostrmTest2, &iostrmTest3, &iostrmTest4, &iostrmTest5, &iostrmTest6,
|
|
&iostrmTest7, &iostrmTest8, &iostrmTest9, &iostrmTest10, &iostrmTest11, &iostrmTest12, NULL
|
|
};
|
|
|
|
/* IOStream test suite (global) */
|
|
SDLTest_TestSuiteReference iostrmTestSuite = {
|
|
"IOStream",
|
|
IOStreamSetUp,
|
|
iostrmTests,
|
|
IOStreamTearDown
|
|
};
|