Skip to content

Commit

Permalink
Added test for deep nested object and array combination
Browse files Browse the repository at this point in the history
Fixing the issue (opensearch-project#5195)

Signed-off-by: Nikhil Kumar <[email protected]>
  • Loading branch information
Nikhil Kumar committed Feb 8, 2023
1 parent 327ee9f commit d45b0eb
Showing 1 changed file with 41 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -1597,4 +1597,45 @@ public void testDocumentContainsDeepNestedFieldParsingShouldFail() throws Except
assertNotNull(update); // dynamic mapping update

}

// Test nesting upto max allowed depth with combination of nesting in object and array
// object -> array -> object -> array ....
public void testDocumentDeepNestedObjectAndArrayCombination() throws Exception {
DocumentMapper mapper = createDocumentMapper(mapping(b -> {}));
long depth_limit = MapperService.INDEX_MAPPING_DEPTH_LIMIT_SETTING.getDefault(Settings.EMPTY);
MapperParsingException e = expectThrows(MapperParsingException.class, () -> mapper.parse(source(b -> {
for (int i = 1; i < depth_limit; i++) {
b.startArray("foo" + 1);
b.startObject();
}
b.startArray("bar");
b.startArray().value(0).value(0).endArray();
b.endArray();
for (int i = 1; i < depth_limit; i++) {
b.endObject();
b.endArray();
}
})));

// check parsing success for nested array within allowed depth limit
ParsedDocument doc = mapper.parse(source(b -> {
for (int i = 1; i < depth_limit - 1; i++) {
b.startArray("foo" + 1);
b.startObject();
}
b.startArray("bar");
b.startArray().value(0).value(0).endArray();
b.endArray();
for (int i = 1; i < depth_limit - 1; i++) {
b.endObject();
b.endArray();
}
}

));
Mapping update = doc.dynamicMappingsUpdate();
assertNotNull(update); // dynamic mapping update

}

}

0 comments on commit d45b0eb

Please sign in to comment.