summaryrefslogtreecommitdiff
path: root/tests/teststops.cpp
diff options
context:
space:
mode:
authorStephen Sinclair <radarsat1@gmail.com>2020-06-05 10:12:21 +0200
committerStephen Sinclair <radarsat1@gmail.com>2020-06-05 10:21:10 +0200
commit7b534671b90286f0557bb8851d1454c0fd60b760 (patch)
tree92c3acae274d12927d922dfde0c05ec27e1d2c60 /tests/teststops.cpp
parentf65e492350127c2b7019bacd5cd642105f7bafd7 (diff)
Update C API and several backend APIs for no-exceptions branch.
Diffstat (limited to 'tests/teststops.cpp')
-rw-r--r--tests/teststops.cpp554
1 files changed, 283 insertions, 271 deletions
diff --git a/tests/teststops.cpp b/tests/teststops.cpp
index 0b85b48..9018f54 100644
--- a/tests/teststops.cpp
+++ b/tests/teststops.cpp
@@ -1,271 +1,283 @@
-/******************************************/
-/*
- teststop.cpp
- by Gary P. Scavone, 2011
-
- This program starts and stops an RtAudio
- stream many times in succession and in
- different ways to to test its functionality.
-*/
-/******************************************/
-
-#include "RtAudio.h"
-#include <iostream>
-#include <cstdlib>
-#include <cstring>
-#include <cstdio>
-
-#define PULSE_RATE 0.01 // seconds
-#define RUNTIME 0.4 // seconds
-#define PAUSETIME 0.1 // seconds
-#define REPETITIONS 10
-
-// Platform-dependent sleep routines.
-#if defined( WIN32 )
- #include <windows.h>
- #define SLEEP( milliseconds ) Sleep( (DWORD) milliseconds )
-#else // Unix variants
- #include <unistd.h>
- #define SLEEP( milliseconds ) usleep( (unsigned long) (milliseconds * 1000.0) )
-#endif
-
-void usage( void ) {
- // Error function in case of incorrect command-line
- // argument specifications
- std::cout << "\nuseage: teststops N fs <iDevice> <oDevice> <iChannelOffset> <oChannelOffset>\n";
- std::cout << " where N = number of channels,\n";
- std::cout << " fs = the sample rate,\n";
- std::cout << " iDevice = optional input device to use (default = 0),\n";
- std::cout << " oDevice = optional output device to use (default = 0),\n";
- std::cout << " iChannelOffset = an optional input channel offset (default = 0),\n";
- std::cout << " and oChannelOffset = optional output channel offset (default = 0).\n\n";
- exit( 0 );
-}
-
-struct MyData {
- unsigned int channels;
- unsigned int pulseCount;
- unsigned int frameCounter;
- unsigned int nFrames;
- unsigned int returnValue;
-};
-
-// Interleaved buffers
-int pulse( void *outputBuffer, void * /*inputBuffer*/, unsigned int nBufferFrames,
- double /*streamTime*/, RtAudioStreamStatus status, void *mydata )
-{
- // Write out a pulse signal and ignore the input buffer.
- unsigned int i, j;
- float sample;
- float *buffer = (float *) outputBuffer;
- MyData *data = (MyData *) mydata;
-
- if ( status ) std::cout << "Stream over/underflow detected!" << std::endl;
-
- for ( i=0; i<nBufferFrames; i++ ) {
- if ( data->frameCounter % data->pulseCount == 0 ) sample = 0.9f;
- else sample = 0.0;
- for ( j=0; j<data->channels; j++ )
- *buffer++ = sample;
-
- data->frameCounter++;
- }
-
- if ( data->frameCounter >= data->nFrames )
- return data->returnValue;
- else
- return 0;
-}
-
-int main( int argc, char *argv[] )
-{
- unsigned int bufferFrames, fs, oDevice = 0, iDevice = 0, iOffset = 0, oOffset = 0;
- unsigned int runtime, pausetime;
- char input;
-
- // minimal command-line checking
- if (argc < 3 || argc > 7 ) usage();
-
- RtAudio *adc = new RtAudio();
- if ( adc->getDeviceCount() < 1 ) {
- std::cout << "\nNo audio devices found!\n";
- exit( 1 );
- }
-
- MyData mydata;
- mydata.channels = (unsigned int) atoi( argv[1] );
- fs = (unsigned int) atoi( argv[2] );
- if ( argc > 3 )
- iDevice = (unsigned int) atoi( argv[3] );
- if ( argc > 4 )
- oDevice = (unsigned int) atoi(argv[4]);
- if ( argc > 5 )
- iOffset = (unsigned int) atoi(argv[5]);
- if ( argc > 6 )
- oOffset = (unsigned int) atoi(argv[6]);
-
- // Let RtAudio print messages to stderr.
- adc->showWarnings( true );
-
- runtime = static_cast<unsigned int>(RUNTIME * 1000);
- pausetime = static_cast<unsigned int>(PAUSETIME * 1000);
-
- // Set our stream parameters for a duplex stream.
- bufferFrames = 512;
- RtAudio::StreamParameters oParams, iParams;
- oParams.deviceId = oDevice;
- oParams.nChannels = mydata.channels;
- oParams.firstChannel = oOffset;
-
- iParams.deviceId = iDevice;
- iParams.nChannels = mydata.channels;
- iParams.firstChannel = iOffset;
-
- if ( iDevice == 0 )
- iParams.deviceId = adc->getDefaultInputDevice();
- if ( oDevice == 0 )
- oParams.deviceId = adc->getDefaultOutputDevice();
-
- // First, test external stopStream() calls.
- mydata.pulseCount = static_cast<unsigned int>(PULSE_RATE * fs);
- mydata.nFrames = 50 * fs;
- mydata.returnValue = 0;
- try {
- adc->openStream( &oParams, &iParams, RTAUDIO_SINT32, fs, &bufferFrames, &pulse, (void *)&mydata );
-
- std::cout << "Press <enter> to start test.\n";
- std::cin.get( input );
-
- for (int i=0; i<REPETITIONS; i++ ) {
- mydata.frameCounter = 0;
- adc->startStream();
- std::cout << "Stream started ... ";
- SLEEP( runtime );
- adc->stopStream();
- std::cout << "stream externally stopped.\n";
- SLEEP( pausetime );
- }
- }
- catch ( RtAudioError& e ) {
- e.printMessage();
- goto cleanup;
- }
-
- adc->closeStream();
-
- // Next, test internal stopStream() calls.
- mydata.nFrames = (unsigned int) (RUNTIME * fs);
- mydata.returnValue = 1;
- try {
- adc->openStream( &oParams, &iParams, RTAUDIO_SINT32, fs, &bufferFrames, &pulse, (void *)&mydata );
-
- std::cin.clear();
- fflush(stdin);
- std::cout << "\nPress <enter> to continue test.\n";
- std::cin.get( input );
-
- for (int i=0; i<REPETITIONS; i++ ) {
- mydata.frameCounter = 0;
- adc->startStream();
- std::cout << "Stream started ... ";
- while ( adc->isStreamRunning() ) SLEEP( 5 );
- std::cout << "stream stopped via callback return value = 1.\n";
- SLEEP( pausetime );
- }
- }
- catch ( RtAudioError& e ) {
- e.printMessage();
- goto cleanup;
- }
-
- adc->closeStream();
-
- // Test internal abortStream() calls.
- mydata.returnValue = 2;
- try {
- adc->openStream( &oParams, &iParams, RTAUDIO_SINT32, fs, &bufferFrames, &pulse, (void *)&mydata );
- std::cin.clear();
- fflush(stdin);
- std::cout << "\nPress <enter> to continue test.\n";
- std::cin.get( input );
-
- for (int i=0; i<REPETITIONS; i++ ) {
- mydata.frameCounter = 0;
- adc->startStream();
- std::cout << "Stream started ... ";
- while ( adc->isStreamRunning() ) SLEEP( 5 );
- std::cout << "stream aborted via callback return value = 2.\n";
- SLEEP( pausetime );
- }
- }
- catch ( RtAudioError& e ) {
- e.printMessage();
- goto cleanup;
- }
-
- adc->closeStream();
-
- // Test consecutive stream re-opening.
- mydata.returnValue = 0;
- mydata.nFrames = 50 * fs;
- try {
-
- std::cin.clear();
- fflush(stdin);
- std::cout << "\nPress <enter> to continue test.\n";
- std::cin.get( input );
-
- for (int i=0; i<REPETITIONS; i++ ) {
- adc->openStream( &oParams, &iParams, RTAUDIO_SINT32, fs, &bufferFrames, &pulse, (void *)&mydata );
- mydata.frameCounter = 0;
- adc->startStream();
- std::cout << "New stream started ... ";
- SLEEP( runtime );
- adc->stopStream();
- adc->closeStream();
- std::cout << "stream stopped externally and closed.\n";
- SLEEP( pausetime );
- }
- }
- catch ( RtAudioError& e ) {
- e.printMessage();
- goto cleanup;
- }
-
- delete adc;
- adc = 0;
-
- // Test consecutive RtAudio creating and deletion.
- try {
-
- std::cin.clear();
- fflush(stdin);
- std::cout << "\nPress <enter> to continue test.\n";
- std::cin.get( input );
-
- for (int i=0; i<REPETITIONS; i++ ) {
- adc = new RtAudio();
- adc->openStream( &oParams, &iParams, RTAUDIO_SINT32, fs, &bufferFrames, &pulse, (void *)&mydata );
- mydata.frameCounter = 0;
- adc->startStream();
- std::cout << "New instance and stream started ... ";
- SLEEP( runtime );
- adc->stopStream();
- adc->closeStream();
- delete adc;
- adc = 0;
- std::cout << "stream stopped and instance deleted.\n";
- SLEEP( pausetime );
- }
- }
- catch ( RtAudioError& e ) {
- e.printMessage();
- goto cleanup;
- }
-
- cleanup:
- if ( adc && adc->isStreamOpen() ) adc->closeStream();
- if ( adc ) delete adc;
-
- return 0;
-}
+/******************************************/
+/*
+ teststop.cpp
+ by Gary P. Scavone, 2011
+
+ This program starts and stops an RtAudio
+ stream many times in succession and in
+ different ways to to test its functionality.
+*/
+/******************************************/
+
+#include "RtAudio.h"
+#include <iostream>
+#include <cstdlib>
+#include <cstring>
+#include <cstdio>
+
+#define PULSE_RATE 0.01 // seconds
+#define RUNTIME 0.4 // seconds
+#define PAUSETIME 0.1 // seconds
+#define REPETITIONS 10
+
+// Platform-dependent sleep routines.
+#if defined( WIN32 )
+ #include <windows.h>
+ #define SLEEP( milliseconds ) Sleep( (DWORD) milliseconds )
+#else // Unix variants
+ #include <unistd.h>
+ #define SLEEP( milliseconds ) usleep( (unsigned long) (milliseconds * 1000.0) )
+#endif
+
+void usage( void ) {
+ // Error function in case of incorrect command-line
+ // argument specifications
+ std::cout << "\nuseage: teststops N fs <iDevice> <oDevice> <iChannelOffset> <oChannelOffset>\n";
+ std::cout << " where N = number of channels,\n";
+ std::cout << " fs = the sample rate,\n";
+ std::cout << " iDevice = optional input device to use (default = 0),\n";
+ std::cout << " oDevice = optional output device to use (default = 0),\n";
+ std::cout << " iChannelOffset = an optional input channel offset (default = 0),\n";
+ std::cout << " and oChannelOffset = optional output channel offset (default = 0).\n\n";
+ exit( 0 );
+}
+
+struct MyData {
+ unsigned int channels;
+ unsigned int pulseCount;
+ unsigned int frameCounter;
+ unsigned int nFrames;
+ unsigned int returnValue;
+};
+
+// Interleaved buffers
+int pulse( void *outputBuffer, void * /*inputBuffer*/, unsigned int nBufferFrames,
+ double /*streamTime*/, RtAudioStreamStatus status, void *mydata )
+{
+ // Write out a pulse signal and ignore the input buffer.
+ unsigned int i, j;
+ float sample;
+ float *buffer = (float *) outputBuffer;
+ MyData *data = (MyData *) mydata;
+
+ if ( status ) std::cout << "Stream over/underflow detected!" << std::endl;
+
+ for ( i=0; i<nBufferFrames; i++ ) {
+ if ( data->frameCounter % data->pulseCount == 0 ) sample = 0.9f;
+ else sample = 0.0;
+ for ( j=0; j<data->channels; j++ )
+ *buffer++ = sample;
+
+ data->frameCounter++;
+ }
+
+ if ( data->frameCounter >= data->nFrames )
+ return data->returnValue;
+ else
+ return 0;
+}
+
+int main( int argc, char *argv[] )
+{
+ unsigned int bufferFrames, fs, oDevice = 0, iDevice = 0, iOffset = 0, oOffset = 0;
+ unsigned int runtime, pausetime;
+ char input;
+
+ // minimal command-line checking
+ if (argc < 3 || argc > 7 ) usage();
+
+ RtAudio *adc = new RtAudio();
+ if ( adc->getDeviceCount() < 1 ) {
+ std::cout << "\nNo audio devices found!\n";
+ exit( 1 );
+ }
+
+ MyData mydata;
+ mydata.channels = (unsigned int) atoi( argv[1] );
+ fs = (unsigned int) atoi( argv[2] );
+ if ( argc > 3 )
+ iDevice = (unsigned int) atoi( argv[3] );
+ if ( argc > 4 )
+ oDevice = (unsigned int) atoi(argv[4]);
+ if ( argc > 5 )
+ iOffset = (unsigned int) atoi(argv[5]);
+ if ( argc > 6 )
+ oOffset = (unsigned int) atoi(argv[6]);
+
+ // Let RtAudio print messages to stderr.
+ adc->showWarnings( true );
+
+ runtime = static_cast<unsigned int>(RUNTIME * 1000);
+ pausetime = static_cast<unsigned int>(PAUSETIME * 1000);
+
+ // Set our stream parameters for a duplex stream.
+ bufferFrames = 512;
+ RtAudio::StreamParameters oParams, iParams;
+ oParams.deviceId = oDevice;
+ oParams.nChannels = mydata.channels;
+ oParams.firstChannel = oOffset;
+
+ iParams.deviceId = iDevice;
+ iParams.nChannels = mydata.channels;
+ iParams.firstChannel = iOffset;
+
+ if ( iDevice == 0 )
+ iParams.deviceId = adc->getDefaultInputDevice();
+ if ( oDevice == 0 )
+ oParams.deviceId = adc->getDefaultOutputDevice();
+
+ // First, test external stopStream() calls.
+ mydata.pulseCount = static_cast<unsigned int>(PULSE_RATE * fs);
+ mydata.nFrames = 50 * fs;
+ mydata.returnValue = 0;
+
+ if ( adc->openStream( &oParams, &iParams, RTAUDIO_SINT32, fs, &bufferFrames, &pulse, (void *)&mydata ) ) {
+ std::cout << "Error during openStream (test external stopStream)\n";
+ goto next2;
+ }
+
+ std::cout << "Press <enter> to start test.\n";
+ std::cin.get( input );
+
+ for (int i=0; i<REPETITIONS; i++ ) {
+ mydata.frameCounter = 0;
+ if ( adc->startStream() ) {
+ std::cout << "Error during startSream (test external stopStream)\n";
+ goto next1;
+ }
+ std::cout << "Stream started ... ";
+ SLEEP( runtime );
+ adc->stopStream();
+ std::cout << "stream externally stopped.\n";
+ SLEEP( pausetime );
+ }
+
+next1:
+ adc->closeStream();
+next2:
+
+ // Next, test internal stopStream() calls.
+ mydata.nFrames = (unsigned int) (RUNTIME * fs);
+ mydata.returnValue = 1;
+
+ if ( adc->openStream( &oParams, &iParams, RTAUDIO_SINT32, fs, &bufferFrames, &pulse, (void *)&mydata ) ) {
+ std::cout << "Error during openStream (test internal stopStream)\n";
+ goto next4;
+ }
+
+ std::cin.clear();
+ fflush(stdin);
+ std::cout << "\nPress <enter> to continue test.\n";
+ std::cin.get( input );
+
+ for (int i=0; i<REPETITIONS; i++ ) {
+ mydata.frameCounter = 0;
+ if ( adc->startStream() ) {
+ std::cout << "Error during startSream (test internal stopStream)\n";
+ goto next3;
+ }
+ std::cout << "Stream started ... ";
+ while ( adc->isStreamRunning() ) SLEEP( 5 );
+ std::cout << "stream stopped via callback return value = 1.\n";
+ SLEEP( pausetime );
+ }
+
+next3:
+ adc->closeStream();
+next4:
+
+ // Test internal abortStream() calls.
+ mydata.returnValue = 2;
+
+ if ( adc->openStream( &oParams, &iParams, RTAUDIO_SINT32, fs, &bufferFrames, &pulse, (void *)&mydata ) ) {
+ std::cout << "Error during openSream (test internal abortStream)\n";
+ goto next6;
+ }
+
+ std::cin.clear();
+ fflush(stdin);
+ std::cout << "\nPress <enter> to continue test.\n";
+ std::cin.get( input );
+
+ for (int i=0; i<REPETITIONS; i++ ) {
+ mydata.frameCounter = 0;
+ if ( adc->startStream() ) {
+ std::cout << "Error during startSream (test internal abortStream)\n";
+ goto next5;
+ }
+ std::cout << "Stream started ... ";
+ while ( adc->isStreamRunning() ) SLEEP( 5 );
+ std::cout << "stream aborted via callback return value = 2.\n";
+ SLEEP( pausetime );
+ }
+
+next5:
+ adc->closeStream();
+next6:
+
+ // Test consecutive stream re-opening.
+ mydata.returnValue = 0;
+ mydata.nFrames = 50 * fs;
+
+ std::cin.clear();
+ fflush(stdin);
+ std::cout << "\nPress <enter> to continue test.\n";
+ std::cin.get( input );
+
+ for (int i=0; i<REPETITIONS; i++ ) {
+ if ( adc->openStream( &oParams, &iParams, RTAUDIO_SINT32, fs, &bufferFrames, &pulse, (void *)&mydata ) ) {
+ std::cout << "Error during openStream (test consecutive re-opening)\n";
+ goto next7;
+ }
+
+ mydata.frameCounter = 0;
+ if ( adc->startStream() ) {
+ std::cout << "Error during startStream (test consecutive re-opening)\n";
+ goto next7;
+ }
+ std::cout << "New stream started ... ";
+ SLEEP( runtime );
+ adc->stopStream();
+ adc->closeStream();
+ std::cout << "stream stopped externally and closed.\n";
+ SLEEP( pausetime );
+ }
+
+next7:
+ delete adc;
+ adc = 0;
+
+ // Test consecutive RtAudio creating and deletion.
+ std::cin.clear();
+ fflush(stdin);
+ std::cout << "\nPress <enter> to continue test.\n";
+ std::cin.get( input );
+
+ for (int i=0; i<REPETITIONS; i++ ) {
+ adc = new RtAudio();
+ if ( adc->openStream( &oParams, &iParams, RTAUDIO_SINT32, fs, &bufferFrames, &pulse, (void *)&mydata ) ) {
+ printf("Error during openStream (test consecutive creation and deletion)\n");
+ goto cleanup;
+ }
+
+ mydata.frameCounter = 0;
+ if ( adc->startStream() ) {
+ std::cout << "Error during startStream (test consecutive creation and deletion)\n";
+ goto cleanup;
+ }
+ std::cout << "New instance and stream started ... ";
+ SLEEP( runtime );
+ adc->stopStream();
+ adc->closeStream();
+ delete adc;
+ adc = 0;
+ std::cout << "stream stopped and instance deleted.\n";
+ SLEEP( pausetime );
+ }
+
+ cleanup:
+ if ( adc && adc->isStreamOpen() ) adc->closeStream();
+ if ( adc ) delete adc;
+
+ return 0;
+}