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,6 +183,6 @@ if (UNIX) | ||
183 | endif() | 183 | endif() |
184 | 184 | ||
185 | if (UNIX) | 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 | add_test(TestPythonWrapper ./testPythonWrapper.sh "${PROJECT_BINARY_DIR}") | 187 | add_test(TestPythonWrapper ./testPythonWrapper.sh "${PROJECT_BINARY_DIR}") |
188 | endif () | 188 | endif () |
morfeusz/wrappers/java/CMakeLists.txt
@@ -10,8 +10,9 @@ include_directories (${CMAKE_SOURCE_DIR}/morfeusz) | @@ -10,8 +10,9 @@ include_directories (${CMAKE_SOURCE_DIR}/morfeusz) | ||
10 | 10 | ||
11 | set (SWIG_JAVA_OUTFILE "${CMAKE_CURRENT_BINARY_DIR}/swigJAVA.cpp") | 11 | set (SWIG_JAVA_OUTFILE "${CMAKE_CURRENT_BINARY_DIR}/swigJAVA.cpp") |
12 | file (COPY pl DESTINATION .) | 12 | file (COPY pl DESTINATION .) |
13 | -file (COPY JMorfeuszTest DESTINATION "${CMAKE_CURRENT_BINARY_DIR}") | 13 | + |
14 | set (JAVA_SRC_DIR "${CMAKE_CURRENT_BINARY_DIR}/pl/waw/ipipan/morfeusz") | 14 | set (JAVA_SRC_DIR "${CMAKE_CURRENT_BINARY_DIR}/pl/waw/ipipan/morfeusz") |
15 | + | ||
15 | add_custom_command ( | 16 | add_custom_command ( |
16 | OUTPUT ${SWIG_JAVA_OUTFILE} | 17 | OUTPUT ${SWIG_JAVA_OUTFILE} |
17 | COMMAND swig -java -c++ -package pl.waw.ipipan.morfeusz -o ${SWIG_JAVA_OUTFILE} -outdir ${JAVA_SRC_DIR} ${CMAKE_SOURCE_DIR}/morfeusz/wrappers/morfeusz.i | 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,6 +20,7 @@ add_custom_command ( | ||
19 | ) | 20 | ) |
20 | add_custom_target(generate-java-wrapper ALL | 21 | add_custom_target(generate-java-wrapper ALL |
21 | DEPENDS ${SWIG_JAVA_OUTFILE}) | 22 | DEPENDS ${SWIG_JAVA_OUTFILE}) |
23 | + | ||
22 | add_library (libjmorfeusz SHARED ${SWIG_JAVA_OUTFILE}) | 24 | add_library (libjmorfeusz SHARED ${SWIG_JAVA_OUTFILE}) |
23 | add_dependencies (libjmorfeusz generate_java_wrapper) | 25 | add_dependencies (libjmorfeusz generate_java_wrapper) |
24 | set_target_properties (libjmorfeusz PROPERTIES OUTPUT_NAME "jmorfeusz") | 26 | set_target_properties (libjmorfeusz PROPERTIES OUTPUT_NAME "jmorfeusz") |
@@ -58,17 +60,6 @@ add_jar (jmorfeusz | @@ -58,17 +60,6 @@ add_jar (jmorfeusz | ||
58 | ENTRY_POINT pl/waw/ipipan/morfeusz/app/App | 60 | ENTRY_POINT pl/waw/ipipan/morfeusz/app/App |
59 | DEPENDS libjmorfeusz generate-java-wrapper) | 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 | add_custom_target(generate-javadoc ALL | 63 | add_custom_target(generate-javadoc ALL |
73 | COMMAND javadoc | 64 | COMMAND javadoc |
74 | -d "${CMAKE_CURRENT_BINARY_DIR}/jmorfeusz_javadoc" | 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 | #!/bin/bash | 1 | #!/bin/bash |
2 | echo "testing java wrapper" | 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 |