LUCENE-8938: use expectThrows() to verify the ex thrown in tests

This commit is contained in:
Munendra S N 2019-07-29 22:21:18 +05:30
parent 1d303cee7f
commit 70a8deb0ab
24 changed files with 241 additions and 519 deletions

View File

@ -175,12 +175,7 @@ public class TestSynonymGraphFilter extends BaseTokenStreamTestCase {
String testFile = "a => 1"; String testFile = "a => 1";
Analyzer analyzer = new MockAnalyzer(random(), MockTokenizer.SIMPLE, false); Analyzer analyzer = new MockAnalyzer(random(), MockTokenizer.SIMPLE, false);
SolrSynonymParser parser = new SolrSynonymParser(true, true, analyzer); SolrSynonymParser parser = new SolrSynonymParser(true, true, analyzer);
try { expectThrows(ParseException.class, () -> parser.parse(new StringReader(testFile)));
parser.parse(new StringReader(testFile));
fail("didn't get expected exception");
} catch (ParseException expected) {
// expected exc
}
analyzer.close(); analyzer.close();
} }
@ -191,12 +186,7 @@ public class TestSynonymGraphFilter extends BaseTokenStreamTestCase {
String testFile = "a => b => c"; String testFile = "a => b => c";
Analyzer analyzer = new MockAnalyzer(random()); Analyzer analyzer = new MockAnalyzer(random());
SolrSynonymParser parser = new SolrSynonymParser(true, true, analyzer); SolrSynonymParser parser = new SolrSynonymParser(true, true, analyzer);
try { expectThrows(ParseException.class, () -> parser.parse(new StringReader(testFile)));
parser.parse(new StringReader(testFile));
fail("didn't get expected exception");
} catch (ParseException expected) {
// expected exc
}
analyzer.close(); analyzer.close();
} }
@ -561,13 +551,10 @@ public class TestSynonymGraphFilter extends BaseTokenStreamTestCase {
public void testZeroSyns() throws Exception { public void testZeroSyns() throws Exception {
Tokenizer tokenizer = new MockTokenizer(); Tokenizer tokenizer = new MockTokenizer();
tokenizer.setReader(new StringReader("aa bb")); tokenizer.setReader(new StringReader("aa bb"));
try {
new SynonymGraphFilter(tokenizer, new SynonymMap.Builder(true).build(), true); IllegalArgumentException ex = expectThrows(IllegalArgumentException.class, () ->
fail("did not hit expected exception"); new SynonymGraphFilter(tokenizer, new SynonymMap.Builder(true).build(), true));
} catch (IllegalArgumentException iae) { assertEquals("fst must be non-null", ex.getMessage());
// expected
assertEquals("fst must be non-null", iae.getMessage());
}
} }
public void testOutputHangsOffEnd() throws Exception { public void testOutputHangsOffEnd() throws Exception {

View File

@ -135,95 +135,55 @@ public class TestCharArrayMap extends LuceneTestCase {
map.put("bar",2); map.put("bar",2);
final int size = map.size(); final int size = map.size();
assertEquals(2, size); assertEquals(2, size);
assertTrue(map.containsKey("foo")); assertTrue(map.containsKey("foo"));
assertEquals(1, map.get("foo").intValue()); assertEquals(1, map.get("foo").intValue());
assertTrue(map.containsKey("bar")); assertTrue(map.containsKey("bar"));
assertEquals(2, map.get("bar").intValue()); assertEquals(2, map.get("bar").intValue());
map = CharArrayMap.unmodifiableMap(map); CharArrayMap<Integer> unmodifiableMap = CharArrayMap.unmodifiableMap(map);
assertEquals("Map size changed due to unmodifiableMap call" , size, map.size()); assertEquals("Map size changed due to unmodifiableMap call" , size, unmodifiableMap.size());
String NOT_IN_MAP = "SirGallahad"; String NOT_IN_MAP = "SirGallahad";
assertFalse("Test String already exists in map", map.containsKey(NOT_IN_MAP)); assertFalse("Test String already exists in map", unmodifiableMap.containsKey(NOT_IN_MAP));
assertNull("Test String already exists in map", map.get(NOT_IN_MAP)); assertNull("Test String already exists in map", unmodifiableMap.get(NOT_IN_MAP));
try{ expectThrows(UnsupportedOperationException.class, () -> unmodifiableMap.put(NOT_IN_MAP.toCharArray(), 3));
map.put(NOT_IN_MAP.toCharArray(), 3); assertFalse("Test String has been added to unmodifiable map", unmodifiableMap.containsKey(NOT_IN_MAP));
fail("Modified unmodifiable map"); assertNull("Test String has been added to unmodifiable map", unmodifiableMap.get(NOT_IN_MAP));
}catch (UnsupportedOperationException e) { assertEquals("Size of unmodifiable map has changed", size, unmodifiableMap.size());
// expected
assertFalse("Test String has been added to unmodifiable map", map.containsKey(NOT_IN_MAP)); expectThrows(UnsupportedOperationException.class, () -> unmodifiableMap.put(NOT_IN_MAP, 3));
assertNull("Test String has been added to unmodifiable map", map.get(NOT_IN_MAP)); assertFalse("Test String has been added to unmodifiable map", unmodifiableMap.containsKey(NOT_IN_MAP));
assertEquals("Size of unmodifiable map has changed", size, map.size()); assertNull("Test String has been added to unmodifiable map", unmodifiableMap.get(NOT_IN_MAP));
} assertEquals("Size of unmodifiable map has changed", size, unmodifiableMap.size());
try{ expectThrows(UnsupportedOperationException.class, () -> unmodifiableMap.put(new StringBuilder(NOT_IN_MAP), 3));
map.put(NOT_IN_MAP, 3); assertFalse("Test String has been added to unmodifiable map", unmodifiableMap.containsKey(NOT_IN_MAP));
fail("Modified unmodifiable map"); assertNull("Test String has been added to unmodifiable map", unmodifiableMap.get(NOT_IN_MAP));
}catch (UnsupportedOperationException e) { assertEquals("Size of unmodifiable map has changed", size, unmodifiableMap.size());
// expected
assertFalse("Test String has been added to unmodifiable map", map.containsKey(NOT_IN_MAP)); expectThrows(UnsupportedOperationException.class, unmodifiableMap::clear);
assertNull("Test String has been added to unmodifiable map", map.get(NOT_IN_MAP)); assertEquals("Size of unmodifiable map has changed", size, unmodifiableMap.size());
assertEquals("Size of unmodifiable map has changed", size, map.size());
} expectThrows(UnsupportedOperationException.class, () -> unmodifiableMap.entrySet().clear());
assertEquals("Size of unmodifiable map has changed", size, unmodifiableMap.size());
try{
map.put(new StringBuilder(NOT_IN_MAP), 3); expectThrows(UnsupportedOperationException.class, () -> unmodifiableMap.keySet().clear());
fail("Modified unmodifiable map"); assertEquals("Size of unmodifiable map has changed", size, unmodifiableMap.size());
}catch (UnsupportedOperationException e) {
// expected expectThrows(UnsupportedOperationException.class, () -> unmodifiableMap.put((Object) NOT_IN_MAP, 3));
assertFalse("Test String has been added to unmodifiable map", map.containsKey(NOT_IN_MAP)); assertFalse("Test String has been added to unmodifiable map", unmodifiableMap.containsKey(NOT_IN_MAP));
assertNull("Test String has been added to unmodifiable map", map.get(NOT_IN_MAP)); assertNull("Test String has been added to unmodifiable map", unmodifiableMap.get(NOT_IN_MAP));
assertEquals("Size of unmodifiable map has changed", size, map.size()); assertEquals("Size of unmodifiable map has changed", size, unmodifiableMap.size());
}
expectThrows(UnsupportedOperationException.class, () -> unmodifiableMap.putAll(Collections.singletonMap(NOT_IN_MAP, 3)));
try{ assertFalse("Test String has been added to unmodifiable map", unmodifiableMap.containsKey(NOT_IN_MAP));
map.clear(); assertNull("Test String has been added to unmodifiable map", unmodifiableMap.get(NOT_IN_MAP));
fail("Modified unmodifiable map"); assertEquals("Size of unmodifiable map has changed", size, unmodifiableMap.size());
}catch (UnsupportedOperationException e) {
// expected assertTrue(unmodifiableMap.containsKey("foo"));
assertEquals("Size of unmodifiable map has changed", size, map.size()); assertEquals(1, unmodifiableMap.get("foo").intValue());
} assertTrue(unmodifiableMap.containsKey("bar"));
assertEquals(2, unmodifiableMap.get("bar").intValue());
try{
map.entrySet().clear();
fail("Modified unmodifiable map");
}catch (UnsupportedOperationException e) {
// expected
assertEquals("Size of unmodifiable map has changed", size, map.size());
}
try{
map.keySet().clear();
fail("Modified unmodifiable map");
}catch (UnsupportedOperationException e) {
// expected
assertEquals("Size of unmodifiable map has changed", size, map.size());
}
try{
map.put((Object) NOT_IN_MAP, 3);
fail("Modified unmodifiable map");
}catch (UnsupportedOperationException e) {
// expected
assertFalse("Test String has been added to unmodifiable map", map.containsKey(NOT_IN_MAP));
assertNull("Test String has been added to unmodifiable map", map.get(NOT_IN_MAP));
assertEquals("Size of unmodifiable map has changed", size, map.size());
}
try{
map.putAll(Collections.singletonMap(NOT_IN_MAP, 3));
fail("Modified unmodifiable map");
}catch (UnsupportedOperationException e) {
// expected
assertFalse("Test String has been added to unmodifiable map", map.containsKey(NOT_IN_MAP));
assertNull("Test String has been added to unmodifiable map", map.get(NOT_IN_MAP));
assertEquals("Size of unmodifiable map has changed", size, map.size());
}
assertTrue(map.containsKey("foo"));
assertEquals(1, map.get("foo").intValue());
assertTrue(map.containsKey("bar"));
assertEquals(2, map.get("bar").intValue());
} }
public void testToString() { public void testToString() {

View File

@ -90,87 +90,49 @@ public class TestCharArraySet extends LuceneTestCase {
// TODO: break this up into simpler test methods, vs "telling a story" // TODO: break this up into simpler test methods, vs "telling a story"
public void testModifyOnUnmodifiable(){ public void testModifyOnUnmodifiable(){
CharArraySet set=new CharArraySet(10, true); CharArraySet set = new CharArraySet(10, true);
set.addAll(Arrays.asList(TEST_STOP_WORDS)); set.addAll(Arrays.asList(TEST_STOP_WORDS));
final int size = set.size(); final int size = set.size();
set = CharArraySet.unmodifiableSet(set); CharArraySet unmodifiableSet = CharArraySet.unmodifiableSet(set);
assertEquals("Set size changed due to unmodifiableSet call" , size, set.size()); assertEquals("Set size changed due to unmodifiableSet call" , size, unmodifiableSet.size());
String NOT_IN_SET = "SirGallahad"; String NOT_IN_SET = "SirGallahad";
assertFalse("Test String already exists in set", set.contains(NOT_IN_SET)); assertFalse("Test String already exists in set", unmodifiableSet.contains(NOT_IN_SET));
try{ expectThrows(UnsupportedOperationException.class, () -> unmodifiableSet.add(NOT_IN_SET.toCharArray()));
set.add(NOT_IN_SET.toCharArray()); assertFalse("Test String has been added to unmodifiable set", unmodifiableSet.contains(NOT_IN_SET));
fail("Modified unmodifiable set"); assertEquals("Size of unmodifiable set has changed", size, unmodifiableSet.size());
}catch (UnsupportedOperationException e) {
// expected expectThrows(UnsupportedOperationException.class, () -> unmodifiableSet.add(NOT_IN_SET));
assertFalse("Test String has been added to unmodifiable set", set.contains(NOT_IN_SET)); assertFalse("Test String has been added to unmodifiable set", unmodifiableSet.contains(NOT_IN_SET));
assertEquals("Size of unmodifiable set has changed", size, set.size()); assertEquals("Size of unmodifiable set has changed", size, unmodifiableSet.size());
}
expectThrows(UnsupportedOperationException.class, () -> unmodifiableSet.add(new StringBuilder(NOT_IN_SET)));
try{ assertFalse("Test String has been added to unmodifiable set", unmodifiableSet.contains(NOT_IN_SET));
set.add(NOT_IN_SET); assertEquals("Size of unmodifiable set has changed", size, unmodifiableSet.size());
fail("Modified unmodifiable set");
}catch (UnsupportedOperationException e) { expectThrows(UnsupportedOperationException.class, () -> unmodifiableSet.clear());
// expected assertFalse("Changed unmodifiable set", unmodifiableSet.contains(NOT_IN_SET));
assertFalse("Test String has been added to unmodifiable set", set.contains(NOT_IN_SET)); assertEquals("Size of unmodifiable set has changed", size, unmodifiableSet.size());
assertEquals("Size of unmodifiable set has changed", size, set.size());
} expectThrows(UnsupportedOperationException.class, () -> unmodifiableSet.add((Object) NOT_IN_SET));
assertFalse("Test String has been added to unmodifiable set", unmodifiableSet.contains(NOT_IN_SET));
try{ assertEquals("Size of unmodifiable set has changed", size, unmodifiableSet.size());
set.add(new StringBuilder(NOT_IN_SET));
fail("Modified unmodifiable set");
}catch (UnsupportedOperationException e) {
// expected
assertFalse("Test String has been added to unmodifiable set", set.contains(NOT_IN_SET));
assertEquals("Size of unmodifiable set has changed", size, set.size());
}
try{
set.clear();
fail("Modified unmodifiable set");
}catch (UnsupportedOperationException e) {
// expected
assertFalse("Changed unmodifiable set", set.contains(NOT_IN_SET));
assertEquals("Size of unmodifiable set has changed", size, set.size());
}
try{
set.add((Object) NOT_IN_SET);
fail("Modified unmodifiable set");
}catch (UnsupportedOperationException e) {
// expected
assertFalse("Test String has been added to unmodifiable set", set.contains(NOT_IN_SET));
assertEquals("Size of unmodifiable set has changed", size, set.size());
}
// This test was changed in 3.1, as a contains() call on the given Collection using the "correct" iterator's // This test was changed in 3.1, as a contains() call on the given Collection using the "correct" iterator's
// current key (now a char[]) on a Set<String> would not hit any element of the CAS and therefor never call // current key (now a char[]) on a Set<String> would not hit any element of the CAS and therefor never call
// remove() on the iterator // remove() on the iterator
try{ expectThrows(UnsupportedOperationException.class, () -> unmodifiableSet.removeAll(new CharArraySet(Arrays.asList(TEST_STOP_WORDS), true)));
set.removeAll(new CharArraySet(Arrays.asList(TEST_STOP_WORDS), true)); assertEquals("Size of unmodifiable set has changed", size, unmodifiableSet.size());
fail("Modified unmodifiable set");
}catch (UnsupportedOperationException e) { expectThrows(UnsupportedOperationException.class, () -> unmodifiableSet.retainAll(new CharArraySet(Arrays.asList(NOT_IN_SET), true)));
// expected assertEquals("Size of unmodifiable set has changed", size, unmodifiableSet.size());
assertEquals("Size of unmodifiable set has changed", size, set.size());
} expectThrows(UnsupportedOperationException.class, () -> unmodifiableSet.addAll(Arrays.asList(NOT_IN_SET)));
assertFalse("Test String has been added to unmodifiable set", unmodifiableSet.contains(NOT_IN_SET));
try{
set.retainAll(new CharArraySet(Arrays.asList(NOT_IN_SET), true));
fail("Modified unmodifiable set");
}catch (UnsupportedOperationException e) {
// expected
assertEquals("Size of unmodifiable set has changed", size, set.size());
}
try{
set.addAll(Arrays.asList(NOT_IN_SET));
fail("Modified unmodifiable set");
}catch (UnsupportedOperationException e) {
// expected
assertFalse("Test String has been added to unmodifiable set", set.contains(NOT_IN_SET));
}
for (int i = 0; i < TEST_STOP_WORDS.length; i++) { for (int i = 0; i < TEST_STOP_WORDS.length; i++) {
assertTrue(set.contains(TEST_STOP_WORDS[i])); assertTrue(set.contains(TEST_STOP_WORDS[i]));
assertTrue(unmodifiableSet.contains(TEST_STOP_WORDS[i]));
} }
} }

View File

@ -127,21 +127,15 @@ public class TestAllFilesCheckIndexHeader extends LuceneTestCase {
dirCopy.sync(Collections.singleton(name)); dirCopy.sync(Collections.singleton(name));
} }
try { // NOTE: we .close so that if the test fails (truncation not detected) we don't also get all these confusing errors about open files:
// NOTE: we .close so that if the test fails (truncation not detected) we don't also get all these confusing errors about open files: expectThrowsAnyOf(Arrays.asList(CorruptIndexException.class, EOFException.class, IndexFormatTooOldException.class),
DirectoryReader.open(dirCopy).close(); () -> DirectoryReader.open(dirCopy).close()
fail("wrong bytes not detected after randomizing first " + wrongBytes + " bytes out of " + victimLength + " for file " + victim); );
} catch (CorruptIndexException | EOFException | IndexFormatTooOldException e) {
// expected
}
// CheckIndex should also fail: // CheckIndex should also fail:
try { expectThrowsAnyOf(Arrays.asList(CorruptIndexException.class, EOFException.class, IndexFormatTooOldException.class),
TestUtil.checkIndex(dirCopy, true, true, null); () -> DirectoryReader.open(dirCopy).close()
fail("wrong bytes not detected after randomizing first " + wrongBytes + " bytes out of " + victimLength + " for file " + victim); );
} catch (CorruptIndexException | EOFException | IndexFormatTooOldException e) {
// expected
}
} }
} }
} }

