Commit f494caa402b6717a6ecdb8541c1f81c71d1e43d3
1 parent
b530db9b
- uproszczenie testów junitowych
git-svn-id: svn://svn.nlp.ipipan.waw.pl/morfeusz/trunk@253 ff4e3ee1-f430-4e82-ade0-24591c43f1fd
Showing
5 changed files
with
121 additions
and
16 deletions
CMakeLists.txt
... | ... | @@ -183,6 +183,6 @@ if (UNIX) |
183 | 183 | endif() |
184 | 184 | |
185 | 185 | if (UNIX) |
186 | - add_test(TestJavaWrapper ./testJavaWrapper.sh "${PROJECT_BINARY_DIR}") | |
186 | + add_test(TestJavaWrapper ./testJavaWrapper.sh "${CMAKE_CURRENT_SOURCE_DIR}" "${PROJECT_BINARY_DIR}") | |
187 | 187 | add_test(TestPythonWrapper ./testPythonWrapper.sh "${PROJECT_BINARY_DIR}") |
188 | 188 | endif () |
... | ... |
morfeusz/wrappers/java/CMakeLists.txt
... | ... | @@ -10,8 +10,9 @@ include_directories (${CMAKE_SOURCE_DIR}/morfeusz) |
10 | 10 | |
11 | 11 | set (SWIG_JAVA_OUTFILE "${CMAKE_CURRENT_BINARY_DIR}/swigJAVA.cpp") |
12 | 12 | file (COPY pl DESTINATION .) |
13 | -file (COPY JMorfeuszTest DESTINATION "${CMAKE_CURRENT_BINARY_DIR}") | |
13 | + | |
14 | 14 | set (JAVA_SRC_DIR "${CMAKE_CURRENT_BINARY_DIR}/pl/waw/ipipan/morfeusz") |
15 | + | |
15 | 16 | add_custom_command ( |
16 | 17 | OUTPUT ${SWIG_JAVA_OUTFILE} |
17 | 18 | COMMAND swig -java -c++ -package pl.waw.ipipan.morfeusz -o ${SWIG_JAVA_OUTFILE} -outdir ${JAVA_SRC_DIR} ${CMAKE_SOURCE_DIR}/morfeusz/wrappers/morfeusz.i |
... | ... | @@ -19,6 +20,7 @@ add_custom_command ( |
19 | 20 | ) |
20 | 21 | add_custom_target(generate-java-wrapper ALL |
21 | 22 | DEPENDS ${SWIG_JAVA_OUTFILE}) |
23 | + | |
22 | 24 | add_library (libjmorfeusz SHARED ${SWIG_JAVA_OUTFILE}) |
23 | 25 | add_dependencies (libjmorfeusz generate_java_wrapper) |
24 | 26 | set_target_properties (libjmorfeusz PROPERTIES OUTPUT_NAME "jmorfeusz") |
... | ... | @@ -58,17 +60,6 @@ add_jar (jmorfeusz |
58 | 60 | ENTRY_POINT pl/waw/ipipan/morfeusz/app/App |
59 | 61 | DEPENDS libjmorfeusz generate-java-wrapper) |
60 | 62 | |
61 | -#create_javadoc(jmorfeusz_javadoc | |
62 | -# PACKAGES pl.waw.ipipan.morfeusz | |
63 | -# SOURCEPATH "${CMAKE_CURRENT_BINARY_DIR}" | |
64 | -# CLASSPATH "${CMAKE_JAVA_INCLUDE_PATH}" | |
65 | -# WINDOWTITLE "JMorfeusz - Morfeusz Java binding" | |
66 | -# DOCTITLE "<h1>JMorfeusz</h1>" | |
67 | -# AUTHOR TRUE | |
68 | -# USE TRUE | |
69 | -# VERSION TRUE | |
70 | -# DEPENDS jmorfeusz generate_java_wrapper) | |
71 | - | |
72 | 63 | add_custom_target(generate-javadoc ALL |
73 | 64 | COMMAND javadoc |
74 | 65 | -d "${CMAKE_CURRENT_BINARY_DIR}/jmorfeusz_javadoc" |
... | ... |
morfeusz/wrappers/java/JMorfeuszTest.java
0 → 100644
1 | + | |
2 | +import java.io.File; | |
3 | +import java.io.IOException; | |
4 | +import java.util.List; | |
5 | +import java.util.NoSuchElementException; | |
6 | +import org.junit.After; | |
7 | +import org.junit.AfterClass; | |
8 | +import static org.junit.Assert.*; | |
9 | +import org.junit.Before; | |
10 | +import org.junit.BeforeClass; | |
11 | +import org.junit.Test; | |
12 | +import pl.waw.ipipan.morfeusz.Morfeusz; | |
13 | +import pl.waw.ipipan.morfeusz.MorfeuszException; | |
14 | +import pl.waw.ipipan.morfeusz.MorphInterpretation; | |
15 | +import pl.waw.ipipan.morfeusz.ResultsIterator; | |
16 | + | |
17 | +/** | |
18 | + * | |
19 | + * @author mlenart | |
20 | + */ | |
21 | +public class JMorfeuszTest { | |
22 | + | |
23 | + private Morfeusz morfeusz; | |
24 | + | |
25 | + public JMorfeuszTest() { | |
26 | + } | |
27 | + | |
28 | + @BeforeClass | |
29 | + public static void setUpClass() { | |
30 | + } | |
31 | + | |
32 | + @AfterClass | |
33 | + public static void tearDownClass() { | |
34 | + } | |
35 | + | |
36 | + @Before | |
37 | + public void setUp() { | |
38 | + morfeusz = Morfeusz.createInstance(); | |
39 | + } | |
40 | + | |
41 | + @After | |
42 | + public void tearDown() { | |
43 | + } | |
44 | + | |
45 | + @Test | |
46 | + public void testAnalyzeAsList() { | |
47 | + List<MorphInterpretation> res = morfeusz.analyseAsList("Aaaa żżżż"); | |
48 | + assertEquals(2, res.size()); | |
49 | + assertEquals("Aaaa", res.get(0).getOrth()); | |
50 | + assertEquals("żżżż", res.get(1).getOrth()); | |
51 | + try { | |
52 | + res.get(2); | |
53 | + fail(); | |
54 | + } | |
55 | + catch (IndexOutOfBoundsException ex) { | |
56 | + | |
57 | + } | |
58 | + } | |
59 | + | |
60 | + @Test | |
61 | + public void testAnalyzeAsIterator() { | |
62 | + ResultsIterator it = morfeusz.analyseAsIterator("Aaaa żżżż"); | |
63 | + assertTrue(it.hasNext()); | |
64 | + assertEquals("Aaaa", it.next().getOrth()); | |
65 | + assertTrue(it.hasNext()); | |
66 | + assertEquals("żżżż", it.next().getOrth()); | |
67 | + try { | |
68 | + it.next(); | |
69 | + fail(); | |
70 | + } | |
71 | + catch (NoSuchElementException ex) { | |
72 | + | |
73 | + } | |
74 | + } | |
75 | + | |
76 | + @Test(expected = MorfeuszException.class) | |
77 | + public void testInvalidAgglOption() { | |
78 | + morfeusz.setAggl("XXXXYYYYZZZZ"); | |
79 | + } | |
80 | + | |
81 | + @Test(expected = MorfeuszException.class) | |
82 | + public void testInvalidPraetOption() { | |
83 | + morfeusz.setPraet("XXXXYYYYZZZZ"); | |
84 | + } | |
85 | + | |
86 | + @Test(expected = MorfeuszException.class) | |
87 | + public void testInvalidGenerate() { | |
88 | + morfeusz.generate("AAAA BBBB"); | |
89 | + } | |
90 | + | |
91 | + @Test(expected = NullPointerException.class) | |
92 | + public void testNullCaseHandling() { | |
93 | + morfeusz.setCaseHandling(null); | |
94 | + } | |
95 | + | |
96 | + @Test(expected = IOException.class) | |
97 | + public void testNonExistingDictionaryFile() throws IOException { | |
98 | + File tmpFile = File.createTempFile("morfeusz_invalid_dict", ".test"); | |
99 | + tmpFile.delete(); | |
100 | + morfeusz.setGeneratorDictionary(tmpFile.getAbsolutePath()); | |
101 | + } | |
102 | + | |
103 | + @Test(expected = IOException.class) | |
104 | + public void testInvalidDictionaryFile() throws IOException { | |
105 | + File tmpFile = File.createTempFile("morfeusz_invalid_dict", ".test"); | |
106 | + morfeusz.setGeneratorDictionary(tmpFile.getAbsolutePath()); | |
107 | + } | |
108 | +} | |
... | ... |
morfeusz/wrappers/java/test_lib/junit.jar
0 → 100644
No preview for this file type
testJavaWrapper.sh
1 | 1 | #!/bin/bash |
2 | 2 | echo "testing java wrapper" |
3 | -PROJECT_BINARY_DIR=$1 | |
4 | -cd morfeusz/wrappers/java/JMorfeuszTest | |
5 | -LD_LIBRARY_PATH="$PROJECT_BINARY_DIR/morfeusz:$PROJECT_BINARY_DIR/morfeusz/wrappers/java" ant -lib "$PROJECT_BINARY_DIR/morfeusz/wrappers/java" test | |
3 | +PROJECT_SRC_DIR=$1 | |
4 | +PROJECT_BINARY_DIR=$2 | |
5 | +TEST_DIR="$PROJECT_BINARY_DIR/morfeusz/wrappers/java" | |
6 | +JUNIT_JAR="$PROJECT_SRC_DIR/morfeusz/wrappers/java/test_lib/junit.jar" | |
7 | +JMORFEUSZ_JAR="$TEST_DIR/jmorfeusz.jar" | |
8 | +JAVA_TEST_FILE="$PROJECT_SRC_DIR/morfeusz/wrappers/java/JMorfeuszTest.java" | |
9 | + | |
10 | +LD_LIBRARY_PATH="$PROJECT_BINARY_DIR/morfeusz:$TEST_DIR" javac -cp "$JUNIT_JAR:$JMORFEUSZ_JAR" -d "$TEST_DIR" "$JAVA_TEST_FILE" | |
11 | +LD_LIBRARY_PATH="$PROJECT_BINARY_DIR/morfeusz:$TEST_DIR" java -cp "$JUNIT_JAR:$JMORFEUSZ_JAR:$TEST_DIR" org.junit.runner.JUnitCore JMorfeuszTest | |
... | ... |