diff --git a/src/java/org/apache/poi/hssf/record/aggregates/RowRecordsAggregate.java b/src/java/org/apache/poi/hssf/record/aggregates/RowRecordsAggregate.java index 16bc385984..ea1846a384 100644 --- a/src/java/org/apache/poi/hssf/record/aggregates/RowRecordsAggregate.java +++ b/src/java/org/apache/poi/hssf/record/aggregates/RowRecordsAggregate.java @@ -293,7 +293,7 @@ public final class RowRecordsAggregate extends RecordAggregate { RowRecord rowRecord = this.getRow( row ); int level = rowRecord.getOutlineLevel(); int currentRow = row; - while (this.getRow( currentRow ) != null) { + while (currentRow >= 0 && this.getRow( currentRow ) != null) { rowRecord = this.getRow( currentRow ); if (rowRecord.getOutlineLevel() < level) { return currentRow + 1; diff --git a/src/testcases/org/apache/poi/ss/usermodel/BaseTestBugzillaIssues.java b/src/testcases/org/apache/poi/ss/usermodel/BaseTestBugzillaIssues.java index fa9f70f66b..eff708ee00 100644 --- a/src/testcases/org/apache/poi/ss/usermodel/BaseTestBugzillaIssues.java +++ b/src/testcases/org/apache/poi/ss/usermodel/BaseTestBugzillaIssues.java @@ -1274,4 +1274,18 @@ public abstract class BaseTestBugzillaIssues { wb.close(); } + + @Test + public void test50319() throws IOException { + Workbook wb = new HSSFWorkbook(); + Sheet sheet = wb.createSheet("Test"); + sheet.createRow(0); + sheet.groupRow(0, 0); + sheet.setRowGroupCollapsed(0, true); + + sheet.groupColumn(0, 0); + sheet.setColumnGroupCollapsed(0, true); + + wb.close(); + } }