View File

@ -19,6 +19,7 @@ package org.apache.lucene.index;
import java.io.EOFException; import java.io.EOFException;
import java.io.IOException; import java.io.IOException;
import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
import org.apache.lucene.analysis.MockAnalyzer; import org.apache.lucene.analysis.MockAnalyzer;
@ -104,21 +105,15 @@ public class TestAllFilesDetectTruncation extends LuceneTestCase {
dirCopy.sync(Collections.singleton(name)); dirCopy.sync(Collections.singleton(name));
} }
try { // NOTE: we .close so that if the test fails (truncation not detected) we don't also get all these confusing errors about open files:
// NOTE: we .close so that if the test fails (truncation not detected) we don't also get all these confusing errors about open files: expectThrowsAnyOf(Arrays.asList(CorruptIndexException.class, EOFException.class),
DirectoryReader.open(dirCopy).close(); () -> DirectoryReader.open(dirCopy).close()
fail("truncation not detected after removing " + lostBytes + " bytes out of " + victimLength + " for file " + victim); );
} catch (CorruptIndexException | EOFException e) {
// expected
}
// CheckIndex should also fail: // CheckIndex should also fail:
try { expectThrowsAnyOf(Arrays.asList(CorruptIndexException.class, EOFException.class),
TestUtil.checkIndex(dirCopy, true, true, null); () -> TestUtil.checkIndex(dirCopy, true, true, null)
fail("truncation not detected after removing " + lostBytes + " bytes out of " + victimLength + " for file " + victim); );
} catch (CorruptIndexException | EOFException e) {
// expected
}
} }
} }
} }

