@@ -236,9 +236,15 @@ tests_encoding_test_SOURCES = tests/encoding.c | |||
noinst_bin_PROGRAMS += tests/tokenizer.test | |||
tests_tokenizer_test_CFLAGS = -Isrc/libespeak-ng ${AM_CFLAGS} | |||
tests_tokenizer_test_LDADD = src/libespeak-ng-test.la | |||
tests_tokenizer_test_LDADD = src/libespeak-ng.la | |||
tests_tokenizer_test_SOURCES = tests/tokenizer.c | |||
noinst_bin_PROGRAMS += tests/readclause.test | |||
tests_readclause_test_CFLAGS = -Isrc/libespeak-ng ${AM_CFLAGS} | |||
tests_readclause_test_LDADD = src/libespeak-ng-test.la | |||
tests_readclause_test_SOURCES = tests/readclause.c | |||
noinst_bin_PROGRAMS += tests/voices.test | |||
tests_voices_test_LDADD = src/libespeak-ng-test.la | |||
@@ -248,6 +254,7 @@ tests_voices_test_SOURCES = tests/voices.c | |||
check: tests/encoding.test tests/tokenizer.test tests/voices.test tests/languages.test | |||
tests/encoding.test | |||
tests/tokenizer.test | |||
tests/readclause.test | |||
ESPEAK_DATA_PATH=$(PWD) tests/voices.test | |||
tests/languages.test | |||
@@ -0,0 +1,177 @@ | |||
/* | |||
* 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 <errno.h> | |||
#include <stdint.h> | |||
#include <stdlib.h> | |||
#include <string.h> | |||
#include <stdio.h> | |||
#include <sys/stat.h> | |||
#include <espeak-ng/espeak_ng.h> | |||
#include <espeak-ng/encoding.h> | |||
#include "speech.h" | |||
#include "phoneme.h" | |||
#include "synthesize.h" | |||
#include "translate.h" | |||
void | |||
test_latin_common() | |||
{ | |||
printf("testing Latin/Common (Latn/Zyyy) script classification\n"); | |||
assert(clause_type_from_codepoint('a') == CLAUSE_NONE); | |||
assert(clause_type_from_codepoint('.') == CLAUSE_PERIOD); | |||
assert(clause_type_from_codepoint('?') == CLAUSE_QUESTION); | |||
assert(clause_type_from_codepoint('!') == CLAUSE_EXCLAMATION); | |||
assert(clause_type_from_codepoint(',') == CLAUSE_COMMA); | |||
assert(clause_type_from_codepoint(':') == CLAUSE_COLON); | |||
assert(clause_type_from_codepoint(';') == CLAUSE_SEMICOLON); | |||
assert(clause_type_from_codepoint(0x00A1) == (CLAUSE_SEMICOLON | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0x00Bf) == (CLAUSE_SEMICOLON | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0x2013) == CLAUSE_SEMICOLON); | |||
assert(clause_type_from_codepoint(0x2014) == CLAUSE_SEMICOLON); | |||
assert(clause_type_from_codepoint(0x2026) == (CLAUSE_SEMICOLON | CLAUSE_SPEAK_PUNCTUATION_NAME | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
} | |||
void | |||
test_greek() | |||
{ | |||
printf("testing Greek (Grek) script classification\n"); | |||
assert(clause_type_from_codepoint(0x037E) == CLAUSE_QUESTION); | |||
assert(clause_type_from_codepoint(0x0387) == CLAUSE_SEMICOLON); | |||
} | |||
void | |||
test_armenian() | |||
{ | |||
printf("testing Armenian (Armn) script classification\n"); | |||
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(0x055D) == CLAUSE_COMMA); | |||
assert(clause_type_from_codepoint(0x055E) == (CLAUSE_QUESTION | CLAUSE_PUNCTUATION_IN_WORD)); | |||
assert(clause_type_from_codepoint(0x0589) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
} | |||
void | |||
test_arabic() | |||
{ | |||
printf("testing Arabic (Arab) script classification\n"); | |||
assert(clause_type_from_codepoint(0x060C) == CLAUSE_COMMA); | |||
assert(clause_type_from_codepoint(0x061B) == CLAUSE_SEMICOLON); | |||
assert(clause_type_from_codepoint(0x061F) == CLAUSE_QUESTION); | |||
assert(clause_type_from_codepoint(0x06D4) == CLAUSE_PERIOD); | |||
} | |||
void | |||
test_devanagari() | |||
{ | |||
printf("testing Devanagari (Deva) script classification\n"); | |||
assert(clause_type_from_codepoint(0x0964) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
} | |||
void | |||
test_tibetan() | |||
{ | |||
printf("testing Tibetan (Tibt) script classification\n"); | |||
assert(clause_type_from_codepoint(0x0F0D) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0x0F0E) == CLAUSE_PARAGRAPH); | |||
} | |||
void | |||
test_sinhala() | |||
{ | |||
printf("testing Sinhala (Sinh) script classification\n"); | |||
assert(clause_type_from_codepoint(0x0DF4) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
} | |||
void | |||
test_georgian() | |||
{ | |||
printf("testing Georgian (Geor) script classification\n"); | |||
assert(clause_type_from_codepoint(0x10FB) == CLAUSE_PARAGRAPH); | |||
} | |||
void | |||
test_ethiopic() | |||
{ | |||
printf("testing Ethiopic (Ethi) script classification\n"); | |||
assert(clause_type_from_codepoint(0x1362) == CLAUSE_PERIOD); | |||
assert(clause_type_from_codepoint(0x1363) == CLAUSE_COMMA); | |||
assert(clause_type_from_codepoint(0x1364) == CLAUSE_SEMICOLON); | |||
assert(clause_type_from_codepoint(0x1365) == CLAUSE_COLON); | |||
assert(clause_type_from_codepoint(0x1366) == CLAUSE_COLON); | |||
assert(clause_type_from_codepoint(0x1367) == CLAUSE_QUESTION); | |||
assert(clause_type_from_codepoint(0x1368) == CLAUSE_PARAGRAPH); | |||
} | |||
void | |||
test_ideographic() | |||
{ | |||
printf("testing Ideographic (Hani) script classification\n"); | |||
assert(clause_type_from_codepoint(0x3001) == (CLAUSE_COMMA | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0x3002) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
} | |||
void | |||
test_fullwidth() | |||
{ | |||
printf("testing Full Width/Common (Zyyy) script classification\n"); | |||
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(0xFF0E) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0xFF1A) == (CLAUSE_COLON | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0xFF1B) == (CLAUSE_SEMICOLON | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0xFF1F) == (CLAUSE_QUESTION | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
} | |||
int | |||
main(int argc, char **argv) | |||
{ | |||
test_latin_common(); | |||
test_greek(); | |||
test_armenian(); | |||
test_arabic(); | |||
test_devanagari(); | |||
test_tibetan(); | |||
test_sinhala(); | |||
test_georgian(); | |||
test_ethiopic(); | |||
test_ideographic(); | |||
test_fullwidth(); | |||
printf("done\n"); | |||
return EXIT_SUCCESS; | |||
} |
@@ -50,128 +50,6 @@ int GetFileLength(const char *filename) | |||
return statbuf.st_size; | |||
} | |||
void | |||
test_latin_common() | |||
{ | |||
printf("testing Latin/Common (Latn/Zyyy) script classification\n"); | |||
assert(clause_type_from_codepoint('a') == CLAUSE_NONE); | |||
assert(clause_type_from_codepoint('.') == CLAUSE_PERIOD); | |||
assert(clause_type_from_codepoint('?') == CLAUSE_QUESTION); | |||
assert(clause_type_from_codepoint('!') == CLAUSE_EXCLAMATION); | |||
assert(clause_type_from_codepoint(',') == CLAUSE_COMMA); | |||
assert(clause_type_from_codepoint(':') == CLAUSE_COLON); | |||
assert(clause_type_from_codepoint(';') == CLAUSE_SEMICOLON); | |||
assert(clause_type_from_codepoint(0x00A1) == (CLAUSE_SEMICOLON | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0x00Bf) == (CLAUSE_SEMICOLON | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0x2013) == CLAUSE_SEMICOLON); | |||
assert(clause_type_from_codepoint(0x2014) == CLAUSE_SEMICOLON); | |||
assert(clause_type_from_codepoint(0x2026) == (CLAUSE_SEMICOLON | CLAUSE_SPEAK_PUNCTUATION_NAME | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
} | |||
void | |||
test_greek() | |||
{ | |||
printf("testing Greek (Grek) script classification\n"); | |||
assert(clause_type_from_codepoint(0x037E) == CLAUSE_QUESTION); | |||
assert(clause_type_from_codepoint(0x0387) == CLAUSE_SEMICOLON); | |||
} | |||
void | |||
test_armenian() | |||
{ | |||
printf("testing Armenian (Armn) script classification\n"); | |||
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(0x055D) == CLAUSE_COMMA); | |||
assert(clause_type_from_codepoint(0x055E) == (CLAUSE_QUESTION | CLAUSE_PUNCTUATION_IN_WORD)); | |||
assert(clause_type_from_codepoint(0x0589) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
} | |||
void | |||
test_arabic() | |||
{ | |||
printf("testing Arabic (Arab) script classification\n"); | |||
assert(clause_type_from_codepoint(0x060C) == CLAUSE_COMMA); | |||
assert(clause_type_from_codepoint(0x061B) == CLAUSE_SEMICOLON); | |||
assert(clause_type_from_codepoint(0x061F) == CLAUSE_QUESTION); | |||
assert(clause_type_from_codepoint(0x06D4) == CLAUSE_PERIOD); | |||
} | |||
void | |||
test_devanagari() | |||
{ | |||
printf("testing Devanagari (Deva) script classification\n"); | |||
assert(clause_type_from_codepoint(0x0964) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
} | |||
void | |||
test_tibetan() | |||
{ | |||
printf("testing Tibetan (Tibt) script classification\n"); | |||
assert(clause_type_from_codepoint(0x0F0D) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0x0F0E) == CLAUSE_PARAGRAPH); | |||
} | |||
void | |||
test_sinhala() | |||
{ | |||
printf("testing Sinhala (Sinh) script classification\n"); | |||
assert(clause_type_from_codepoint(0x0DF4) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
} | |||
void | |||
test_georgian() | |||
{ | |||
printf("testing Georgian (Geor) script classification\n"); | |||
assert(clause_type_from_codepoint(0x10FB) == CLAUSE_PARAGRAPH); | |||
} | |||
void | |||
test_ethiopic() | |||
{ | |||
printf("testing Ethiopic (Ethi) script classification\n"); | |||
assert(clause_type_from_codepoint(0x1362) == CLAUSE_PERIOD); | |||
assert(clause_type_from_codepoint(0x1363) == CLAUSE_COMMA); | |||
assert(clause_type_from_codepoint(0x1364) == CLAUSE_SEMICOLON); | |||
assert(clause_type_from_codepoint(0x1365) == CLAUSE_COLON); | |||
assert(clause_type_from_codepoint(0x1366) == CLAUSE_COLON); | |||
assert(clause_type_from_codepoint(0x1367) == CLAUSE_QUESTION); | |||
assert(clause_type_from_codepoint(0x1368) == CLAUSE_PARAGRAPH); | |||
} | |||
void | |||
test_ideographic() | |||
{ | |||
printf("testing Ideographic (Hani) script classification\n"); | |||
assert(clause_type_from_codepoint(0x3001) == (CLAUSE_COMMA | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0x3002) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
} | |||
void | |||
test_fullwidth() | |||
{ | |||
printf("testing Full Width/Common (Zyyy) script classification\n"); | |||
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(0xFF0E) == (CLAUSE_PERIOD | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0xFF1A) == (CLAUSE_COLON | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0xFF1B) == (CLAUSE_SEMICOLON | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
assert(clause_type_from_codepoint(0xFF1F) == (CLAUSE_QUESTION | CLAUSE_OPTIONAL_SPACE_AFTER)); | |||
} | |||
void | |||
test_unbound_tokenizer() | |||
{ | |||
@@ -685,18 +563,6 @@ test_Latn_symbol_tokens() | |||
void | |||
run_tests() | |||
{ | |||
test_latin_common(); | |||
test_greek(); | |||
test_armenian(); | |||
test_arabic(); | |||
test_devanagari(); | |||
test_tibetan(); | |||
test_sinhala(); | |||
test_georgian(); | |||
test_ethiopic(); | |||
test_ideographic(); | |||
test_fullwidth(); | |||
test_unbound_tokenizer(); | |||
test_linux_newline_tokens(); |