LUCENE-5434: drop the merged reader if the merge was aborted, before trying to delete its files

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1566013 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Michael McCandless 2014-02-08 13:40:53 +00:00
parent b5926da2d6
commit ce4a5b9459
1 changed files with 12 additions and 1 deletions

View File

@ -3489,6 +3489,16 @@ public class IndexWriter implements Closeable, TwoPhaseCommit{
if (infoStream.isEnabled("IW")) { if (infoStream.isEnabled("IW")) {
infoStream.message("IW", "commitMerge: skip: it was aborted"); infoStream.message("IW", "commitMerge: skip: it was aborted");
} }
// In case we opened and pooled a reader for this
// segment, drop it now. This ensures that we close
// the reader before trying to delete any of its
// files. This is not a very big deal, since this
// reader will never be used by any NRT reader, and
// another thread is currently running close(false)
// so it will be dropped shortly anyway, but not
// doing this makes MockDirWrapper angry in
// TestNRTThreads (LUCENE-5434):
readerPool.drop(merge.info);
deleter.deleteNewFiles(merge.info.files()); deleter.deleteNewFiles(merge.info.files());
return false; return false;
} }
@ -4186,7 +4196,8 @@ public class IndexWriter implements Closeable, TwoPhaseCommit{
// Force READ context because we merge deletes onto // Force READ context because we merge deletes onto
// this reader: // this reader:
if (!commitMerge(merge, mergeState)) { if (!commitMerge(merge, mergeState)) {
// commitMerge will return false if this merge was aborted // commitMerge will return false if this merge was
// aborted
return 0; return 0;
} }