/*
* 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;
}