2015-06-21 17:33:46 +02:00
/**
* Original code : automated SDL audio test written by Edgar Simo " bobbens "
* New / updated tests : aschiffler at ferzkopp dot net
*/
/* quiet windows compiler warnings */
2022-10-06 01:09:32 +02:00
# if defined(_MSC_VER) && !defined(_CRT_SECURE_NO_WARNINGS)
2022-11-30 12:51:59 -08:00
# define _CRT_SECURE_NO_WARNINGS
2022-10-06 01:09:32 +02:00
# endif
2015-06-21 17:33:46 +02:00
# include <stdio.h>
2022-11-26 20:43:38 -08:00
# include <SDL3/SDL.h>
# include <SDL3/SDL_test.h>
2015-06-21 17:33:46 +02:00
/* ================= Test Case Implementation ================== */
/* Fixture */
2022-12-29 22:58:16 +01:00
static void audioSetUp ( void * arg )
2015-06-21 17:33:46 +02:00
{
/* Start SDL audio subsystem */
2022-11-30 12:51:59 -08:00
int ret = SDL_InitSubSystem ( SDL_INIT_AUDIO ) ;
SDLTest_AssertPass ( " Call to SDL_InitSubSystem(SDL_INIT_AUDIO) " ) ;
SDLTest_AssertCheck ( ret = = 0 , " Check result from SDL_InitSubSystem(SDL_INIT_AUDIO) " ) ;
2015-06-21 17:33:46 +02:00
if ( ret ! = 0 ) {
2022-11-30 12:51:59 -08:00
SDLTest_LogError ( " %s " , SDL_GetError ( ) ) ;
}
2015-06-21 17:33:46 +02:00
}
2022-12-29 22:58:16 +01:00
static void audioTearDown ( void * arg )
2015-06-21 17:33:46 +02:00
{
/* Remove a possibly created file from SDL disk writer audio driver; ignore errors */
2022-12-01 16:07:03 -05:00
( void ) remove ( " sdlaudio.raw " ) ;
2015-06-21 17:33:46 +02:00
SDLTest_AssertPass ( " Cleanup of test files completed " ) ;
}
/* Global counter for callback invocation */
2022-12-29 22:58:16 +01:00
static int g_audio_testCallbackCounter ;
2015-06-21 17:33:46 +02:00
/* Global accumulator for total callback length */
2022-12-29 22:58:16 +01:00
static int g_audio_testCallbackLength ;
2015-06-21 17:33:46 +02:00
/* Test callback function */
2022-12-29 22:58:16 +01:00
static void SDLCALL audio_testCallback ( void * userdata , Uint8 * stream , int len )
2015-06-21 17:33:46 +02:00
{
2022-11-30 12:51:59 -08:00
/* track that callback was called */
2022-12-29 22:58:16 +01:00
g_audio_testCallbackCounter + + ;
g_audio_testCallbackLength + = len ;
2015-06-21 17:33:46 +02:00
}
2023-01-05 09:57:14 +01:00
static SDL_AudioDeviceID g_audio_id = - 1 ;
2015-06-21 17:33:46 +02:00
/* Test case functions */
/**
* \ brief Stop and restart audio subsystem
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_QuitSubSystem
* \ sa SDL_InitSubSystem
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_quitInitAudioSubSystem ( void * arg )
2015-06-21 17:33:46 +02:00
{
/* Stop SDL audio subsystem */
2022-11-30 12:51:59 -08:00
SDL_QuitSubSystem ( SDL_INIT_AUDIO ) ;
SDLTest_AssertPass ( " Call to SDL_QuitSubSystem(SDL_INIT_AUDIO) " ) ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
/* Restart audio again */
2022-12-29 22:58:16 +01:00
audioSetUp ( NULL ) ;
2015-06-21 17:33:46 +02:00
return TEST_COMPLETED ;
}
/**
* \ brief Start and stop audio directly
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_InitAudio
* \ sa SDL_QuitAudio
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_initQuitAudio ( void * arg )
2015-06-21 17:33:46 +02:00
{
2022-11-30 12:51:59 -08:00
int result ;
2015-06-21 17:33:46 +02:00
int i , iMax ;
2022-11-30 12:51:59 -08:00
const char * audioDriver ;
2015-06-21 17:33:46 +02:00
/* Stop SDL audio subsystem */
2022-11-30 12:51:59 -08:00
SDL_QuitSubSystem ( SDL_INIT_AUDIO ) ;
SDLTest_AssertPass ( " Call to SDL_QuitSubSystem(SDL_INIT_AUDIO) " ) ;
/* Loop over all available audio drivers */
iMax = SDL_GetNumAudioDrivers ( ) ;
SDLTest_AssertPass ( " Call to SDL_GetNumAudioDrivers() " ) ;
SDLTest_AssertCheck ( iMax > 0 , " Validate number of audio drivers; expected: >0 got: %d " , iMax ) ;
for ( i = 0 ; i < iMax ; i + + ) {
audioDriver = SDL_GetAudioDriver ( i ) ;
SDLTest_AssertPass ( " Call to SDL_GetAudioDriver(%d) " , i ) ;
2022-12-01 16:07:03 -05:00
SDLTest_Assert ( audioDriver ! = NULL , " Audio driver name is not NULL " ) ;
SDLTest_AssertCheck ( audioDriver [ 0 ] ! = ' \0 ' , " Audio driver name is not empty; got: %s " , audioDriver ) ; /* NOLINT(clang-analyzer-core.NullDereference): Checked for NULL above */
2022-11-30 12:51:59 -08:00
/* Call Init */
2022-12-27 14:22:22 +01:00
SDL_SetHint ( " SDL_AUDIO_DRIVER " , audioDriver ) ;
result = SDL_InitSubSystem ( SDL_INIT_AUDIO ) ;
SDLTest_AssertPass ( " Call to SDL_InitSubSystem(SDL_INIT_AUDIO) with driver='%s' " , audioDriver ) ;
2022-11-30 12:51:59 -08:00
SDLTest_AssertCheck ( result = = 0 , " Validate result value; expected: 0 got: %d " , result ) ;
/* Call Quit */
2022-12-27 14:22:22 +01:00
SDL_QuitSubSystem ( SDL_INIT_AUDIO ) ;
SDLTest_AssertPass ( " Call to SDL_QuitSubSystem(SDL_INIT_AUDIO) " ) ;
2015-06-21 17:33:46 +02:00
}
/* NULL driver specification */
audioDriver = NULL ;
/* Call Init */
2022-12-27 14:22:22 +01:00
SDL_SetHint ( " SDL_AUDIO_DRIVER " , audioDriver ) ;
result = SDL_InitSubSystem ( SDL_INIT_AUDIO ) ;
2015-06-21 17:33:46 +02:00
SDLTest_AssertPass ( " Call to SDL_AudioInit(NULL) " ) ;
SDLTest_AssertCheck ( result = = 0 , " Validate result value; expected: 0 got: %d " , result ) ;
/* Call Quit */
2022-12-27 14:22:22 +01:00
SDL_QuitSubSystem ( SDL_INIT_AUDIO ) ;
SDLTest_AssertPass ( " Call to SDL_QuitSubSystem(SDL_INIT_AUDIO) " ) ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
/* Restart audio again */
2022-12-29 22:58:16 +01:00
audioSetUp ( NULL ) ;
2015-06-21 17:33:46 +02:00
return TEST_COMPLETED ;
}
/**
* \ brief Start , open , close and stop audio
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_InitAudio
* \ sa SDL_OpenAudioDevice
* \ sa SDL_CloseAudioDevice
* \ sa SDL_QuitAudio
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_initOpenCloseQuitAudio ( void * arg )
2015-06-21 17:33:46 +02:00
{
2023-01-05 09:57:14 +01:00
int result ;
2015-06-21 17:33:46 +02:00
int i , iMax , j , k ;
2022-11-30 12:51:59 -08:00
const char * audioDriver ;
2015-06-21 17:33:46 +02:00
SDL_AudioSpec desired ;
/* Stop SDL audio subsystem */
2022-11-30 12:51:59 -08:00
SDL_QuitSubSystem ( SDL_INIT_AUDIO ) ;
SDLTest_AssertPass ( " Call to SDL_QuitSubSystem(SDL_INIT_AUDIO) " ) ;
/* Loop over all available audio drivers */
iMax = SDL_GetNumAudioDrivers ( ) ;
SDLTest_AssertPass ( " Call to SDL_GetNumAudioDrivers() " ) ;
SDLTest_AssertCheck ( iMax > 0 , " Validate number of audio drivers; expected: >0 got: %d " , iMax ) ;
for ( i = 0 ; i < iMax ; i + + ) {
audioDriver = SDL_GetAudioDriver ( i ) ;
SDLTest_AssertPass ( " Call to SDL_GetAudioDriver(%d) " , i ) ;
2022-12-01 16:07:03 -05:00
SDLTest_Assert ( audioDriver ! = NULL , " Audio driver name is not NULL " ) ;
SDLTest_AssertCheck ( audioDriver [ 0 ] ! = ' \0 ' , " Audio driver name is not empty; got: %s " , audioDriver ) ; /* NOLINT(clang-analyzer-core.NullDereference): Checked for NULL above */
2022-11-30 12:51:59 -08:00
/* Change specs */
for ( j = 0 ; j < 2 ; j + + ) {
/* Call Init */
2022-12-27 14:22:22 +01:00
SDL_SetHint ( " SDL_AUDIO_DRIVER " , audioDriver ) ;
result = SDL_InitSubSystem ( SDL_INIT_AUDIO ) ;
SDLTest_AssertPass ( " Call to SDL_InitSubSystem(SDL_INIT_AUDIO) with driver='%s' " , audioDriver ) ;
2022-11-30 12:51:59 -08:00
SDLTest_AssertCheck ( result = = 0 , " Validate result value; expected: 0 got: %d " , result ) ;
/* Set spec */
SDL_memset ( & desired , 0 , sizeof ( desired ) ) ;
switch ( j ) {
case 0 :
/* Set standard desired spec */
desired . freq = 22050 ;
desired . format = AUDIO_S16SYS ;
desired . channels = 2 ;
desired . samples = 4096 ;
2022-12-29 22:58:16 +01:00
desired . callback = audio_testCallback ;
2022-11-30 12:51:59 -08:00
desired . userdata = NULL ;
case 1 :
/* Set custom desired spec */
desired . freq = 48000 ;
desired . format = AUDIO_F32SYS ;
desired . channels = 2 ;
desired . samples = 2048 ;
2022-12-29 22:58:16 +01:00
desired . callback = audio_testCallback ;
2022-11-30 12:51:59 -08:00
desired . userdata = NULL ;
break ;
2015-06-21 17:33:46 +02:00
}
/* Call Open (maybe multiple times) */
2022-11-30 12:51:59 -08:00
for ( k = 0 ; k < = j ; k + + ) {
2023-01-05 09:57:14 +01:00
result = SDL_OpenAudioDevice ( NULL , 0 , & desired , NULL , 0 ) ;
if ( k = = 0 ) {
g_audio_id = result ;
}
SDLTest_AssertPass ( " Call to SDL_OpenAudioDevice(NULL, 0, desired_spec_%d, NULL, 0), call %d " , j , k + 1 ) ;
SDLTest_AssertCheck ( result > 0 , " Verify return value; expected: > 0, got: %d " , result ) ;
2015-06-21 17:33:46 +02:00
}
/* Call Close (maybe multiple times) */
2022-11-30 12:51:59 -08:00
for ( k = 0 ; k < = j ; k + + ) {
2023-01-05 09:57:14 +01:00
SDL_CloseAudioDevice ( g_audio_id ) ;
SDLTest_AssertPass ( " Call to SDL_CloseAudioDevice(), call %d " , k + 1 ) ;
2015-06-21 17:33:46 +02:00
}
/* Call Quit (maybe multiple times) */
2022-11-30 12:51:59 -08:00
for ( k = 0 ; k < = j ; k + + ) {
2022-12-27 14:22:22 +01:00
SDL_QuitSubSystem ( SDL_INIT_AUDIO ) ;
SDLTest_AssertPass ( " Call to SDL_QuitSubSystem(SDL_INIT_AUDIO), call %d " , k + 1 ) ;
2015-06-21 17:33:46 +02:00
}
} /* spec loop */
2022-11-30 12:51:59 -08:00
} /* driver loop */
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
/* Restart audio again */
2022-12-29 22:58:16 +01:00
audioSetUp ( NULL ) ;
2015-06-21 17:33:46 +02:00
return TEST_COMPLETED ;
}
/**
* \ brief Pause and unpause audio
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_PauseAudioDevice
* \ sa SDL_PlayAudioDevice
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_pauseUnpauseAudio ( void * arg )
2015-06-21 17:33:46 +02:00
{
int result ;
int i , iMax , j , k , l ;
int totalDelay ;
int pause_on ;
int originalCounter ;
2022-11-30 12:51:59 -08:00
const char * audioDriver ;
2015-06-21 17:33:46 +02:00
SDL_AudioSpec desired ;
/* Stop SDL audio subsystem */
2022-11-30 12:51:59 -08:00
SDL_QuitSubSystem ( SDL_INIT_AUDIO ) ;
SDLTest_AssertPass ( " Call to SDL_QuitSubSystem(SDL_INIT_AUDIO) " ) ;
/* Loop over all available audio drivers */
iMax = SDL_GetNumAudioDrivers ( ) ;
SDLTest_AssertPass ( " Call to SDL_GetNumAudioDrivers() " ) ;
SDLTest_AssertCheck ( iMax > 0 , " Validate number of audio drivers; expected: >0 got: %d " , iMax ) ;
for ( i = 0 ; i < iMax ; i + + ) {
audioDriver = SDL_GetAudioDriver ( i ) ;
SDLTest_AssertPass ( " Call to SDL_GetAudioDriver(%d) " , i ) ;
2022-12-01 16:07:03 -05:00
SDLTest_Assert ( audioDriver ! = NULL , " Audio driver name is not NULL " ) ;
SDLTest_AssertCheck ( audioDriver [ 0 ] ! = ' \0 ' , " Audio driver name is not empty; got: %s " , audioDriver ) ; /* NOLINT(clang-analyzer-core.NullDereference): Checked for NULL above */
2022-11-30 12:51:59 -08:00
/* Change specs */
for ( j = 0 ; j < 2 ; j + + ) {
/* Call Init */
2022-12-27 14:22:22 +01:00
SDL_SetHint ( " SDL_AUDIO_DRIVER " , audioDriver ) ;
result = SDL_InitSubSystem ( SDL_INIT_AUDIO ) ;
SDLTest_AssertPass ( " Call to SDL_InitSubSystem(SDL_INIT_AUDIO) with driver='%s' " , audioDriver ) ;
2022-11-30 12:51:59 -08:00
SDLTest_AssertCheck ( result = = 0 , " Validate result value; expected: 0 got: %d " , result ) ;
/* Set spec */
SDL_memset ( & desired , 0 , sizeof ( desired ) ) ;
switch ( j ) {
case 0 :
/* Set standard desired spec */
desired . freq = 22050 ;
desired . format = AUDIO_S16SYS ;
desired . channels = 2 ;
desired . samples = 4096 ;
2022-12-29 22:58:16 +01:00
desired . callback = audio_testCallback ;
2022-11-30 12:51:59 -08:00
desired . userdata = NULL ;
case 1 :
/* Set custom desired spec */
desired . freq = 48000 ;
desired . format = AUDIO_F32SYS ;
desired . channels = 2 ;
desired . samples = 2048 ;
2022-12-29 22:58:16 +01:00
desired . callback = audio_testCallback ;
2022-11-30 12:51:59 -08:00
desired . userdata = NULL ;
break ;
2015-06-21 17:33:46 +02:00
}
/* Call Open */
2023-01-05 09:57:14 +01:00
g_audio_id = SDL_OpenAudioDevice ( NULL , 0 , & desired , NULL , 0 ) ;
result = g_audio_id ;
SDLTest_AssertPass ( " Call to SDL_OpenAudioDevice(NULL, 0, desired_spec_%d, NULL, 0) " , j ) ;
SDLTest_AssertCheck ( result > 0 , " Verify return value; expected > 0 got: %d " , result ) ;
2015-06-21 17:33:46 +02:00
/* Start and stop audio multiple times */
2022-11-30 12:51:59 -08:00
for ( l = 0 ; l < 3 ; l + + ) {
SDLTest_Log ( " Pause/Unpause iteration: %d " , l + 1 ) ;
2015-06-21 17:33:46 +02:00
/* Reset callback counters */
2022-12-29 22:58:16 +01:00
g_audio_testCallbackCounter = 0 ;
g_audio_testCallbackLength = 0 ;
2015-06-21 17:33:46 +02:00
/* Un-pause audio to start playing (maybe multiple times) */
pause_on = 0 ;
2022-11-30 12:51:59 -08:00
for ( k = 0 ; k < = j ; k + + ) {
2023-01-06 13:59:45 +01:00
SDL_PlayAudioDevice ( g_audio_id ) ;
SDLTest_AssertPass ( " Call to SDL_PlayAudioDevice(g_audio_id), call %d " , k + 1 ) ;
2015-06-21 17:33:46 +02:00
}
2022-11-30 12:51:59 -08:00
2015-06-21 17:33:46 +02:00
/* Wait for callback */
totalDelay = 0 ;
do {
SDL_Delay ( 10 ) ;
totalDelay + = 10 ;
2022-12-29 22:58:16 +01:00
} while ( g_audio_testCallbackCounter = = 0 & & totalDelay < 1000 ) ;
SDLTest_AssertCheck ( g_audio_testCallbackCounter > 0 , " Verify callback counter; expected: >0 got: %d " , g_audio_testCallbackCounter ) ;
SDLTest_AssertCheck ( g_audio_testCallbackLength > 0 , " Verify callback length; expected: >0 got: %d " , g_audio_testCallbackLength ) ;
2015-06-21 17:33:46 +02:00
/* Pause audio to stop playing (maybe multiple times) */
2022-11-30 12:51:59 -08:00
for ( k = 0 ; k < = j ; k + + ) {
pause_on = ( k = = 0 ) ? 1 : SDLTest_RandomIntegerInRange ( 99 , 9999 ) ;
2023-01-06 13:59:45 +01:00
if ( pause_on ) {
SDL_PauseAudioDevice ( g_audio_id ) ;
SDLTest_AssertPass ( " Call to SDL_PauseAudioDevice(g_audio_id), call %d " , k + 1 ) ;
} else {
SDL_PlayAudioDevice ( g_audio_id ) ;
SDLTest_AssertPass ( " Call to SDL_PlayAudioDevice(g_audio_id), call %d " , k + 1 ) ;
}
2015-06-21 17:33:46 +02:00
}
2022-11-30 12:51:59 -08:00
2015-06-21 17:33:46 +02:00
/* Ensure callback is not called again */
2022-12-29 22:58:16 +01:00
originalCounter = g_audio_testCallbackCounter ;
2015-06-21 17:33:46 +02:00
SDL_Delay ( totalDelay + 10 ) ;
2022-12-29 22:58:16 +01:00
SDLTest_AssertCheck ( originalCounter = = g_audio_testCallbackCounter , " Verify callback counter; expected: %d, got: %d " , originalCounter , g_audio_testCallbackCounter ) ;
2015-06-21 17:33:46 +02:00
}
/* Call Close */
2023-01-05 09:57:14 +01:00
SDL_CloseAudioDevice ( g_audio_id ) ;
SDLTest_AssertPass ( " Call to SDL_CloseAudioDevice() " ) ;
2015-06-21 17:33:46 +02:00
/* Call Quit */
2022-12-27 14:22:22 +01:00
SDL_QuitSubSystem ( SDL_INIT_AUDIO ) ;
SDLTest_AssertPass ( " Call to SDL_QuitSubSystem(SDL_INIT_AUDIO) " ) ;
2015-06-21 17:33:46 +02:00
} /* spec loop */
2022-11-30 12:51:59 -08:00
} /* driver loop */
2015-06-21 17:33:46 +02:00
/* Restart audio again */
2022-12-29 22:58:16 +01:00
audioSetUp ( NULL ) ;
2015-06-21 17:33:46 +02:00
return TEST_COMPLETED ;
}
/**
* \ brief Enumerate and name available audio devices ( output and capture ) .
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_GetNumAudioDevices
* \ sa SDL_GetAudioDeviceName
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_enumerateAndNameAudioDevices ( void * arg )
2015-06-21 17:33:46 +02:00
{
2022-11-30 12:51:59 -08:00
int t , tt ;
int i , n , nn ;
const char * name , * nameAgain ;
/* Iterate over types: t=0 output device, t=1 input/capture device */
for ( t = 0 ; t < 2 ; t + + ) {
/* Get number of devices. */
n = SDL_GetNumAudioDevices ( t ) ;
SDLTest_AssertPass ( " Call to SDL_GetNumAudioDevices(%i) " , t ) ;
SDLTest_Log ( " Number of %s devices < 0, reported as %i " , ( t ) ? " capture " : " output " , n ) ;
SDLTest_AssertCheck ( n > = 0 , " Validate result is >= 0, got: %i " , n ) ;
/* Variation of non-zero type */
if ( t = = 1 ) {
tt = t + SDLTest_RandomIntegerInRange ( 1 , 10 ) ;
nn = SDL_GetNumAudioDevices ( tt ) ;
SDLTest_AssertCheck ( n = = nn , " Verify result from SDL_GetNumAudioDevices(%i), expected same number of audio devices %i, got %i " , tt , n , nn ) ;
nn = SDL_GetNumAudioDevices ( - tt ) ;
SDLTest_AssertCheck ( n = = nn , " Verify result from SDL_GetNumAudioDevices(%i), expected same number of audio devices %i, got %i " , - tt , n , nn ) ;
}
/* List devices. */
if ( n > 0 ) {
for ( i = 0 ; i < n ; i + + ) {
name = SDL_GetAudioDeviceName ( i , t ) ;
SDLTest_AssertPass ( " Call to SDL_GetAudioDeviceName(%i, %i) " , i , t ) ;
SDLTest_AssertCheck ( name ! = NULL , " Verify result from SDL_GetAudioDeviceName(%i, %i) is not NULL " , i , t ) ;
if ( name ! = NULL ) {
SDLTest_AssertCheck ( name [ 0 ] ! = ' \0 ' , " verify result from SDL_GetAudioDeviceName(%i, %i) is not empty, got: '%s' " , i , t , name ) ;
if ( t = = 1 ) {
/* Also try non-zero type */
tt = t + SDLTest_RandomIntegerInRange ( 1 , 10 ) ;
nameAgain = SDL_GetAudioDeviceName ( i , tt ) ;
SDLTest_AssertCheck ( nameAgain ! = NULL , " Verify result from SDL_GetAudioDeviceName(%i, %i) is not NULL " , i , tt ) ;
if ( nameAgain ! = NULL ) {
SDLTest_AssertCheck ( nameAgain [ 0 ] ! = ' \0 ' , " Verify result from SDL_GetAudioDeviceName(%i, %i) is not empty, got: '%s' " , i , tt , nameAgain ) ;
SDLTest_AssertCheck ( SDL_strcmp ( name , nameAgain ) = = 0 ,
" Verify SDL_GetAudioDeviceName(%i, %i) and SDL_GetAudioDeviceName(%i %i) return the same string " ,
i , t , i , tt ) ;
}
}
}
2015-06-21 17:33:46 +02:00
}
2022-11-30 12:51:59 -08:00
}
}
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
return TEST_COMPLETED ;
2015-06-21 17:33:46 +02:00
}
/**
* \ brief Negative tests around enumeration and naming of audio devices .
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_GetNumAudioDevices
* \ sa SDL_GetAudioDeviceName
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_enumerateAndNameAudioDevicesNegativeTests ( void * arg )
2015-06-21 17:33:46 +02:00
{
2022-11-30 12:51:59 -08:00
int t ;
int i , j , no , nc ;
const char * name ;
/* Get number of devices. */
no = SDL_GetNumAudioDevices ( 0 ) ;
SDLTest_AssertPass ( " Call to SDL_GetNumAudioDevices(0) " ) ;
nc = SDL_GetNumAudioDevices ( 1 ) ;
SDLTest_AssertPass ( " Call to SDL_GetNumAudioDevices(1) " ) ;
/* Invalid device index when getting name */
for ( t = 0 ; t < 2 ; t + + ) {
/* Negative device index */
i = SDLTest_RandomIntegerInRange ( - 10 , - 1 ) ;
name = SDL_GetAudioDeviceName ( i , t ) ;
SDLTest_AssertPass ( " Call to SDL_GetAudioDeviceName(%i, %i) " , i , t ) ;
SDLTest_AssertCheck ( name = = NULL , " Check SDL_GetAudioDeviceName(%i, %i) result NULL, expected NULL, got: %s " , i , t , ( name = = NULL ) ? " NULL " : name ) ;
/* Device index past range */
for ( j = 0 ; j < 3 ; j + + ) {
i = ( t ) ? nc + j : no + j ;
name = SDL_GetAudioDeviceName ( i , t ) ;
SDLTest_AssertPass ( " Call to SDL_GetAudioDeviceName(%i, %i) " , i , t ) ;
SDLTest_AssertCheck ( name = = NULL , " Check SDL_GetAudioDeviceName(%i, %i) result, expected: NULL, got: %s " , i , t , ( name = = NULL ) ? " NULL " : name ) ;
}
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
/* Capture index past capture range but within output range */
if ( ( no > 0 ) & & ( no > nc ) & & ( t = = 1 ) ) {
i = no - 1 ;
name = SDL_GetAudioDeviceName ( i , t ) ;
SDLTest_AssertPass ( " Call to SDL_GetAudioDeviceName(%i, %i) " , i , t ) ;
SDLTest_AssertCheck ( name = = NULL , " Check SDL_GetAudioDeviceName(%i, %i) result, expected: NULL, got: %s " , i , t , ( name = = NULL ) ? " NULL " : name ) ;
}
}
return TEST_COMPLETED ;
}
2015-06-21 17:33:46 +02:00
/**
* \ brief Checks available audio driver names .
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_GetNumAudioDrivers
* \ sa SDL_GetAudioDriver
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_printAudioDrivers ( void * arg )
2015-06-21 17:33:46 +02:00
{
2022-11-30 12:51:59 -08:00
int i , n ;
const char * name ;
/* Get number of drivers */
n = SDL_GetNumAudioDrivers ( ) ;
SDLTest_AssertPass ( " Call to SDL_GetNumAudioDrivers() " ) ;
SDLTest_AssertCheck ( n > = 0 , " Verify number of audio drivers >= 0, got: %i " , n ) ;
/* List drivers. */
if ( n > 0 ) {
for ( i = 0 ; i < n ; i + + ) {
name = SDL_GetAudioDriver ( i ) ;
SDLTest_AssertPass ( " Call to SDL_GetAudioDriver(%i) " , i ) ;
SDLTest_AssertCheck ( name ! = NULL , " Verify returned name is not NULL " ) ;
if ( name ! = NULL ) {
SDLTest_AssertCheck ( name [ 0 ] ! = ' \0 ' , " Verify returned name is not empty, got: '%s' " , name ) ;
}
}
}
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
return TEST_COMPLETED ;
}
2015-06-21 17:33:46 +02:00
/**
* \ brief Checks current audio driver name with initialized audio .
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_GetCurrentAudioDriver
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_printCurrentAudioDriver ( void * arg )
2015-06-21 17:33:46 +02:00
{
2022-11-30 12:51:59 -08:00
/* Check current audio driver */
const char * name = SDL_GetCurrentAudioDriver ( ) ;
SDLTest_AssertPass ( " Call to SDL_GetCurrentAudioDriver() " ) ;
SDLTest_AssertCheck ( name ! = NULL , " Verify returned name is not NULL " ) ;
if ( name ! = NULL ) {
SDLTest_AssertCheck ( name [ 0 ] ! = ' \0 ' , " Verify returned name is not empty, got: '%s' " , name ) ;
}
return TEST_COMPLETED ;
2015-06-21 17:33:46 +02:00
}
/* Definition of all formats, channels, and frequencies used to test audio conversions */
2023-02-28 15:17:47 -05:00
static SDL_AudioFormat g_audioFormats [ ] = { AUDIO_S8 , AUDIO_U8 , AUDIO_S16LSB , AUDIO_S16MSB , AUDIO_S16SYS , AUDIO_S16 ,
AUDIO_S32LSB , AUDIO_S32MSB , AUDIO_S32SYS , AUDIO_S32 ,
2022-11-30 12:51:59 -08:00
AUDIO_F32LSB , AUDIO_F32MSB , AUDIO_F32SYS , AUDIO_F32 } ;
2023-02-28 15:17:47 -05:00
static const char * g_audioFormatsVerbose [ ] = { " AUDIO_S8 " , " AUDIO_U8 " , " AUDIO_S16LSB " , " AUDIO_S16MSB " , " AUDIO_S16SYS " , " AUDIO_S16 " ,
" AUDIO_S32LSB " , " AUDIO_S32MSB " , " AUDIO_S32SYS " , " AUDIO_S32 " ,
2022-11-30 12:51:59 -08:00
" AUDIO_F32LSB " , " AUDIO_F32MSB " , " AUDIO_F32SYS " , " AUDIO_F32 " } ;
2023-03-01 22:56:56 +03:00
static const int g_numAudioFormats = SDL_arraysize ( g_audioFormats ) ;
2023-01-16 09:45:34 +01:00
static const int g_numAudioChannels = 4 ;
static Uint8 g_audioChannels [ ] = { 1 , 2 , 4 , 6 } ;
static const int g_numAudioFrequencies = 4 ;
static int g_audioFrequencies [ ] = { 11025 , 22050 , 44100 , 48000 } ;
2015-06-21 17:33:46 +02:00
/**
* \ brief Builds various audio conversion structures
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_CreateAudioStream
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_buildAudioStream ( void * arg )
2015-06-21 17:33:46 +02:00
{
2023-01-16 09:45:34 +01:00
SDL_AudioStream * stream ;
2022-11-30 12:51:59 -08:00
SDL_AudioSpec spec1 ;
SDL_AudioSpec spec2 ;
int i , ii , j , jj , k , kk ;
/* No conversion needed */
spec1 . format = AUDIO_S16LSB ;
spec1 . channels = 2 ;
spec1 . freq = 22050 ;
2023-01-16 09:45:34 +01:00
stream = SDL_CreateAudioStream ( spec1 . format , spec1 . channels , spec1 . freq ,
spec1 . format , spec1 . channels , spec1 . freq ) ;
SDLTest_AssertPass ( " Call to SDL_CreateAudioStream(spec1 ==> spec1) " ) ;
SDLTest_AssertCheck ( stream ! = NULL , " Verify stream value; expected: != NULL, got: %p " , ( void * ) stream ) ;
SDL_DestroyAudioStream ( stream ) ;
2022-11-30 12:51:59 -08:00
/* Typical conversion */
spec1 . format = AUDIO_S8 ;
spec1 . channels = 1 ;
spec1 . freq = 22050 ;
spec2 . format = AUDIO_S16LSB ;
spec2 . channels = 2 ;
spec2 . freq = 44100 ;
2023-01-16 09:45:34 +01:00
stream = SDL_CreateAudioStream ( spec1 . format , spec1 . channels , spec1 . freq ,
spec2 . format , spec2 . channels , spec2 . freq ) ;
SDLTest_AssertPass ( " Call to SDL_CreateAudioStream(spec1 ==> spec2) " ) ;
SDLTest_AssertCheck ( stream ! = NULL , " Verify stream value; expected: != NULL, got: %p " , ( void * ) stream ) ;
SDL_DestroyAudioStream ( stream ) ;
2022-11-30 12:51:59 -08:00
/* All source conversions with random conversion targets, allow 'null' conversions */
2022-12-29 22:58:16 +01:00
for ( i = 0 ; i < g_numAudioFormats ; i + + ) {
for ( j = 0 ; j < g_numAudioChannels ; j + + ) {
for ( k = 0 ; k < g_numAudioFrequencies ; k + + ) {
spec1 . format = g_audioFormats [ i ] ;
spec1 . channels = g_audioChannels [ j ] ;
spec1 . freq = g_audioFrequencies [ k ] ;
ii = SDLTest_RandomIntegerInRange ( 0 , g_numAudioFormats - 1 ) ;
jj = SDLTest_RandomIntegerInRange ( 0 , g_numAudioChannels - 1 ) ;
kk = SDLTest_RandomIntegerInRange ( 0 , g_numAudioFrequencies - 1 ) ;
spec2 . format = g_audioFormats [ ii ] ;
spec2 . channels = g_audioChannels [ jj ] ;
spec2 . freq = g_audioFrequencies [ kk ] ;
2023-01-16 09:45:34 +01:00
stream = SDL_CreateAudioStream ( spec1 . format , spec1 . channels , spec1 . freq ,
spec2 . format , spec2 . channels , spec2 . freq ) ;
SDLTest_AssertPass ( " Call to SDL_CreateAudioStream(format[%i]=%s(%i),channels[%i]=%i,freq[%i]=%i ==> format[%i]=%s(%i),channels[%i]=%i,freq[%i]=%i) " ,
2022-12-29 22:58:16 +01:00
i , g_audioFormatsVerbose [ i ] , spec1 . format , j , spec1 . channels , k , spec1 . freq , ii , g_audioFormatsVerbose [ ii ] , spec2 . format , jj , spec2 . channels , kk , spec2 . freq ) ;
2023-01-16 09:45:34 +01:00
SDLTest_AssertCheck ( stream ! = NULL , " Verify stream value; expected: != NULL, got: %p " , ( void * ) stream ) ;
if ( stream = = NULL ) {
2022-11-30 12:51:59 -08:00
SDLTest_LogError ( " %s " , SDL_GetError ( ) ) ;
}
2023-01-16 09:45:34 +01:00
SDL_DestroyAudioStream ( stream ) ;
2022-11-30 12:51:59 -08:00
}
2015-06-21 17:33:46 +02:00
}
}
2022-11-30 12:51:59 -08:00
return TEST_COMPLETED ;
2015-06-21 17:33:46 +02:00
}
/**
2023-01-16 09:45:34 +01:00
* \ brief Checks calls with invalid input to SDL_CreateAudioStream
2015-06-21 17:33:46 +02:00
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_CreateAudioStream
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_buildAudioStreamNegative ( void * arg )
2015-06-21 17:33:46 +02:00
{
2022-11-30 12:51:59 -08:00
const char * error ;
2023-01-16 09:45:34 +01:00
SDL_AudioStream * stream ;
2022-11-30 12:51:59 -08:00
SDL_AudioSpec spec1 ;
SDL_AudioSpec spec2 ;
int i ;
char message [ 256 ] ;
/* Valid format */
2015-06-21 17:33:46 +02:00
spec1 . format = AUDIO_S8 ;
spec1 . channels = 1 ;
spec1 . freq = 22050 ;
spec2 . format = AUDIO_S16LSB ;
spec2 . channels = 2 ;
spec2 . freq = 44100 ;
SDL_ClearError ( ) ;
SDLTest_AssertPass ( " Call to SDL_ClearError() " ) ;
2022-11-30 12:51:59 -08:00
/* Invalid conversions */
for ( i = 1 ; i < 64 ; i + + ) {
/* Valid format to start with */
spec1 . format = AUDIO_S8 ;
spec1 . channels = 1 ;
spec1 . freq = 22050 ;
spec2 . format = AUDIO_S16LSB ;
spec2 . channels = 2 ;
spec2 . freq = 44100 ;
SDL_ClearError ( ) ;
SDLTest_AssertPass ( " Call to SDL_ClearError() " ) ;
/* Set various invalid format inputs */
SDL_strlcpy ( message , " Invalid: " , 256 ) ;
if ( i & 1 ) {
SDL_strlcat ( message , " spec1.format " , 256 ) ;
spec1 . format = 0 ;
}
if ( i & 2 ) {
SDL_strlcat ( message , " spec1.channels " , 256 ) ;
spec1 . channels = 0 ;
}
if ( i & 4 ) {
SDL_strlcat ( message , " spec1.freq " , 256 ) ;
spec1 . freq = 0 ;
}
if ( i & 8 ) {
SDL_strlcat ( message , " spec2.format " , 256 ) ;
spec2 . format = 0 ;
}
if ( i & 16 ) {
SDL_strlcat ( message , " spec2.channels " , 256 ) ;
spec2 . channels = 0 ;
}
if ( i & 32 ) {
SDL_strlcat ( message , " spec2.freq " , 256 ) ;
spec2 . freq = 0 ;
}
SDLTest_Log ( " %s " , message ) ;
2023-01-16 09:45:34 +01:00
stream = SDL_CreateAudioStream ( spec1 . format , spec1 . channels , spec1 . freq ,
spec2 . format , spec2 . channels , spec2 . freq ) ;
SDLTest_AssertPass ( " Call to SDL_CreateAudioStream(spec1 ==> spec2) " ) ;
SDLTest_AssertCheck ( stream = = NULL , " Verify stream value; expected: NULL, got: %p " , ( void * ) stream ) ;
2022-11-30 12:51:59 -08:00
error = SDL_GetError ( ) ;
SDLTest_AssertPass ( " Call to SDL_GetError() " ) ;
SDLTest_AssertCheck ( error ! = NULL & & error [ 0 ] ! = ' \0 ' , " Validate that error message was not NULL or empty " ) ;
2023-01-16 09:45:34 +01:00
SDL_DestroyAudioStream ( stream ) ;
2022-11-30 12:51:59 -08:00
}
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
SDL_ClearError ( ) ;
SDLTest_AssertPass ( " Call to SDL_ClearError() " ) ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
return TEST_COMPLETED ;
2015-06-21 17:33:46 +02:00
}
/**
* \ brief Checks current audio status .
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_GetAudioDeviceStatus
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_getAudioStatus ( void * arg )
2015-06-21 17:33:46 +02:00
{
2022-11-30 12:51:59 -08:00
SDL_AudioStatus result ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
/* Check current audio status */
2023-01-05 09:57:14 +01:00
result = SDL_GetAudioDeviceStatus ( g_audio_id ) ;
SDLTest_AssertPass ( " Call to SDL_GetAudioDeviceStatus(g_audio_id) " ) ;
2022-11-30 12:51:59 -08:00
SDLTest_AssertCheck ( result = = SDL_AUDIO_STOPPED | | result = = SDL_AUDIO_PLAYING | | result = = SDL_AUDIO_PAUSED ,
" Verify returned value; expected: STOPPED (%i) | PLAYING (%i) | PAUSED (%i), got: %i " ,
SDL_AUDIO_STOPPED , SDL_AUDIO_PLAYING , SDL_AUDIO_PAUSED , result ) ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
return TEST_COMPLETED ;
2015-06-21 17:33:46 +02:00
}
/**
* \ brief Opens , checks current audio status , and closes a device .
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_GetAudioStatus
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_openCloseAndGetAudioStatus ( void * arg )
2015-06-21 17:33:46 +02:00
{
2022-11-30 12:51:59 -08:00
SDL_AudioStatus result ;
int i ;
int count ;
const char * device ;
SDL_AudioDeviceID id ;
SDL_AudioSpec desired , obtained ;
/* Get number of devices. */
count = SDL_GetNumAudioDevices ( 0 ) ;
SDLTest_AssertPass ( " Call to SDL_GetNumAudioDevices(0) " ) ;
if ( count > 0 ) {
for ( i = 0 ; i < count ; i + + ) {
/* Get device name */
device = SDL_GetAudioDeviceName ( i , 0 ) ;
SDLTest_AssertPass ( " SDL_GetAudioDeviceName(%i,0) " , i ) ;
SDLTest_AssertCheck ( device ! = NULL , " Validate device name is not NULL; got: %s " , ( device ! = NULL ) ? device : " NULL " ) ;
if ( device = = NULL ) {
return TEST_ABORTED ;
}
/* Set standard desired spec */
desired . freq = 22050 ;
desired . format = AUDIO_S16SYS ;
desired . channels = 2 ;
desired . samples = 4096 ;
2022-12-29 22:58:16 +01:00
desired . callback = audio_testCallback ;
2022-11-30 12:51:59 -08:00
desired . userdata = NULL ;
/* Open device */
id = SDL_OpenAudioDevice ( device , 0 , & desired , & obtained , SDL_AUDIO_ALLOW_ANY_CHANGE ) ;
SDLTest_AssertPass ( " SDL_OpenAudioDevice('%s',...) " , device ) ;
2023-01-05 09:57:14 +01:00
SDLTest_AssertCheck ( id > 0 , " Validate device ID; expected: > 0, got: % " SDL_PRIu32 , id ) ;
if ( id > 0 ) {
2022-11-30 12:51:59 -08:00
/* Check device audio status */
result = SDL_GetAudioDeviceStatus ( id ) ;
SDLTest_AssertPass ( " Call to SDL_GetAudioDeviceStatus() " ) ;
SDLTest_AssertCheck ( result = = SDL_AUDIO_STOPPED | | result = = SDL_AUDIO_PLAYING | | result = = SDL_AUDIO_PAUSED ,
" Verify returned value; expected: STOPPED (%i) | PLAYING (%i) | PAUSED (%i), got: %i " ,
SDL_AUDIO_STOPPED , SDL_AUDIO_PLAYING , SDL_AUDIO_PAUSED , result ) ;
/* Close device again */
SDL_CloseAudioDevice ( id ) ;
SDLTest_AssertPass ( " Call to SDL_CloseAudioDevice() " ) ;
}
}
} else {
SDLTest_Log ( " No devices to test with " ) ;
}
return TEST_COMPLETED ;
2015-06-21 17:33:46 +02:00
}
/**
* \ brief Locks and unlocks open audio device .
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_LockAudioDevice
* \ sa SDL_UnlockAudioDevice
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_lockUnlockOpenAudioDevice ( void * arg )
2015-06-21 17:33:46 +02:00
{
2022-11-30 12:51:59 -08:00
int i ;
int count ;
const char * device ;
SDL_AudioDeviceID id ;
SDL_AudioSpec desired , obtained ;
/* Get number of devices. */
count = SDL_GetNumAudioDevices ( 0 ) ;
SDLTest_AssertPass ( " Call to SDL_GetNumAudioDevices(0) " ) ;
if ( count > 0 ) {
for ( i = 0 ; i < count ; i + + ) {
/* Get device name */
device = SDL_GetAudioDeviceName ( i , 0 ) ;
SDLTest_AssertPass ( " SDL_GetAudioDeviceName(%i,0) " , i ) ;
SDLTest_AssertCheck ( device ! = NULL , " Validate device name is not NULL; got: %s " , ( device ! = NULL ) ? device : " NULL " ) ;
if ( device = = NULL ) {
return TEST_ABORTED ;
}
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
/* Set standard desired spec */
desired . freq = 22050 ;
desired . format = AUDIO_S16SYS ;
desired . channels = 2 ;
desired . samples = 4096 ;
2022-12-29 22:58:16 +01:00
desired . callback = audio_testCallback ;
2022-11-30 12:51:59 -08:00
desired . userdata = NULL ;
/* Open device */
id = SDL_OpenAudioDevice ( device , 0 , & desired , & obtained , SDL_AUDIO_ALLOW_ANY_CHANGE ) ;
SDLTest_AssertPass ( " SDL_OpenAudioDevice('%s',...) " , device ) ;
2023-01-05 09:57:14 +01:00
SDLTest_AssertCheck ( id > 1 , " Validate device ID; expected: > 0, got: % " SDL_PRIu32 , id ) ;
if ( id > 0 ) {
2022-11-30 12:51:59 -08:00
/* Lock to protect callback */
SDL_LockAudioDevice ( id ) ;
SDLTest_AssertPass ( " SDL_LockAudioDevice(% " SDL_PRIu32 " ) " , id ) ;
/* Simulate callback processing */
SDL_Delay ( 10 ) ;
SDLTest_Log ( " Simulate callback processing - delay " ) ;
/* Unlock again */
SDL_UnlockAudioDevice ( id ) ;
SDLTest_AssertPass ( " SDL_UnlockAudioDevice(% " SDL_PRIu32 " ) " , id ) ;
/* Close device again */
SDL_CloseAudioDevice ( id ) ;
SDLTest_AssertPass ( " Call to SDL_CloseAudioDevice() " ) ;
}
}
} else {
SDLTest_Log ( " No devices to test with " ) ;
}
return TEST_COMPLETED ;
}
2015-06-21 17:33:46 +02:00
/**
* \ brief Convert audio using various conversion structures
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_CreateAudioStream
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_convertAudio ( void * arg )
2015-06-21 17:33:46 +02:00
{
2023-01-16 09:45:34 +01:00
SDL_AudioStream * stream ;
2022-11-30 12:51:59 -08:00
SDL_AudioSpec spec1 ;
SDL_AudioSpec spec2 ;
int c ;
char message [ 128 ] ;
2023-01-16 09:45:34 +01:00
int i , ii , j , jj , k , kk ;
2022-11-30 12:51:59 -08:00
/* Iterate over bitmask that determines which parameters are modified in the conversion */
for ( c = 1 ; c < 8 ; c + + ) {
SDL_strlcpy ( message , " Changing: " , 128 ) ;
if ( c & 1 ) {
SDL_strlcat ( message , " Format " , 128 ) ;
}
if ( c & 2 ) {
SDL_strlcat ( message , " Channels " , 128 ) ;
}
if ( c & 4 ) {
SDL_strlcat ( message , " Frequencies " , 128 ) ;
}
SDLTest_Log ( " %s " , message ) ;
/* All source conversions with random conversion targets */
2022-12-29 22:58:16 +01:00
for ( i = 0 ; i < g_numAudioFormats ; i + + ) {
for ( j = 0 ; j < g_numAudioChannels ; j + + ) {
for ( k = 0 ; k < g_numAudioFrequencies ; k + + ) {
spec1 . format = g_audioFormats [ i ] ;
spec1 . channels = g_audioChannels [ j ] ;
spec1 . freq = g_audioFrequencies [ k ] ;
2022-11-30 12:51:59 -08:00
/* Ensure we have a different target format */
do {
if ( c & 1 ) {
2022-12-29 22:58:16 +01:00
ii = SDLTest_RandomIntegerInRange ( 0 , g_numAudioFormats - 1 ) ;
2022-11-30 12:51:59 -08:00
} else {
ii = 1 ;
}
if ( c & 2 ) {
2022-12-29 22:58:16 +01:00
jj = SDLTest_RandomIntegerInRange ( 0 , g_numAudioChannels - 1 ) ;
2022-11-30 12:51:59 -08:00
} else {
jj = j ;
}
if ( c & 4 ) {
2022-12-29 22:58:16 +01:00
kk = SDLTest_RandomIntegerInRange ( 0 , g_numAudioFrequencies - 1 ) ;
2022-11-30 12:51:59 -08:00
} else {
kk = k ;
}
} while ( ( i = = ii ) & & ( j = = jj ) & & ( k = = kk ) ) ;
2022-12-29 22:58:16 +01:00
spec2 . format = g_audioFormats [ ii ] ;
spec2 . channels = g_audioChannels [ jj ] ;
spec2 . freq = g_audioFrequencies [ kk ] ;
2022-11-30 12:51:59 -08:00
2023-01-16 09:45:34 +01:00
stream = SDL_CreateAudioStream ( spec1 . format , spec1 . channels , spec1 . freq ,
spec2 . format , spec2 . channels , spec2 . freq ) ;
SDLTest_AssertPass ( " Call to SDL_CreateAudioStream(format[%i]=%s(%i),channels[%i]=%i,freq[%i]=%i ==> format[%i]=%s(%i),channels[%i]=%i,freq[%i]=%i) " ,
2022-12-29 22:58:16 +01:00
i , g_audioFormatsVerbose [ i ] , spec1 . format , j , spec1 . channels , k , spec1 . freq , ii , g_audioFormatsVerbose [ ii ] , spec2 . format , jj , spec2 . channels , kk , spec2 . freq ) ;
2023-01-16 09:45:34 +01:00
SDLTest_AssertCheck ( stream ! = NULL , " Verify stream value; expected: != NULL, got: %p " , ( void * ) stream ) ;
if ( stream = = NULL ) {
2022-11-30 12:51:59 -08:00
SDLTest_LogError ( " %s " , SDL_GetError ( ) ) ;
} else {
2023-01-16 09:45:34 +01:00
Uint8 * dst_buf = NULL , * src_buf = NULL ;
int dst_len = 0 , src_len = 0 , real_dst_len = 0 ;
int l = 64 ;
int src_samplesize , dst_samplesize ;
src_samplesize = ( SDL_AUDIO_BITSIZE ( spec1 . format ) / 8 ) * spec1 . channels ;
dst_samplesize = ( SDL_AUDIO_BITSIZE ( spec2 . format ) / 8 ) * spec2 . channels ;
/* Create some random data to convert */
src_len = l * src_samplesize ;
SDLTest_Log ( " Creating dummy sample buffer of %i length (%i bytes) " , l , src_len ) ;
src_buf = ( Uint8 * ) SDL_malloc ( src_len ) ;
SDLTest_AssertCheck ( dst_buf ! = NULL , " Check src data buffer to convert is not NULL " ) ;
if ( src_buf = = NULL ) {
2022-11-30 12:51:59 -08:00
return TEST_ABORTED ;
}
2023-01-16 09:45:34 +01:00
src_len = src_len & ~ ( src_samplesize - 1 ) ;
dst_len = dst_samplesize * ( src_len / src_samplesize ) ;
if ( spec1 . freq < spec2 . freq ) {
const double mult = ( ( double ) spec2 . freq ) / ( ( double ) spec1 . freq ) ;
dst_len * = ( int ) SDL_ceil ( mult ) ;
}
dst_len = dst_len & ~ ( dst_samplesize - 1 ) ;
dst_buf = ( Uint8 * ) SDL_calloc ( 1 , dst_len ) ;
SDLTest_AssertCheck ( dst_buf ! = NULL , " Check dst data buffer to convert is not NULL " ) ;
if ( dst_buf = = NULL ) {
return TEST_ABORTED ;
}
/* Run the audio converter */
if ( SDL_PutAudioStreamData ( stream , src_buf , src_len ) < 0 | |
SDL_FlushAudioStream ( stream ) < 0 ) {
2022-11-30 12:51:59 -08:00
return TEST_ABORTED ;
}
2023-01-16 09:45:34 +01:00
real_dst_len = SDL_GetAudioStreamData ( stream , dst_buf , dst_len ) ;
SDLTest_AssertCheck ( real_dst_len > 0 , " Verify result value; expected: > 0; got: %i " , real_dst_len ) ;
if ( real_dst_len < 0 ) {
return TEST_ABORTED ;
}
2022-11-30 12:51:59 -08:00
2023-01-16 09:45:34 +01:00
SDL_DestroyAudioStream ( stream ) ;
2022-11-30 12:51:59 -08:00
/* Free converted buffer */
2023-01-16 09:45:34 +01:00
SDL_free ( src_buf ) ;
SDL_free ( dst_buf ) ;
2022-11-30 12:51:59 -08:00
}
}
2022-11-27 17:38:43 +01:00
}
2015-06-21 17:33:46 +02:00
}
}
2022-11-30 12:51:59 -08:00
return TEST_COMPLETED ;
2015-06-21 17:33:46 +02:00
}
/**
* \ brief Opens , checks current connected status , and closes a device .
*
2023-02-02 00:21:53 +01:00
* \ sa SDL_AudioDeviceConnected
2015-06-21 17:33:46 +02:00
*/
2023-01-16 09:45:34 +01:00
static int audio_openCloseAudioDeviceConnected ( void * arg )
2015-06-21 17:33:46 +02:00
{
2022-11-30 12:51:59 -08:00
int result = - 1 ;
int i ;
int count ;
const char * device ;
SDL_AudioDeviceID id ;
SDL_AudioSpec desired , obtained ;
/* Get number of devices. */
count = SDL_GetNumAudioDevices ( 0 ) ;
SDLTest_AssertPass ( " Call to SDL_GetNumAudioDevices(0) " ) ;
if ( count > 0 ) {
for ( i = 0 ; i < count ; i + + ) {
/* Get device name */
device = SDL_GetAudioDeviceName ( i , 0 ) ;
SDLTest_AssertPass ( " SDL_GetAudioDeviceName(%i,0) " , i ) ;
SDLTest_AssertCheck ( device ! = NULL , " Validate device name is not NULL; got: %s " , ( device ! = NULL ) ? device : " NULL " ) ;
if ( device = = NULL ) {
return TEST_ABORTED ;
}
/* Set standard desired spec */
desired . freq = 22050 ;
desired . format = AUDIO_S16SYS ;
desired . channels = 2 ;
desired . samples = 4096 ;
2022-12-29 22:58:16 +01:00
desired . callback = audio_testCallback ;
2022-11-30 12:51:59 -08:00
desired . userdata = NULL ;
/* Open device */
id = SDL_OpenAudioDevice ( device , 0 , & desired , & obtained , SDL_AUDIO_ALLOW_ANY_CHANGE ) ;
SDLTest_AssertPass ( " SDL_OpenAudioDevice('%s',...) " , device ) ;
2023-01-05 09:57:14 +01:00
SDLTest_AssertCheck ( id > 0 , " Validate device ID; expected: > 0, got: % " SDL_PRIu32 , id ) ;
if ( id > 0 ) {
2022-11-30 12:51:59 -08:00
/* TODO: enable test code when function is available in SDL3 */
2015-06-21 17:33:46 +02:00
# ifdef AUDIODEVICECONNECTED_DEFINED
2022-11-30 12:51:59 -08:00
/* Get connected status */
result = SDL_AudioDeviceConnected ( id ) ;
SDLTest_AssertPass ( " Call to SDL_AudioDeviceConnected() " ) ;
2015-06-21 17:33:46 +02:00
# endif
2022-11-30 12:51:59 -08:00
SDLTest_AssertCheck ( result = = 1 , " Verify returned value; expected: 1; got: %i " , result ) ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
/* Close device again */
SDL_CloseAudioDevice ( id ) ;
SDLTest_AssertPass ( " Call to SDL_CloseAudioDevice() " ) ;
}
}
} else {
SDLTest_Log ( " No devices to test with " ) ;
}
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
return TEST_COMPLETED ;
}
2015-06-21 17:33:46 +02:00
/* ================= Test Case References ================== */
/* Audio test cases */
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest1 = {
2023-01-16 09:45:34 +01:00
audio_enumerateAndNameAudioDevices , " audio_enumerateAndNameAudioDevices " , " Enumerate and name available audio devices (output and capture) " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest2 = {
2023-01-16 09:45:34 +01:00
audio_enumerateAndNameAudioDevicesNegativeTests , " audio_enumerateAndNameAudioDevicesNegativeTests " , " Negative tests around enumeration and naming of audio devices. " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest3 = {
2023-01-16 09:45:34 +01:00
audio_printAudioDrivers , " audio_printAudioDrivers " , " Checks available audio driver names. " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest4 = {
2023-01-16 09:45:34 +01:00
audio_printCurrentAudioDriver , " audio_printCurrentAudioDriver " , " Checks current audio driver name with initialized audio. " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest5 = {
2023-01-16 09:45:34 +01:00
audio_buildAudioStream , " audio_buildAudioStream " , " Builds various audio conversion structures. " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest6 = {
2023-01-16 09:45:34 +01:00
audio_buildAudioStreamNegative , " audio_buildAudioStreamNegative " , " Checks calls with invalid input to SDL_CreateAudioStream " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest7 = {
2023-01-16 09:45:34 +01:00
audio_getAudioStatus , " audio_getAudioStatus " , " Checks current audio status. " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest8 = {
2023-01-16 09:45:34 +01:00
audio_openCloseAndGetAudioStatus , " audio_openCloseAndGetAudioStatus " , " Opens and closes audio device and get audio status. " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest9 = {
2023-01-16 09:45:34 +01:00
audio_lockUnlockOpenAudioDevice , " audio_lockUnlockOpenAudioDevice " , " Locks and unlocks an open audio device. " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2023-01-16 09:45:34 +01:00
/* TODO: enable test when SDL_ConvertAudio segfaults on cygwin have been fixed.
* TODO : re - check , since this was changer to AudioStream */
2015-06-21 17:33:46 +02:00
/* For debugging, test case can be run manually using --filter audio_convertAudio */
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest10 = {
2023-01-16 09:45:34 +01:00
audio_convertAudio , " audio_convertAudio " , " Convert audio using available formats. " , TEST_DISABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
/* TODO: enable test when SDL_AudioDeviceConnected has been implemented. */
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest11 = {
2023-01-16 09:45:34 +01:00
audio_openCloseAudioDeviceConnected , " audio_openCloseAudioDeviceConnected " , " Opens and closes audio device and get connected status. " , TEST_DISABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest12 = {
2023-01-16 09:45:34 +01:00
audio_quitInitAudioSubSystem , " audio_quitInitAudioSubSystem " , " Quit and re-init audio subsystem. " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest13 = {
2023-01-16 09:45:34 +01:00
audio_initQuitAudio , " audio_initQuitAudio " , " Init and quit audio drivers directly. " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest14 = {
2023-01-16 09:45:34 +01:00
audio_initOpenCloseQuitAudio , " audio_initOpenCloseQuitAudio " , " Cycle through init, open, close and quit with various audio specs. " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference audioTest15 = {
2023-01-16 09:45:34 +01:00
audio_pauseUnpauseAudio , " audio_pauseUnpauseAudio " , " Pause and Unpause audio for various audio specs while testing callback. " , TEST_ENABLED
2022-11-30 12:51:59 -08:00
} ;
2015-06-21 17:33:46 +02:00
/* Sequence of Audio test cases */
2022-11-30 12:51:59 -08:00
static const SDLTest_TestCaseReference * audioTests [ ] = {
2015-06-21 17:33:46 +02:00
& audioTest1 , & audioTest2 , & audioTest3 , & audioTest4 , & audioTest5 , & audioTest6 ,
& audioTest7 , & audioTest8 , & audioTest9 , & audioTest10 , & audioTest11 ,
& audioTest12 , & audioTest13 , & audioTest14 , & audioTest15 , NULL
} ;
/* Audio test suite (global) */
SDLTest_TestSuiteReference audioTestSuite = {
" Audio " ,
2022-12-29 22:58:16 +01:00
audioSetUp ,
2015-06-21 17:33:46 +02:00
audioTests ,
2022-12-29 22:58:16 +01:00
audioTearDown
2015-06-21 17:33:46 +02:00
} ;