View File

@ -21,6 +21,7 @@ import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import java.nio.file.NoSuchFileException; import java.nio.file.NoSuchFileException;
import java.nio.file.Path; import java.nio.file.Path;
import java.util.Arrays;
import java.util.Collection; import java.util.Collection;
import java.util.HashSet; import java.util.HashSet;
import java.util.Iterator; import java.util.Iterator;
@ -475,22 +476,16 @@ public class TestDirectoryReader extends LuceneTestCase {
if (dir instanceof BaseDirectoryWrapper) { if (dir instanceof BaseDirectoryWrapper) {
((BaseDirectoryWrapper)dir).setCheckIndexOnClose(false); // we will hit NoSuchFileException in MDW since we nuked it! ((BaseDirectoryWrapper)dir).setCheckIndexOnClose(false); // we will hit NoSuchFileException in MDW since we nuked it!
} }
try { expectThrowsAnyOf(Arrays.asList(FileNotFoundException.class, NoSuchFileException.class),
DirectoryReader.open(dir); () -> DirectoryReader.open(dir)
fail("expected FileNotFoundException/NoSuchFileException"); );
} catch (FileNotFoundException | NoSuchFileException e) {
// expected
}
IOUtils.rm(dirFile); IOUtils.rm(dirFile);
// Make sure we still get a CorruptIndexException (not NPE): // Make sure we still get a CorruptIndexException (not NPE):
try { expectThrowsAnyOf(Arrays.asList(FileNotFoundException.class, NoSuchFileException.class),
DirectoryReader.open(dir); () -> DirectoryReader.open(dir)
fail("expected FileNotFoundException/NoSuchFileException"); );
} catch (FileNotFoundException | NoSuchFileException e) {
// expected
}
dir.close(); dir.close();
} }

