mirror of https://github.com/apache/lucene.git
LUCENE-8938: use expectThrows() to verify the ex thrown in tests
This commit is contained in:
parent
1d303cee7f
commit
70a8deb0ab
|
@ -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 {
|
||||||
|
|
|
@ -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() {
|
||||||
|
|
|
@ -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]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
Loading…
Reference in New Issue