Skip to content

Commit

Permalink
Fix log message when unable to find a reference id for a document (op…
Browse files Browse the repository at this point in the history
…ensearch-project#1187)

* Fix log message when unable to find a reference id for a document

We were incorrectly reporting documents that were missing a reference id
as an error message whereas this is on par with a missing source body at
warning level.

Updated the error message to include slightly more context for
troubleshooting.

- Lower logging level when there is no usable reference idenifiers
- Add the directory path in logging messages from troubleshooting
- Rename docId -> docSegId since it represents the position of the
  document as opposed to he other identifiers to improve readability

* Disable testDocumentBuffering failures, tracking with MIGRATIONS-2254

Signed-off-by: Peter Nied <peternied@hotmail.com>
  • Loading branch information
peternied authored Dec 9, 2024
1 parent fc62f57 commit 99bd50b
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
import org.apache.lucene.index.IndexWriterConfig;
import org.apache.lucene.store.ByteBuffersDirectory;
import org.apache.lucene.util.BytesRef;
import org.junit.jupiter.api.Disabled;
import org.junit.jupiter.api.Tag;
import org.junit.jupiter.api.Test;
import reactor.core.publisher.Mono;
Expand All @@ -36,6 +37,7 @@
import static org.mockito.Mockito.when;

@Slf4j
@Disabled("https://opensearch.atlassian.net/browse/MIGRATIONS-2254")
public class PerformanceVerificationTest {

@Test
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -161,13 +161,17 @@ protected DirectoryReader wrapReader(DirectoryReader reader, boolean softDeletes
return reader;
}

protected RfsLuceneDocument getDocument(IndexReader reader, int docId, boolean isLive) {
protected RfsLuceneDocument getDocument(IndexReader reader, int docSegId, boolean isLive) {
Document document;
try {
document = reader.document(docId);
document = reader.document(docSegId);
} catch (IOException e) {
log.atError().setCause(e).setMessage("Failed to read document at Lucene index location {}")
.addArgument(docId).log();
log.atError()
.setCause(e)
.setMessage("Failed to read document segment id {} from source {}")
.addArgument(docSegId)
.addArgument(indexDirectoryPath)
.log();
return null;
}

Expand Down Expand Up @@ -207,18 +211,21 @@ protected RfsLuceneDocument getDocument(IndexReader reader, int docId, boolean i
}
}
if (id == null) {
log.atError().setMessage("Document with index {} does not have an id. Skipping")
.addArgument(docId).log();
log.atWarn().setMessage("Skipping document segment id {} from source {}, it does not have an referenceable id.")
.addArgument(docSegId)
.addArgument(indexDirectoryPath)
.log();
return null; // Skip documents with missing id
}

if (sourceBytes == null || sourceBytes.bytes.length == 0) {
log.atWarn().setMessage("Document {} doesn't have the _source field enabled")
.addArgument(id).log();
log.atWarn().setMessage("Skipping document segment id {} document id {} from source {}, it doesn't have the _source field enabled.")
.addArgument(docSegId)
.addArgument(id)
.addArgument(indexDirectoryPath)
.log();
return null; // Skip these
}

log.atDebug().setMessage("Reading document {}").addArgument(id).log();
} catch (RuntimeException e) {
StringBuilder errorMessage = new StringBuilder();
errorMessage.append("Unable to parse Document id from Document. The Document's Fields: ");
Expand All @@ -232,7 +239,10 @@ protected RfsLuceneDocument getDocument(IndexReader reader, int docId, boolean i
return null; // Skip these
}

log.atDebug().setMessage("Document {} read successfully").addArgument(id).log();
log.atDebug().setMessage("Document id {} from source {} read successfully.")
.addArgument(id)
.addArgument(indexDirectoryPath)
.log();
return new RfsLuceneDocument(id, type, sourceBytes.utf8ToString(), routing);
}
}

0 comments on commit 99bd50b

Please sign in to comment.