View File

@ -372,12 +372,7 @@ public class TestIndexableField extends LuceneTestCase {
public void testNotIndexedTermVectors() throws Exception { public void testNotIndexedTermVectors() throws Exception {
Directory dir = newDirectory(); Directory dir = newDirectory();
RandomIndexWriter w = new RandomIndexWriter(random(), dir); RandomIndexWriter w = new RandomIndexWriter(random(), dir);
try { expectThrows(IllegalArgumentException.class, () -> w.addDocument(Collections.singletonList(new CustomField())));
w.addDocument(Collections.<IndexableField>singletonList(new CustomField()));
fail("didn't hit exception");
} catch (IllegalArgumentException iae) {
// expected
}
w.close(); w.close();
dir.close(); dir.close();
} }

View File

@ -38,6 +38,7 @@ import org.apache.lucene.util.TestUtil;
*/ */
@SuppressFileSystems("ExtrasFS") @SuppressFileSystems("ExtrasFS")
public class TestSwappedIndexFiles extends LuceneTestCase { public class TestSwappedIndexFiles extends LuceneTestCase {
public void test() throws Exception { public void test() throws Exception {
Directory dir1 = newDirectory(); Directory dir1 = newDirectory();
Directory dir2 = newDirectory(); Directory dir2 = newDirectory();
@ -107,21 +108,15 @@ public class TestSwappedIndexFiles extends LuceneTestCase {
dirCopy.sync(Collections.singleton(name)); dirCopy.sync(Collections.singleton(name));
} }
try { // NOTE: we .close so that if the test fails (truncation not detected) we don't also get all these confusing errors about open files:
// NOTE: we .close so that if the test fails (truncation not detected) we don't also get all these confusing errors about open files: expectThrowsAnyOf(Arrays.asList(CorruptIndexException.class, EOFException.class, IndexFormatTooOldException.class),
DirectoryReader.open(dirCopy).close(); () -> DirectoryReader.open(dirCopy).close()
fail("wrong file " + victim + " not detected"); );
} catch (CorruptIndexException | EOFException | IndexFormatTooOldException e) {
// expected
}
// CheckIndex should also fail: // CheckIndex should also fail:
try { expectThrowsAnyOf(Arrays.asList(CorruptIndexException.class, EOFException.class, IndexFormatTooOldException.class),
TestUtil.checkIndex(dirCopy, true, true, null); () -> TestUtil.checkIndex(dirCopy, true, true, null)
fail("wrong file " + victim + " not detected"); );
} catch (CorruptIndexException | EOFException | IndexFormatTooOldException e) {
// expected
}
} }
} }
} }

View File

