mirror of https://github.com/apache/lucene.git
don't fail test due to jre bugs in String.toLowerCase
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1243415 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
6f186b0dd4
commit
6a07201844
|
@ -19,6 +19,7 @@ package org.apache.lucene.analysis.miscellaneous;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.StringReader;
|
import java.io.StringReader;
|
||||||
|
import java.lang.Thread.UncaughtExceptionHandler;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
@ -137,6 +138,40 @@ public class PatternAnalyzerTest extends BaseTokenStreamTestCase {
|
||||||
/** blast some random strings through the analyzer */
|
/** blast some random strings through the analyzer */
|
||||||
public void testRandomStrings() throws Exception {
|
public void testRandomStrings() throws Exception {
|
||||||
Analyzer a = new PatternAnalyzer(TEST_VERSION_CURRENT, Pattern.compile(","), true, StopAnalyzer.ENGLISH_STOP_WORDS_SET);
|
Analyzer a = new PatternAnalyzer(TEST_VERSION_CURRENT, Pattern.compile(","), true, StopAnalyzer.ENGLISH_STOP_WORDS_SET);
|
||||||
checkRandomData(random, a, 10000*RANDOM_MULTIPLIER);
|
|
||||||
|
// dodge jre bug http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=7104012
|
||||||
|
final UncaughtExceptionHandler savedHandler = Thread.getDefaultUncaughtExceptionHandler();
|
||||||
|
Thread.setDefaultUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler() {
|
||||||
|
@Override
|
||||||
|
public void uncaughtException(Thread thread, Throwable throwable) {
|
||||||
|
assumeTrue("not failing due to jre bug ", !isJREBug7104012(throwable));
|
||||||
|
// otherwise its some other bug, pass to default handler
|
||||||
|
savedHandler.uncaughtException(thread, throwable);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
try {
|
||||||
|
Thread.getDefaultUncaughtExceptionHandler();
|
||||||
|
checkRandomData(random, a, 10000*RANDOM_MULTIPLIER);
|
||||||
|
} catch (ArrayIndexOutOfBoundsException ex) {
|
||||||
|
assumeTrue("not failing due to jre bug ", !isJREBug7104012(ex));
|
||||||
|
throw ex; // otherwise rethrow
|
||||||
|
} finally {
|
||||||
|
Thread.setDefaultUncaughtExceptionHandler(savedHandler);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static boolean isJREBug7104012(Throwable t) {
|
||||||
|
if (!(t instanceof ArrayIndexOutOfBoundsException)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
StackTraceElement trace[] = t.getStackTrace();
|
||||||
|
for (StackTraceElement st : trace) {
|
||||||
|
if ("java.text.RuleBasedBreakIterator".equals(st.getClassName())
|
||||||
|
&& "lookupBackwardState".equals(st.getMethodName())) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue