/* * Copyright (C) 2017 Reece H. Dunn * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write see: * . */ #include "config.h" #include "test_assert.h" #include #include #include #include #include #include "speech.h" #include "phoneme.h" #include "voice.h" #include "synthesize.h" #include "translate.h" // region espeak_Initialize static void test_espeak_terminate_without_initialize() { printf("testing espeak_Terminate without espeak_Initialize\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } static void test_espeak_initialize() { printf("testing espeak_Initialize\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_PLAYBACK, 0, NULL, 0) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } // endregion // region espeak_Synth static void test_espeak_synth() { printf("testing espeak_Synth\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, NULL, 0) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; TEST_ASSERT(espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == EE_OK); #if !USE_ASYNC TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); #endif TEST_ASSERT(espeak_Synchronize() == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } static void test_espeak_synth_no_voices(const char *path) { printf("testing espeak_Synth in path with no voices\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, path, espeakINITIALIZE_DONT_EXIT) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; int res = espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL); #if USE_ASYNC TEST_ASSERT(res == EE_OK); #else TEST_ASSERT(res == EE_NOT_FOUND); #endif TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Synchronize() == EE_OK); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } // endregion // region espeak_ng_Synthesize static void test_espeak_ng_synthesize() { printf("testing espeak_ng_Synthesize\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, NULL, 0) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; TEST_ASSERT(espeak_ng_Synthesize(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == ENS_OK); #if !USE_ASYNC TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); #endif TEST_ASSERT(espeak_Synchronize() == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } static void test_espeak_ng_synthesize_no_voices(const char *path) { printf("testing espeak_ng_Synthesize in path with no voices\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, path, espeakINITIALIZE_DONT_EXIT) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; int res = espeak_ng_Synthesize(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL); #if USE_ASYNC TEST_ASSERT(res == EE_OK); #else TEST_ASSERT(res == ENS_VOICE_NOT_FOUND); #endif TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_ng_Synchronize() == ENS_OK); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } // endregion // region espeak_SetVoiceByName static void test_espeak_set_voice_by_name_null_voice() { printf("testing espeak_SetVoiceByName(NULL)\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, NULL, 0) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_SetVoiceByName("") == EE_NOT_FOUND); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; TEST_ASSERT(espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == EE_OK); #if !USE_ASYNC TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); #endif TEST_ASSERT(espeak_Synchronize() == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } static void test_espeak_set_voice_by_name_blank_voice() { printf("testing espeak_SetVoiceByName(\"\")\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, NULL, 0) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_SetVoiceByName("") == EE_NOT_FOUND); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; TEST_ASSERT(espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == EE_OK); #if !USE_ASYNC TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); #endif TEST_ASSERT(espeak_Synchronize() == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } static void test_espeak_set_voice_by_name_valid_voice() { printf("testing espeak_SetVoiceByName(\"de\")\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, NULL, 0) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_SetVoiceByName("de") == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "de") == 0); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; TEST_ASSERT(espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == EE_OK); #if !USE_ASYNC TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "de") == 0); TEST_ASSERT(p_decoder != NULL); #endif TEST_ASSERT(espeak_Synchronize() == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "de") == 0); TEST_ASSERT(p_decoder != NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } static void test_espeak_set_voice_by_name_invalid_voice() { printf("testing espeak_SetVoiceByName(\"zzz\")\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, NULL, 0) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_SetVoiceByName("zzz") == EE_NOT_FOUND); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; TEST_ASSERT(espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == EE_OK); #if !USE_ASYNC TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); #endif TEST_ASSERT(espeak_Synchronize() == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } static void test_espeak_set_voice_by_name_language_variant_intonation_parameter() { printf("testing espeak_SetVoiceByName(\"!v/Annie\") (language variant; intonation)\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, NULL, 0) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_SetVoiceByName("!v/Annie") == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; TEST_ASSERT(espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == EE_OK); #if !USE_ASYNC TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); #endif TEST_ASSERT(espeak_Synchronize() == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } // endregion // region espeak_SetVoiceByProperties static void test_espeak_set_voice_by_properties_empty() { printf("testing espeak_SetVoiceByProperties: (none)\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, NULL, 0) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); espeak_VOICE properties; memset(&properties, 0, sizeof(properties)); TEST_ASSERT(espeak_SetVoiceByProperties(&properties) == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; TEST_ASSERT(espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == EE_OK); #if !USE_ASYNC TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); #endif TEST_ASSERT(espeak_Synchronize() == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } static void test_espeak_set_voice_by_properties_blank_language() { printf("testing espeak_SetVoiceByProperties: languages=\"\"\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, NULL, 0) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); espeak_VOICE properties; memset(&properties, 0, sizeof(properties)); properties.languages = ""; TEST_ASSERT(espeak_SetVoiceByProperties(&properties) == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; TEST_ASSERT(espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == EE_OK); #if !USE_ASYNC TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); #endif TEST_ASSERT(espeak_Synchronize() == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } static void test_espeak_set_voice_by_properties_with_valid_language() { printf("testing espeak_SetVoiceByProperties: languages=\"mk\" (valid)\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, NULL, 0) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); espeak_VOICE properties; memset(&properties, 0, sizeof(properties)); properties.languages = "mk"; TEST_ASSERT(espeak_SetVoiceByProperties(&properties) == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "mk") == 0); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; TEST_ASSERT(espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == EE_OK); #if !USE_ASYNC TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "mk") == 0); TEST_ASSERT(p_decoder != NULL); #endif TEST_ASSERT(espeak_Synchronize() == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "mk") == 0); TEST_ASSERT(p_decoder != NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } static void test_espeak_set_voice_by_properties_with_invalid_language() { printf("testing espeak_SetVoiceByProperties: languages=\"zzz\" (invalid)\n"); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); TEST_ASSERT(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, NULL, 0) == 22050); TEST_ASSERT(event_list != NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); espeak_VOICE properties; memset(&properties, 0, sizeof(properties)); properties.languages = "zzz"; TEST_ASSERT(espeak_SetVoiceByProperties(&properties) == EE_NOT_FOUND); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); const char *test = "One two three."; TEST_ASSERT(espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == EE_OK); #if !USE_ASYNC TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); #endif TEST_ASSERT(espeak_Synchronize() == EE_OK); TEST_ASSERT(translator != NULL); TEST_ASSERT(strcmp(translator->dictionary_name, "en") == 0); TEST_ASSERT(p_decoder != NULL); TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } static int _test_espeak_ng_phoneme_events_cb(short *samples, int num_samples, espeak_EVENT *events) { char *out = events->user_data; size_t offset; (void) samples; (void) num_samples; for (espeak_EVENT *e = events; e->type != 0; e++) { if (e->type == espeakEVENT_PHONEME) { if (out[0] == 0) offset = 0; else { offset = strlen(out); out[offset++] = ' '; } strncpy(out + offset, e->id.string, sizeof(e->id.string)); } } return 0; } static void test_espeak_ng_phoneme_events(int enabled, int ipa) { printf("testing espeak_ng_SetPhonemeEvents(enabled=%d, ipa=%d)\n", enabled, ipa); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); espeak_ng_InitializePath(NULL); espeak_ng_ERROR_CONTEXT context = NULL; TEST_ASSERT(espeak_ng_Initialize(&context) == ENS_OK); TEST_ASSERT(espeak_ng_InitializeOutput(0, 0, NULL) == ENS_OK); espeak_SetSynthCallback(_test_espeak_ng_phoneme_events_cb); TEST_ASSERT(espeak_ng_SetPhonemeEvents(enabled, ipa) == ENS_OK); char phoneme_events[256]; memset(phoneme_events, 0, sizeof(phoneme_events)); const char *test = "test"; TEST_ASSERT(espeak_ng_Synthesize(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, phoneme_events) == ENS_OK); TEST_ASSERT(espeak_ng_Synchronize() == ENS_OK); if (enabled) { if (ipa) { TEST_ASSERT(strncmp(phoneme_events, "t ɛ s t ", sizeof(phoneme_events)) == 0); } else { TEST_ASSERT(strncmp(phoneme_events, "t E s t _: _", sizeof(phoneme_events)) == 0); } } else { TEST_ASSERT(phoneme_events[0] == 0); } TEST_ASSERT(espeak_Terminate() == EE_OK); TEST_ASSERT(event_list == NULL); TEST_ASSERT(translator == NULL); TEST_ASSERT(p_decoder == NULL); } // endregion int main(int argc, char **argv) { (void)argc; // unused parameter char *progdir = strdup(argv[0]); // Path separator on windows may be both '/' and '\' char *dir; if ((dir = strrchr(progdir, PATHSEP)) != NULL) *dir = 0; else if ((dir = strrchr(progdir, '/')) != NULL) *dir = 0; test_espeak_terminate_without_initialize(); test_espeak_initialize(); test_espeak_synth(); test_espeak_synth(); // Check that this does not crash when run a second time. test_espeak_synth_no_voices(progdir); test_espeak_synth(); test_espeak_ng_synthesize(); test_espeak_ng_synthesize(); // Check that this does not crash when run a second time. test_espeak_ng_synthesize_no_voices(progdir); test_espeak_ng_synthesize(); test_espeak_set_voice_by_name_null_voice(); test_espeak_set_voice_by_name_blank_voice(); test_espeak_set_voice_by_name_valid_voice(); test_espeak_set_voice_by_name_invalid_voice(); test_espeak_set_voice_by_name_language_variant_intonation_parameter(); test_espeak_set_voice_by_properties_empty(); test_espeak_set_voice_by_properties_blank_language(); test_espeak_set_voice_by_properties_with_valid_language(); test_espeak_set_voice_by_properties_with_invalid_language(); test_espeak_ng_phoneme_events(0, 0); test_espeak_ng_phoneme_events(1, 0); test_espeak_ng_phoneme_events(1, 1); free(progdir); return EXIT_SUCCESS; }