@ -35,12 +35,9 @@ public final class TestRateLimiter extends LuceneTestCase {
Thread t = new Thread() { Thread t = new Thread() {
@Override @Override
public void run() { public void run() {
try { expectThrows(ThreadInterruptedException.class, () -> {
new SimpleRateLimiter(1).pause((long) (1.5*Integer.MAX_VALUE*1024*1024/1000)); new SimpleRateLimiter(1).pause((long) (1.5*Integer.MAX_VALUE*1024*1024/1000));
fail("should have been interrupted"); });
} catch (ThreadInterruptedException tie) {
// expected
}
} }
}; };
t.start(); t.start();

View File

@ -47,10 +47,7 @@ public class TestCheckJoinIndex extends LuceneTestCase {
w.close(); w.close();
BitSetProducer parentsFilter = new QueryBitSetProducer(new MatchNoDocsQuery()); BitSetProducer parentsFilter = new QueryBitSetProducer(new MatchNoDocsQuery());
try { try {
CheckJoinIndex.check(reader, parentsFilter); expectThrows(IllegalStateException.class, () -> CheckJoinIndex.check(reader, parentsFilter));
fail("Invalid index");
} catch (IllegalStateException e) {
// expected
} finally { } finally {
reader.close(); reader.close();
dir.close(); dir.close();
@ -88,10 +85,7 @@ public class TestCheckJoinIndex extends LuceneTestCase {
w.close(); w.close();
BitSetProducer parentsFilter = new QueryBitSetProducer(new TermQuery(new Term("parent", "true"))); BitSetProducer parentsFilter = new QueryBitSetProducer(new TermQuery(new Term("parent", "true")));
try { try {
CheckJoinIndex.check(reader, parentsFilter); expectThrows(IllegalStateException.class, () -> CheckJoinIndex.check(reader, parentsFilter));
fail("Invalid index");
} catch (IllegalStateException e) {
// expected
} finally { } finally {
reader.close(); reader.close();
dir.close(); dir.close();
@ -128,10 +122,7 @@ public class TestCheckJoinIndex extends LuceneTestCase {
BitSetProducer parentsFilter = new QueryBitSetProducer(new TermQuery(new Term("parent", "true"))); BitSetProducer parentsFilter = new QueryBitSetProducer(new TermQuery(new Term("parent", "true")));
try { try {
CheckJoinIndex.check(reader, parentsFilter); expectThrows(IllegalStateException.class, () -> CheckJoinIndex.check(reader, parentsFilter));
fail("Invalid index");
} catch (IllegalStateException e) {
// expected
} finally { } finally {
reader.close(); reader.close();
dir.close(); dir.close();

View File

@ -169,18 +169,8 @@ public class TestQueryParser extends QueryParserTestBase {
// doesn't work for some reason. // doesn't work for some reason.
@SuppressWarnings("rawtype") @SuppressWarnings("rawtype")
public void testProtectedCtors() throws Exception { public void testProtectedCtors() throws Exception {
try { expectThrows(NoSuchMethodException.class, () -> QueryParser.class.getConstructor(CharStream.class));
QueryParser.class.getConstructor(CharStream.class); expectThrows(NoSuchMethodException.class, () -> QueryParser.class.getConstructor(QueryParserTokenManager.class));
fail("please switch public QueryParser(CharStream) to be protected");
} catch (NoSuchMethodException nsme) {
// expected
}
try {
QueryParser.class.getConstructor(QueryParserTokenManager.class);
fail("please switch public QueryParser(QueryParserTokenManager) to be protected");
} catch (NoSuchMethodException nsme) {
// expected
}
} }
public void testFuzzySlopeExtendability() throws ParseException { public void testFuzzySlopeExtendability() throws ParseException {

View File

@ -24,7 +24,15 @@ import java.util.GregorianCalendar;
import java.util.Locale; import java.util.Locale;
import java.util.TimeZone; import java.util.TimeZone;
import org.apache.lucene.analysis.*; import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.analysis.LowerCaseFilter;
import org.apache.lucene.analysis.MockAnalyzer;
import org.apache.lucene.analysis.MockSynonymFilter;
import org.apache.lucene.analysis.MockTokenFilter;
import org.apache.lucene.analysis.MockTokenizer;
import org.apache.lucene.analysis.TokenFilter;
import org.apache.lucene.analysis.TokenStream;
import org.apache.lucene.analysis.Tokenizer;
import org.apache.lucene.analysis.tokenattributes.CharTermAttribute; import org.apache.lucene.analysis.tokenattributes.CharTermAttribute;
import org.apache.lucene.analysis.tokenattributes.OffsetAttribute; import org.apache.lucene.analysis.tokenattributes.OffsetAttribute;
import org.apache.lucene.document.DateTools; import org.apache.lucene.document.DateTools;
@ -34,17 +42,27 @@ import org.apache.lucene.index.DirectoryReader;
import org.apache.lucene.index.IndexReader; import org.apache.lucene.index.IndexReader;
import org.apache.lucene.index.IndexWriter; import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.index.Term; import org.apache.lucene.index.Term;
//import org.apache.lucene.queryparser.classic.CharStream;
//import org.apache.lucene.queryparser.classic.ParseException;
//import org.apache.lucene.queryparser.classic.QueryParser;
//import org.apache.lucene.queryparser.classic.QueryParserBase;
import org.apache.lucene.queryparser.classic.QueryParser; import org.apache.lucene.queryparser.classic.QueryParser;
import org.apache.lucene.queryparser.classic.QueryParserBase; import org.apache.lucene.queryparser.classic.QueryParserBase;
//import org.apache.lucene.queryparser.classic.QueryParserTokenManager;
import org.apache.lucene.queryparser.classic.TestQueryParser; import org.apache.lucene.queryparser.classic.TestQueryParser;
import org.apache.lucene.queryparser.flexible.standard.CommonQueryParserConfiguration; import org.apache.lucene.queryparser.flexible.standard.CommonQueryParserConfiguration;
import org.apache.lucene.search.*; import org.apache.lucene.search.BooleanClause;
import org.apache.lucene.search.BooleanClause.Occur; import org.apache.lucene.search.BooleanClause.Occur;
import org.apache.lucene.search.BooleanQuery;
import org.apache.lucene.search.BoostQuery;
import org.apache.lucene.search.FuzzyQuery;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.MatchAllDocsQuery;
import org.apache.lucene.search.MatchNoDocsQuery;
import org.apache.lucene.search.MultiTermQuery;
import org.apache.lucene.search.PhraseQuery;
import org.apache.lucene.search.PrefixQuery;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.RegexpQuery;
import org.apache.lucene.search.ScoreDoc;
import org.apache.lucene.search.TermQuery;
import org.apache.lucene.search.TermRangeQuery;
import org.apache.lucene.search.WildcardQuery;
import org.apache.lucene.store.Directory; import org.apache.lucene.store.Directory;
import org.apache.lucene.util.LuceneTestCase; import org.apache.lucene.util.LuceneTestCase;
import org.apache.lucene.util.automaton.Automata; import org.apache.lucene.util.automaton.Automata;
@ -484,23 +502,16 @@ public abstract class QueryParserTestBase extends LuceneTestCase {
// Range queries: // Range queries:
assertWildcardQueryEquals("[A TO C]", "[a TO c]"); assertWildcardQueryEquals("[A TO C]", "[a TO c]");
// Test suffix queries: first disallow // Test suffix queries: first disallow
try { Exception ex = expectThrows(Exception.class, () -> {
assertWildcardQueryEquals("*Term", "*term", false); assertWildcardQueryEquals("*Term", "*term", false);
} catch(Exception pe) { });
// expected exception assertTrue(isQueryParserException(ex));
if(!isQueryParserException(pe)){
fail(); ex = expectThrows(Exception.class, () -> {
}
}
try {
assertWildcardQueryEquals("?Term", "?term"); assertWildcardQueryEquals("?Term", "?term");
fail(); });
} catch(Exception pe) { assertTrue(isQueryParserException(ex));
// expected exception
if(!isQueryParserException(pe)){
fail();
}
}
// Test suffix queries: then allow // Test suffix queries: then allow
assertWildcardQueryEquals("*Term", "*term", true); assertWildcardQueryEquals("*Term", "*term", true);
assertWildcardQueryEquals("?Term", "?term", true); assertWildcardQueryEquals("?Term", "?term", true);

View File

@ -19,6 +19,7 @@ package org.apache.lucene.replicator;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import java.nio.file.NoSuchFileException; import java.nio.file.NoSuchFileException;
import java.util.Arrays;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map.Entry; import java.util.Map.Entry;
@ -141,12 +142,9 @@ public class LocalReplicatorTest extends ReplicatorTestCase {
public void testObtainMissingFile() throws IOException { public void testObtainMissingFile() throws IOException {
replicator.publish(createRevision(1)); replicator.publish(createRevision(1));
SessionToken res = replicator.checkForUpdate(null); SessionToken res = replicator.checkForUpdate(null);
try { expectThrowsAnyOf(Arrays.asList(FileNotFoundException.class, NoSuchFileException.class), () -> {
replicator.obtainFile(res.id, res.sourceFiles.keySet().iterator().next(), "madeUpFile"); replicator.obtainFile(res.id, res.sourceFiles.keySet().iterator().next(), "madeUpFile");
fail("should have failed obtaining an unrecognized file"); });
} catch (FileNotFoundException | NoSuchFileException e) {
// expected
}
} }
@Test @Test

View File

@ -136,14 +136,9 @@ public class HttpReplicatorTest extends ReplicatorTestCase {
try { try {
publishRevision(5); publishRevision(5);
try { replicationServlet.setRespondWithError(true);
replicationServlet.setRespondWithError(true); expectThrows(Exception.class, client::updateNow);
client.updateNow();
fail("expected exception");
} catch (Throwable t) {
// expected
}
replicationServlet.setRespondWithError(false); replicationServlet.setRespondWithError(false);
client.updateNow(); // now it should work client.updateNow(); // now it should work

View File

@ -747,12 +747,7 @@ public class TestTermAutomatonQuery extends LuceneTestCase {
TermAutomatonQuery q = new TermAutomatonQuery("field"); TermAutomatonQuery q = new TermAutomatonQuery("field");
int initState = q.createState(); int initState = q.createState();
q.setAccept(initState, true); q.setAccept(initState, true);
try { expectThrows(IllegalStateException.class, q::finish);
q.finish();
fail("did not hit exc");
} catch (IllegalStateException ise) {
// expected
}
} }
public void testRewriteNoMatch() throws Exception { public void testRewriteNoMatch() throws Exception {

View File

@ -1212,14 +1212,11 @@ public class AnalyzingSuggesterTest extends LuceneTestCase {
Directory tempDir = getDirectory(); Directory tempDir = getDirectory();
AnalyzingSuggester suggester = new AnalyzingSuggester(tempDir, "suggest", a); AnalyzingSuggester suggester = new AnalyzingSuggester(tempDir, "suggest", a);
String bigString = TestUtil.randomSimpleString(random(), 30000, 30000); String bigString = TestUtil.randomSimpleString(random(), 30000, 30000);
try { IllegalArgumentException ex = expectThrows(IllegalArgumentException.class, () -> {
suggester.build(new InputArrayIterator(new Input[] { suggester.build(new InputArrayIterator(new Input[] {
new Input(bigString, 7)})); new Input(bigString, 7)}));
fail("did not hit expected exception"); });
} catch (IllegalArgumentException iae) { assertTrue(ex.getMessage().contains("input automaton is too large"));
// expected
assertTrue(iae.getMessage().contains("input automaton is too large"));
}
IOUtils.close(a, tempDir); IOUtils.close(a, tempDir);
} }

View File

@ -60,19 +60,10 @@ public class TestCompressingTermVectorsFormat extends BaseTermVectorsFormatTestC
assertNotNull(terms); assertNotNull(terms);
TermsEnum termsEnum = terms.iterator(); TermsEnum termsEnum = terms.iterator();
assertEquals(SeekStatus.FOUND, termsEnum.seekCeil(new BytesRef("this"))); assertEquals(SeekStatus.FOUND, termsEnum.seekCeil(new BytesRef("this")));
try {
termsEnum.ord(); expectThrows(UnsupportedOperationException.class, termsEnum::ord);
fail(); expectThrows(UnsupportedOperationException.class, () -> termsEnum.seekExact(0));
} catch (UnsupportedOperationException expected) {
// expected exception
}
try {
termsEnum.seekExact(0);
fail();
} catch (UnsupportedOperationException expected) {
// expected exception
}
ir.close(); ir.close();
iw.close(); iw.close();
dir.close(); dir.close();

View File

@ -54,12 +54,9 @@ public class TestHandleLimitFS extends MockFileSystemTestCase {
} }
// now exceed // now exceed
try { IOException e = expectThrows(IOException.class, () ->
Files.newOutputStream(Files.createTempFile(dir, null, null)); Files.newOutputStream(Files.createTempFile(dir, null, null)));
fail("didn't hit exception"); assertTrue(e.getMessage().contains("Too many open files"));
} catch (IOException e) {
assertTrue(e.getMessage().contains("Too many open files"));
}
IOUtils.close(toClose); IOUtils.close(toClose);
} }

View File

@ -53,37 +53,17 @@ public class TestHandleTrackingFS extends MockFileSystemTestCase {
OutputStream file = Files.newOutputStream(dir.resolve("somefile")); OutputStream file = Files.newOutputStream(dir.resolve("somefile"));
file.write(5); file.write(5);
try { expectThrows(IOException.class, file::close);
file.close();
fail("expected IOException");
} catch (IOException ex) {
// expected
}
SeekableByteChannel channel = Files.newByteChannel(dir.resolve("somefile")); SeekableByteChannel channel = Files.newByteChannel(dir.resolve("somefile"));
try { expectThrows(IOException.class, channel::close);
channel.close();
fail("expected IOException");
} catch (IOException ex) {
// expected
}
InputStream stream = Files.newInputStream(dir.resolve("somefile")); InputStream stream = Files.newInputStream(dir.resolve("somefile"));
try { expectThrows(IOException.class, stream::close);
stream.close();
fail("expected IOException");
} catch (IOException ex) {
// expected
}
fs.close(); fs.close();
DirectoryStream<Path> dirStream = Files.newDirectoryStream(dir); DirectoryStream<Path> dirStream = Files.newDirectoryStream(dir);
try { expectThrows(IOException.class, dirStream::close);
dirStream.close();
fail("expected IOException");
} catch (IOException ex) {
// expected
}
} }
@ -102,34 +82,14 @@ public class TestHandleTrackingFS extends MockFileSystemTestCase {
}.getFileSystem(URI.create("file:///")); }.getFileSystem(URI.create("file:///"));
Path dir = new FilterPath(path, fs); Path dir = new FilterPath(path, fs);
try { expectThrows(IOException.class, () -> Files.newOutputStream(dir.resolve("somefile")));
OutputStream file = Files.newOutputStream(dir.resolve("somefile"));
fail("expected IOException");
} catch (IOException ex) {
// expected
}
try { expectThrows(IOException.class, () -> Files.newByteChannel(dir.resolve("somefile")));
SeekableByteChannel channel = Files.newByteChannel(dir.resolve("somefile"));
fail("expected IOException");
} catch (IOException ex) {
// expected
}
try { expectThrows(IOException.class, () -> Files.newInputStream(dir.resolve("somefile")));
InputStream stream = Files.newInputStream(dir.resolve("somefile"));
fail("expected IOException");
} catch (IOException ex) {
// expected
}
fs.close(); fs.close();
try { expectThrows(IOException.class, () -> Files.newDirectoryStream(dir));
DirectoryStream<Path> dirStream = Files.newDirectoryStream(dir);
fail("expected IOException");
} catch (IOException ex) {
// expected
}
fs.close(); fs.close();
} }
} }

View File

@ -44,12 +44,9 @@ public class TestLeakFS extends MockFileSystemTestCase {
file.write(5); file.write(5);
file.close(); file.close();
InputStream leak = Files.newInputStream(dir.resolve("stillopen")); InputStream leak = Files.newInputStream(dir.resolve("stillopen"));
try {
dir.getFileSystem().close(); Exception e = expectThrows(Exception.class, () -> dir.getFileSystem().close());
fail("should have gotten exception"); assertTrue(e.getMessage().contains("file handle leaks"));
} catch (Exception e) {
assertTrue(e.getMessage().contains("file handle leaks"));
}
leak.close(); leak.close();
} }
@ -58,12 +55,8 @@ public class TestLeakFS extends MockFileSystemTestCase {
Path dir = wrap(createTempDir()); Path dir = wrap(createTempDir());
OutputStream leak = Files.newOutputStream(dir.resolve("leaky")); OutputStream leak = Files.newOutputStream(dir.resolve("leaky"));
try { Exception e = expectThrows(Exception.class, () -> dir.getFileSystem().close());
dir.getFileSystem().close(); assertTrue(e.getMessage().contains("file handle leaks"));
fail("should have gotten exception");
} catch (Exception e) {
assertTrue(e.getMessage().contains("file handle leaks"));
}
leak.close(); leak.close();
} }
@ -75,12 +68,9 @@ public class TestLeakFS extends MockFileSystemTestCase {
file.write(5); file.write(5);
file.close(); file.close();
FileChannel leak = FileChannel.open(dir.resolve("stillopen")); FileChannel leak = FileChannel.open(dir.resolve("stillopen"));
try {
dir.getFileSystem().close(); Exception e = expectThrows(Exception.class, () -> dir.getFileSystem().close());
fail("should have gotten exception"); assertTrue(e.getMessage().contains("file handle leaks"));
} catch (Exception e) {
assertTrue(e.getMessage().contains("file handle leaks"));
}
leak.close(); leak.close();
} }
@ -92,12 +82,8 @@ public class TestLeakFS extends MockFileSystemTestCase {
file.write(5); file.write(5);
file.close(); file.close();
AsynchronousFileChannel leak = AsynchronousFileChannel.open(dir.resolve("stillopen")); AsynchronousFileChannel leak = AsynchronousFileChannel.open(dir.resolve("stillopen"));
try { Exception e = expectThrows(Exception.class, () -> dir.getFileSystem().close());
dir.getFileSystem().close(); assertTrue(e.getMessage().contains("file handle leaks"));
fail("should have gotten exception");
} catch (Exception e) {
assertTrue(e.getMessage().contains("file handle leaks"));
}
leak.close(); leak.close();
} }
@ -109,12 +95,9 @@ public class TestLeakFS extends MockFileSystemTestCase {
file.write(5); file.write(5);
file.close(); file.close();
SeekableByteChannel leak = Files.newByteChannel(dir.resolve("stillopen")); SeekableByteChannel leak = Files.newByteChannel(dir.resolve("stillopen"));
try {
dir.getFileSystem().close(); Exception e = expectThrows(Exception.class, () -> dir.getFileSystem().close());
fail("should have gotten exception"); assertTrue(e.getMessage().contains("file handle leaks"));
} catch (Exception e) {
assertTrue(e.getMessage().contains("file handle leaks"));
}
leak.close(); leak.close();
} }
} }

View File

@ -82,10 +82,7 @@ public class TestVerboseFS extends MockFileSystemTestCase {
Files.createDirectory(dir.resolve("subdir")); Files.createDirectory(dir.resolve("subdir"));
assertTrue(stream.sawMessage()); assertTrue(stream.sawMessage());
try { expectThrows(IOException.class, () -> Files.createDirectory(dir.resolve("subdir")));
Files.createDirectory(dir.resolve("subdir"));
fail("didn't get expected exception");
} catch (IOException expected) {}
} }
/** Test delete */ /** Test delete */
@ -96,10 +93,7 @@ public class TestVerboseFS extends MockFileSystemTestCase {
Files.delete(dir.resolve("foobar")); Files.delete(dir.resolve("foobar"));
assertTrue(stream.sawMessage()); assertTrue(stream.sawMessage());
try { expectThrows(IOException.class, () -> Files.delete(dir.resolve("foobar")));
Files.delete(dir.resolve("foobar"));
fail("didn't get expected exception");
} catch (IOException expected) {}
} }
/** Test deleteIfExists */ /** Test deleteIfExists */
@ -122,10 +116,7 @@ public class TestVerboseFS extends MockFileSystemTestCase {
Files.copy(dir.resolve("foobar"), dir.resolve("baz")); Files.copy(dir.resolve("foobar"), dir.resolve("baz"));
assertTrue(stream.sawMessage()); assertTrue(stream.sawMessage());
try { expectThrows(IOException.class, () -> Files.copy(dir.resolve("nonexistent"), dir.resolve("something")));
Files.copy(dir.resolve("nonexistent"), dir.resolve("something"));
fail("didn't get expected exception");
} catch (IOException expected) {}
} }
/** Test move */ /** Test move */
@ -136,10 +127,7 @@ public class TestVerboseFS extends MockFileSystemTestCase {
Files.move(dir.resolve("foobar"), dir.resolve("baz")); Files.move(dir.resolve("foobar"), dir.resolve("baz"));
assertTrue(stream.sawMessage()); assertTrue(stream.sawMessage());
try { expectThrows(IOException.class, () -> Files.move(dir.resolve("nonexistent"), dir.resolve("something")));
Files.move(dir.resolve("nonexistent"), dir.resolve("something"));
fail("didn't get expected exception");
} catch (IOException expected) {}
} }
/** Test newOutputStream */ /** Test newOutputStream */
@ -149,11 +137,8 @@ public class TestVerboseFS extends MockFileSystemTestCase {
OutputStream file = Files.newOutputStream(dir.resolve("output")); OutputStream file = Files.newOutputStream(dir.resolve("output"));
assertTrue(stream.sawMessage()); assertTrue(stream.sawMessage());
file.close(); file.close();
try { expectThrows(IOException.class, () -> Files.newOutputStream(dir.resolve("output"), StandardOpenOption.CREATE_NEW));
Files.newOutputStream(dir.resolve("output"), StandardOpenOption.CREATE_NEW);
fail("didn't get expected exception");
} catch (IOException expected) {}
} }
/** Test FileChannel.open */ /** Test FileChannel.open */
@ -163,11 +148,9 @@ public class TestVerboseFS extends MockFileSystemTestCase {
FileChannel channel = FileChannel.open(dir.resolve("foobar"), StandardOpenOption.CREATE_NEW, StandardOpenOption.READ, StandardOpenOption.WRITE); FileChannel channel = FileChannel.open(dir.resolve("foobar"), StandardOpenOption.CREATE_NEW, StandardOpenOption.READ, StandardOpenOption.WRITE);
assertTrue(stream.sawMessage()); assertTrue(stream.sawMessage());
channel.close(); channel.close();
try { expectThrows(IOException.class, () -> FileChannel.open(dir.resolve("foobar"),
FileChannel.open(dir.resolve("foobar"), StandardOpenOption.CREATE_NEW, StandardOpenOption.READ, StandardOpenOption.WRITE); StandardOpenOption.CREATE_NEW, StandardOpenOption.READ, StandardOpenOption.WRITE));
fail("didn't get expected exception");
} catch (IOException expected) {}
} }
/** Test AsynchronousFileChannel.open */ /** Test AsynchronousFileChannel.open */
@ -177,11 +160,9 @@ public class TestVerboseFS extends MockFileSystemTestCase {
AsynchronousFileChannel channel = AsynchronousFileChannel.open(dir.resolve("foobar"), StandardOpenOption.CREATE_NEW, StandardOpenOption.READ, StandardOpenOption.WRITE); AsynchronousFileChannel channel = AsynchronousFileChannel.open(dir.resolve("foobar"), StandardOpenOption.CREATE_NEW, StandardOpenOption.READ, StandardOpenOption.WRITE);
assertTrue(stream.sawMessage()); assertTrue(stream.sawMessage());
channel.close(); channel.close();
try { expectThrows(IOException.class, () -> AsynchronousFileChannel.open(dir.resolve("foobar"),
AsynchronousFileChannel.open(dir.resolve("foobar"), StandardOpenOption.CREATE_NEW, StandardOpenOption.READ, StandardOpenOption.WRITE); StandardOpenOption.CREATE_NEW, StandardOpenOption.READ, StandardOpenOption.WRITE));
fail("didn't get expected exception");
} catch (IOException expected) {}
} }
/** Test newByteChannel */ /** Test newByteChannel */
@ -191,33 +172,16 @@ public class TestVerboseFS extends MockFileSystemTestCase {
SeekableByteChannel channel = Files.newByteChannel(dir.resolve("foobar"), StandardOpenOption.CREATE_NEW, StandardOpenOption.READ, StandardOpenOption.WRITE); SeekableByteChannel channel = Files.newByteChannel(dir.resolve("foobar"), StandardOpenOption.CREATE_NEW, StandardOpenOption.READ, StandardOpenOption.WRITE);
assertTrue(stream.sawMessage()); assertTrue(stream.sawMessage());
channel.close(); channel.close();
try { expectThrows(IOException.class, () -> Files.newByteChannel(dir.resolve("foobar"),
Files.newByteChannel(dir.resolve("foobar"), StandardOpenOption.CREATE_NEW, StandardOpenOption.READ, StandardOpenOption.WRITE); StandardOpenOption.CREATE_NEW, StandardOpenOption.READ, StandardOpenOption.WRITE));
fail("didn't get expected exception");
} catch (IOException expected) {}
} }
/** Test that verbose does not corrumpt file not found exceptions */ /** Test that verbose does not corrupt file not found exceptions */
public void testVerboseFSNoSuchFileException() throws IOException { public void testVerboseFSNoSuchFileException() {
Path dir = wrap(createTempDir()); Path dir = wrap(createTempDir());
try { expectThrows(NoSuchFileException.class, () -> AsynchronousFileChannel.open(dir.resolve("doesNotExist.rip")));
AsynchronousFileChannel.open(dir.resolve("doesNotExist.rip")); expectThrows(NoSuchFileException.class, () -> FileChannel.open(dir.resolve("doesNotExist.rip")));
fail("did not hit exception"); expectThrows(NoSuchFileException.class, () -> Files.newByteChannel(dir.resolve("stillopen")));
} catch (NoSuchFileException nsfe) {
// expected
}
try {
FileChannel.open(dir.resolve("doesNotExist.rip"));
fail("did not hit exception");
} catch (NoSuchFileException nsfe) {
// expected
}
try {
Files.newByteChannel(dir.resolve("stillopen"));
fail("did not hit exception");
} catch (NoSuchFileException nsfe) {
// expected
}
} }
} }

