| tests_readclause_test_LDADD = src/libespeak-ng-test.la | tests_readclause_test_LDADD = src/libespeak-ng-test.la | ||||
| tests_readclause_test_SOURCES = tests/readclause.c | tests_readclause_test_SOURCES = tests/readclause.c | ||||
| noinst_bin_PROGRAMS += tests/voices.test | |||||
| noinst_bin_PROGRAMS += tests/api.test | |||||
| tests_voices_test_LDADD = src/libespeak-ng-test.la | |||||
| tests_voices_test_CFLAGS = -Isrc/libespeak-ng ${AM_CFLAGS} | |||||
| tests_voices_test_SOURCES = tests/voices.c | |||||
| tests_api_test_CFLAGS = -Isrc/libespeak-ng ${AM_CFLAGS} | |||||
| tests_api_test_LDADD = src/libespeak-ng-test.la | |||||
| tests_api_test_SOURCES = tests/api.c | |||||
| %.check: %.test | %.check: %.test | ||||
| @echo " TEST $<" | @echo " TEST $<" | ||||
| check: tests/encoding.check \ | check: tests/encoding.check \ | ||||
| tests/tokenizer.check \ | tests/tokenizer.check \ | ||||
| tests/readclause.check \ | tests/readclause.check \ | ||||
| tests/voices.check \ | |||||
| tests/api.check \ | |||||
| tests/languages.check | tests/languages.check | ||||
| ##### phoneme data: | ##### phoneme data: |
| #include "event.h" | #include "event.h" | ||||
| unsigned char *outbuf = NULL; | unsigned char *outbuf = NULL; | ||||
| int outbuf_size = 0; | |||||
| espeak_EVENT *event_list = NULL; | espeak_EVENT *event_list = NULL; | ||||
| int event_list_ix = 0; | int event_list_ix = 0; | ||||
| out_samplerate = 0; | out_samplerate = 0; | ||||
| #ifdef HAVE_PCAUDIOLIB_AUDIO_H | #ifdef HAVE_PCAUDIOLIB_AUDIO_H | ||||
| my_audio = create_audio_device_object(device, "eSpeak", "Text-to-Speech"); | |||||
| if (my_audio == NULL) | |||||
| my_audio = create_audio_device_object(device, "eSpeak", "Text-to-Speech"); | |||||
| #endif | #endif | ||||
| // buffer_length is in mS, allocate 2 bytes per sample | // buffer_length is in mS, allocate 2 bytes per sample | ||||
| count_samples = 0; | count_samples = 0; | ||||
| if (translator == NULL) | |||||
| espeak_SetVoiceByName("default"); | |||||
| espeak_ng_STATUS status; | |||||
| if (translator == NULL) { | |||||
| status = espeak_SetVoiceByName("en"); | |||||
| if (status != ENS_OK) | |||||
| return status; | |||||
| } | |||||
| if (p_decoder == NULL) | if (p_decoder == NULL) | ||||
| p_decoder = create_text_decoder(); | p_decoder = create_text_decoder(); | ||||
| espeak_ng_STATUS status; | |||||
| status = text_decoder_decode_string_multibyte(p_decoder, text, translator->encoding, flags); | status = text_decoder_decode_string_multibyte(p_decoder, text, translator->encoding, flags); | ||||
| if (status != ENS_OK) | if (status != ENS_OK) | ||||
| return status; | return status; | ||||
| #ifdef HAVE_PCAUDIOLIB_AUDIO_H | #ifdef HAVE_PCAUDIOLIB_AUDIO_H | ||||
| audio_object_close(my_audio); | audio_object_close(my_audio); | ||||
| audio_object_destroy(my_audio); | audio_object_destroy(my_audio); | ||||
| my_audio = NULL; | |||||
| #endif | #endif | ||||
| out_samplerate = 0; | out_samplerate = 0; | ||||
| } | } | ||||
| outbuf = NULL; | outbuf = NULL; | ||||
| FreePhData(); | FreePhData(); | ||||
| FreeVoiceList(); | FreeVoiceList(); | ||||
| translator = NULL; | |||||
| if (p_decoder != NULL) { | |||||
| destroy_text_decoder(p_decoder); | |||||
| p_decoder = NULL; | |||||
| } | |||||
| return ENS_OK; | return ENS_OK; | ||||
| } | } |
| extern SPEED_FACTORS speed; | extern SPEED_FACTORS speed; | ||||
| extern long count_samples; | extern long count_samples; | ||||
| extern int outbuf_size; | |||||
| extern unsigned char *out_ptr; | extern unsigned char *out_ptr; | ||||
| extern unsigned char *out_start; | extern unsigned char *out_start; | ||||
| extern unsigned char *out_end; | extern unsigned char *out_end; |
| unsigned char *out_ptr; | unsigned char *out_ptr; | ||||
| unsigned char *out_start; | unsigned char *out_start; | ||||
| unsigned char *out_end; | unsigned char *out_end; | ||||
| int outbuf_size = 0; | |||||
| // the queue of operations passed to wavegen from sythesize | // the queue of operations passed to wavegen from sythesize | ||||
| intptr_t wcmdq[N_WCMDQ][4]; | intptr_t wcmdq[N_WCMDQ][4]; |
| /* | |||||
| * 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: | |||||
| * <http://www.gnu.org/licenses/>. | |||||
| */ | |||||
| #include "config.h" | |||||
| #include <assert.h> | |||||
| #include <stdlib.h> | |||||
| #include <string.h> | |||||
| #include <espeak-ng/espeak_ng.h> | |||||
| #include <espeak-ng/speak_lib.h> | |||||
| #include <espeak-ng/encoding.h> | |||||
| #include "speech.h" | |||||
| #include "phoneme.h" | |||||
| #include "synthesize.h" | |||||
| #include "translate.h" | |||||
| void | |||||
| test_espeak_terminate_without_initialize() | |||||
| { | |||||
| printf("testing espeak_Terminate without espeak_Initialize\n"); | |||||
| assert(event_list == NULL); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| assert(espeak_Terminate() == EE_OK); | |||||
| assert(event_list == NULL); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| } | |||||
| void | |||||
| test_espeak_initialize() | |||||
| { | |||||
| printf("testing espeak_Initialize\n"); | |||||
| assert(event_list == NULL); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| assert(espeak_Initialize(AUDIO_OUTPUT_PLAYBACK, 0, NULL, 0) == 22050); | |||||
| assert(event_list != NULL); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| assert(espeak_Terminate() == EE_OK); | |||||
| assert(event_list == NULL); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| } | |||||
| void | |||||
| test_espeak_synth() | |||||
| { | |||||
| printf("testing espeak_Synth\n"); | |||||
| assert(event_list == NULL); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| assert(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, NULL, 0) == 22050); | |||||
| assert(event_list != NULL); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| const char *test = "One two three."; | |||||
| assert(espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == EE_OK); | |||||
| assert(translator != NULL); | |||||
| assert(p_decoder != NULL); | |||||
| assert(espeak_Synchronize() == EE_OK); | |||||
| assert(translator != NULL); | |||||
| assert(p_decoder != NULL); | |||||
| assert(espeak_Terminate() == EE_OK); | |||||
| assert(event_list == NULL); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| } | |||||
| void | |||||
| test_espeak_synth_no_voices(const char *path) | |||||
| { | |||||
| printf("testing espeak_Synth in path with no voices\n"); | |||||
| assert(event_list == NULL); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| assert(espeak_Initialize(AUDIO_OUTPUT_RETRIEVAL, 0, path, espeakINITIALIZE_DONT_EXIT) == 22050); | |||||
| assert(event_list != NULL); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| const char *test = "One two three."; | |||||
| assert(espeak_Synth(test, strlen(test)+1, 0, POS_CHARACTER, 0, espeakCHARS_AUTO, NULL, NULL) == EE_INTERNAL_ERROR); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| assert(espeak_Synchronize() == EE_OK); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| assert(espeak_Terminate() == EE_OK); | |||||
| assert(event_list == NULL); | |||||
| assert(translator == NULL); | |||||
| assert(p_decoder == NULL); | |||||
| } | |||||
| int | |||||
| main(int argc, char **argv) | |||||
| { | |||||
| char *progdir = strdup(argv[0]); | |||||
| char *dir = strrchr(progdir, '/'); | |||||
| if (dir != 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(); | |||||
| free(progdir); | |||||
| return EXIT_SUCCESS; | |||||
| } |
| #include "synthesize.h" | #include "synthesize.h" | ||||
| #include "translate.h" | #include "translate.h" | ||||
| // Arguments to ReadClause. Declared here to avoid duplicating them across the | |||||
| // different test functions. | |||||
| static char source[N_TR_SOURCE+40]; // extra space for embedded command & voice change info at end | |||||
| static short charix[N_TR_SOURCE+4]; | |||||
| static int charix_top = 0; | |||||
| static int tone2; | |||||
| static char voice_change_name[40]; | |||||
| static int terminator; | |||||
| static espeak_ng_STATUS | |||||
| set_text(const char *text, const char *voicename) | |||||
| { | |||||
| espeak_ng_STATUS status = espeak_ng_SetVoiceByName(voicename); | |||||
| if (status != ENS_OK) | |||||
| return status; | |||||
| if (p_decoder == NULL) | |||||
| p_decoder = create_text_decoder(); | |||||
| return text_decoder_decode_string(p_decoder, text, -1, ESPEAKNG_ENCODING_UTF_8); | |||||
| } | |||||
| void | void | ||||
| test_latin_common() | |||||
| test_latin() | |||||
| { | { | ||||
| printf("testing Latin/Common (Latn/Zyyy) script classification\n"); | |||||
| printf("testing Latin (Latn)\n"); | |||||
| assert(clause_type_from_codepoint('a') == CLAUSE_NONE); | assert(clause_type_from_codepoint('a') == CLAUSE_NONE); | ||||
| assert(clause_type_from_codepoint('.') == CLAUSE_PERIOD); | assert(clause_type_from_codepoint('.') == CLAUSE_PERIOD); | ||||
| void | void | ||||
| test_greek() | test_greek() | ||||
| { | { | ||||
| printf("testing Greek (Grek) script classification\n"); | |||||
| printf("testing Greek (Grek)\n"); | |||||
| assert(clause_type_from_codepoint(0x037E) == CLAUSE_QUESTION); | assert(clause_type_from_codepoint(0x037E) == CLAUSE_QUESTION); | ||||
| assert(clause_type_from_codepoint(0x0387) == CLAUSE_SEMICOLON); | assert(clause_type_from_codepoint(0x0387) == CLAUSE_SEMICOLON); | ||||
| void | void | ||||
| test_armenian() | test_armenian() | ||||
| { | { | ||||
| printf("testing Armenian (Armn) script classification\n"); | |||||
| printf("testing Armenian (Armn)\n"); | |||||
| assert(clause_type_from_codepoint(0x055B) == (CLAUSE_EXCLAMATION | CLAUSE_PUNCTUATION_IN_WORD)); | assert(clause_type_from_codepoint(0x055B) == (CLAUSE_EXCLAMATION | CLAUSE_PUNCTUATION_IN_WORD)); | ||||
| assert(clause_type_from_codepoint(0x055C) == (CLAUSE_EXCLAMATION | CLAUSE_PUNCTUATION_IN_WORD)); | assert(clause_type_from_codepoint(0x055C) == (CLAUSE_EXCLAMATION | CLAUSE_PUNCTUATION_IN_WORD)); | ||||
| void | void | ||||
| test_arabic() | test_arabic() | ||||
| { | { | ||||
| printf("testing Arabic (Arab) script classification\n"); | |||||
| printf("testing Arabic (Arab)\n"); | |||||
| assert(clause_type_from_codepoint(0x060C) == CLAUSE_COMMA); | assert(clause_type_from_codepoint(0x060C) == CLAUSE_COMMA); | ||||
| assert(clause_type_from_codepoint(0x061B) == CLAUSE_SEMICOLON); | assert(clause_type_from_codepoint(0x061B) == CLAUSE_SEMICOLON); | ||||
| void | void | ||||
| test_devanagari() | test_devanagari() | ||||
| { | { | ||||
| printf("testing Devanagari (Deva) script classification\n"); | |||||
| printf("testing Devanagari (Deva)\n"); | |||||
| assert(clause_type_from_codepoint(0x0964) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | assert(clause_type_from_codepoint(0x0964) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | ||||
| } | } | ||||
| void | void | ||||
| test_tibetan() | test_tibetan() | ||||
| { | { | ||||
| printf("testing Tibetan (Tibt) script classification\n"); | |||||
| printf("testing Tibetan (Tibt)\n"); | |||||
| assert(clause_type_from_codepoint(0x0F0D) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | assert(clause_type_from_codepoint(0x0F0D) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | ||||
| assert(clause_type_from_codepoint(0x0F0E) == CLAUSE_PARAGRAPH); | assert(clause_type_from_codepoint(0x0F0E) == CLAUSE_PARAGRAPH); | ||||
| void | void | ||||
| test_sinhala() | test_sinhala() | ||||
| { | { | ||||
| printf("testing Sinhala (Sinh) script classification\n"); | |||||
| printf("testing Sinhala (Sinh)\n"); | |||||
| assert(clause_type_from_codepoint(0x0DF4) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | assert(clause_type_from_codepoint(0x0DF4) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | ||||
| } | } | ||||
| void | void | ||||
| test_georgian() | test_georgian() | ||||
| { | { | ||||
| printf("testing Georgian (Geor) script classification\n"); | |||||
| printf("testing Georgian (Geor)\n"); | |||||
| assert(clause_type_from_codepoint(0x10FB) == CLAUSE_PARAGRAPH); | assert(clause_type_from_codepoint(0x10FB) == CLAUSE_PARAGRAPH); | ||||
| } | } | ||||
| void | void | ||||
| test_ethiopic() | test_ethiopic() | ||||
| { | { | ||||
| printf("testing Ethiopic (Ethi) script classification\n"); | |||||
| printf("testing Ethiopic (Ethi)\n"); | |||||
| assert(clause_type_from_codepoint(0x1362) == CLAUSE_PERIOD); | assert(clause_type_from_codepoint(0x1362) == CLAUSE_PERIOD); | ||||
| assert(clause_type_from_codepoint(0x1363) == CLAUSE_COMMA); | assert(clause_type_from_codepoint(0x1363) == CLAUSE_COMMA); | ||||
| void | void | ||||
| test_ideographic() | test_ideographic() | ||||
| { | { | ||||
| printf("testing Ideographic (Hani) script classification\n"); | |||||
| printf("testing Ideographic (Hani)\n"); | |||||
| assert(clause_type_from_codepoint(0x3001) == (CLAUSE_COMMA | CLAUSE_OPTIONAL_SPACE_AFTER)); | assert(clause_type_from_codepoint(0x3001) == (CLAUSE_COMMA | CLAUSE_OPTIONAL_SPACE_AFTER)); | ||||
| assert(clause_type_from_codepoint(0x3002) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | assert(clause_type_from_codepoint(0x3002) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | ||||
| void | void | ||||
| test_fullwidth() | test_fullwidth() | ||||
| { | { | ||||
| printf("testing Full Width/Common (Zyyy) script classification\n"); | |||||
| printf("testing Full Width\n"); | |||||
| assert(clause_type_from_codepoint(0xFF01) == (CLAUSE_EXCLAMATION | CLAUSE_OPTIONAL_SPACE_AFTER)); | assert(clause_type_from_codepoint(0xFF01) == (CLAUSE_EXCLAMATION | CLAUSE_OPTIONAL_SPACE_AFTER)); | ||||
| assert(clause_type_from_codepoint(0xFF0C) == (CLAUSE_COMMA | CLAUSE_OPTIONAL_SPACE_AFTER)); | assert(clause_type_from_codepoint(0xFF0C) == (CLAUSE_COMMA | CLAUSE_OPTIONAL_SPACE_AFTER)); | ||||
| assert(clause_type_from_codepoint(0xFF1F) == (CLAUSE_QUESTION | CLAUSE_OPTIONAL_SPACE_AFTER)); | assert(clause_type_from_codepoint(0xFF1F) == (CLAUSE_QUESTION | CLAUSE_OPTIONAL_SPACE_AFTER)); | ||||
| } | } | ||||
| void | |||||
| test_uts51_emoji_character() | |||||
| { | |||||
| printf("testing Emoji ... UTS-51 ED-3. emoji character\n"); | |||||
| short retix[] = { | |||||
| 0, -1, -1, | |||||
| 2, -1, -1, | |||||
| 3, -1, -1, | |||||
| 4, -1, -1, -1, | |||||
| 5, -1, -1, -1, | |||||
| 6, | |||||
| 0 }; | |||||
| assert(set_text( | |||||
| "\xE2\x86\x94" // [2194] left right arrow | |||||
| "\xE2\x86\x95" // [2195] up down arrow | |||||
| "\xE2\x9B\x94" // [26D5] no entry | |||||
| "\xF0\x9F\x90\x8B" // [1F40B] whale | |||||
| "\xF0\x9F\x90\xAC", // [1F42C] dolphin | |||||
| "en") == ENS_OK); | |||||
| assert(ReadClause(translator, source, charix, &charix_top, N_TR_SOURCE, &tone2, voice_change_name) == CLAUSE_EOF); | |||||
| assert(!strcmp(source, | |||||
| "\xE2\x86\x94" // [2194] left right arrow | |||||
| "\xE2\x86\x95" // [2195] up down arrow | |||||
| "\xE2\x9B\x94" // [26D5] no entry | |||||
| "\xF0\x9F\x90\x8B" // [1F40B] whale | |||||
| "\xF0\x9F\x90\xAC" // [1F42C] dolphin | |||||
| " ")); | |||||
| assert(charix_top == (sizeof(retix)/sizeof(retix[0])) - 2); | |||||
| assert(!memcmp(charix, retix, sizeof(retix))); | |||||
| assert(tone2 == 0); | |||||
| assert(voice_change_name[0] == 0); | |||||
| } | |||||
| int | int | ||||
| main(int argc, char **argv) | main(int argc, char **argv) | ||||
| { | { | ||||
| test_latin_common(); | |||||
| assert(espeak_Initialize(AUDIO_OUTPUT_SYNCHRONOUS, 0, NULL, espeakINITIALIZE_DONT_EXIT) == 22050); | |||||
| test_latin(); | |||||
| test_greek(); | test_greek(); | ||||
| test_armenian(); | test_armenian(); | ||||
| test_arabic(); | test_arabic(); | ||||
| test_ideographic(); | test_ideographic(); | ||||
| test_fullwidth(); | test_fullwidth(); | ||||
| test_uts51_emoji_character(); | |||||
| assert(espeak_Terminate() == EE_OK); | |||||
| return EXIT_SUCCESS; | return EXIT_SUCCESS; | ||||
| } | } | ||||
| // References: | |||||
| // [UTS-51] Unicode Emoji (http://www.unicode.org/reports/tr51/tr51-12.html) 5.0-12. 2017-05-18 |
| /* | |||||
| * 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: | |||||
| * <http://www.gnu.org/licenses/>. | |||||
| */ | |||||
| #include "config.h" | |||||
| #include <assert.h> | |||||
| #include <stdint.h> | |||||
| #include <stdlib.h> | |||||
| #include <stdio.h> | |||||
| #include <espeak-ng/espeak_ng.h> | |||||
| #include <espeak-ng/speak_lib.h> | |||||
| void | |||||
| test_selection_by_name() | |||||
| { | |||||
| printf("testing selection of voice by name\n"); | |||||
| assert(espeak_SetVoiceByName("de") == EE_OK); | |||||
| assert(espeak_SetVoiceByName("und") == EE_NOT_FOUND); | |||||
| assert(espeak_ng_SetVoiceByName("de") == ENS_OK); | |||||
| assert(espeak_ng_SetVoiceByName("und") == ENS_VOICE_NOT_FOUND); | |||||
| } | |||||
| int | |||||
| main(int argc, char **argv) | |||||
| { | |||||
| assert(espeak_Initialize(AUDIO_OUTPUT_SYNCHRONOUS, 0, NULL, espeakINITIALIZE_DONT_EXIT) == 22050); | |||||
| test_selection_by_name(); | |||||
| assert(espeak_Terminate() == EE_OK); | |||||
| return EXIT_SUCCESS; | |||||
| } |