View File

@ -55,12 +55,9 @@ public class TestWindowsFS extends MockFileSystemTestCase {
file.write(5); file.write(5);
file.close(); file.close();
InputStream is = Files.newInputStream(dir.resolve("stillopen")); InputStream is = Files.newInputStream(dir.resolve("stillopen"));
try {
Files.delete(dir.resolve("stillopen")); IOException e = expectThrows(IOException.class, () -> Files.delete(dir.resolve("stillopen")));
fail("should have gotten exception"); assertTrue(e.getMessage().contains("access denied"));
} catch (IOException e) {
assertTrue(e.getMessage().contains("access denied"));
}
is.close(); is.close();
} }
@ -72,12 +69,9 @@ public class TestWindowsFS extends MockFileSystemTestCase {
file.write(5); file.write(5);
file.close(); file.close();
InputStream is = Files.newInputStream(dir.resolve("stillopen")); InputStream is = Files.newInputStream(dir.resolve("stillopen"));
try {
Files.deleteIfExists(dir.resolve("stillopen")); IOException e = expectThrows(IOException.class, () -> Files.deleteIfExists(dir.resolve("stillopen")));
fail("should have gotten exception"); assertTrue(e.getMessage().contains("access denied"));
} catch (IOException e) {
assertTrue(e.getMessage().contains("access denied"));
}
is.close(); is.close();
} }
@ -90,12 +84,10 @@ public class TestWindowsFS extends MockFileSystemTestCase {
file.write(5); file.write(5);
file.close(); file.close();
InputStream is = Files.newInputStream(dir.resolve("stillopen")); InputStream is = Files.newInputStream(dir.resolve("stillopen"));
try {
Files.move(dir.resolve("stillopen"), dir.resolve("target"), StandardCopyOption.ATOMIC_MOVE); IOException e = expectThrows(IOException.class, () ->
fail("should have gotten exception"); Files.move(dir.resolve("stillopen"), dir.resolve("target"), StandardCopyOption.ATOMIC_MOVE));
} catch (IOException e) { assertTrue(e.getMessage().contains("access denied"));
assertTrue(e.getMessage().contains("access denied"));
}
is.close(); is.close();
} }

View File

@ -56,14 +56,10 @@ public class TestMockDirectoryWrapper extends BaseDirectoryTestCase {
// close() to ensure the written bytes are not buffered and counted // close() to ensure the written bytes are not buffered and counted
// against the directory size // against the directory size
out.close(); out.close();
out = dir.createOutput("bar", IOContext.DEFAULT);
try { IndexOutput out2 = dir.createOutput("bar", IOContext.DEFAULT);
out.writeBytes(bytes, bytes.length); expectThrows(IOException.class, () -> out2.writeBytes(bytes, bytes.length));
fail("should have failed on disk full"); out2.close();
} catch (IOException e) {
// expected
}
out.close();
dir.close(); dir.close();
// test copyBytes // test copyBytes
@ -74,14 +70,10 @@ public class TestMockDirectoryWrapper extends BaseDirectoryTestCase {
// close() to ensure the written bytes are not buffered and counted // close() to ensure the written bytes are not buffered and counted
// against the directory size // against the directory size
out.close(); out.close();
out = dir.createOutput("bar", IOContext.DEFAULT);
try { IndexOutput out3 = dir.createOutput("bar", IOContext.DEFAULT);
out.copyBytes(new ByteArrayDataInput(bytes), bytes.length); expectThrows(IOException.class, () -> out3.copyBytes(new ByteArrayDataInput(bytes), bytes.length));
fail("should have failed on disk full"); out3.close();
} catch (IOException e) {
// expected
}
out.close();
dir.close(); dir.close();
} }

View File

@ -28,30 +28,16 @@ public class TestRunWithRestrictedPermissions extends LuceneTestCase {
} }
public void testNormallyAllowedStuff() throws Exception { public void testNormallyAllowedStuff() throws Exception {
try { expectThrows(SecurityException.class, () -> runWithRestrictedPermissions(this::doSomeForbiddenStuff));
runWithRestrictedPermissions(this::doSomeForbiddenStuff);
fail("this should not pass!");
} catch (SecurityException se) {
// pass
}
} }
public void testCompletelyForbidden1() throws Exception { public void testCompletelyForbidden1() throws Exception {
try { expectThrows(SecurityException.class, () -> runWithRestrictedPermissions(this::doSomeCompletelyForbiddenStuff));
runWithRestrictedPermissions(this::doSomeCompletelyForbiddenStuff);
fail("this should not pass!");
} catch (SecurityException se) {
// pass
}
} }
public void testCompletelyForbidden2() throws Exception { public void testCompletelyForbidden2() throws Exception {
try { expectThrows(SecurityException.class, () ->
runWithRestrictedPermissions(this::doSomeCompletelyForbiddenStuff, new AllPermission()); runWithRestrictedPermissions(this::doSomeCompletelyForbiddenStuff, new AllPermission()));
fail("this should not pass (not even with AllPermission)");
} catch (SecurityException se) {
// pass
}
} }
private Void doSomeForbiddenStuff() throws IOException { private Void doSomeForbiddenStuff() throws IOException {