Add test to verify bug 69266

We could not reproduce the reported issue,
this test verifies this the functionality
some more now.

git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1921982 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Dominik Stadler 2024-11-20 20:29:49 +00:00
parent 7c881a408f
commit c17d78a182
1 changed files with 42 additions and 10 deletions

View File

@ -21,12 +21,20 @@ import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertFalse; import static org.junit.jupiter.api.Assertions.assertFalse;
import static org.junit.jupiter.api.Assertions.assertTrue; import static org.junit.jupiter.api.Assertions.assertTrue;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import org.apache.poi.ss.usermodel.PageOrder; import org.apache.poi.ss.usermodel.PageOrder;
import org.apache.poi.ss.usermodel.PaperSize; import org.apache.poi.ss.usermodel.PaperSize;
import org.apache.poi.ss.usermodel.PrintCellComments; import org.apache.poi.ss.usermodel.PrintCellComments;
import org.apache.poi.ss.usermodel.PrintOrientation; import org.apache.poi.ss.usermodel.PrintOrientation;
import org.apache.poi.ss.usermodel.PrintSetup;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.WorkbookFactory;
import org.apache.poi.xssf.XSSFITestDataProvider; import org.apache.poi.xssf.XSSFITestDataProvider;
import org.junit.jupiter.api.Disabled; import org.apache.poi.xssf.XSSFTestDataSamples;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPageMargins; import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPageMargins;
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPageSetup; import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTPageSetup;
@ -287,15 +295,6 @@ class TestXSSFPrintSetup {
wb.close(); wb.close();
} }
/**
* Open a file with print settings, save and check.
* Then, change, save, read, check
*/
@Disabled
void testRoundTrip() {
// TODO
}
@Test @Test
void testSetLandscapeFalse() { void testSetLandscapeFalse() {
XSSFPrintSetup ps = new XSSFPrintSetup(CTWorksheet.Factory.newInstance()); XSSFPrintSetup ps = new XSSFPrintSetup(CTWorksheet.Factory.newInstance());
@ -321,4 +320,37 @@ class TestXSSFPrintSetup {
ps.setLeftToRight(false); ps.setLeftToRight(false);
assertFalse(ps.getLeftToRight()); assertFalse(ps.getLeftToRight());
} }
@Test
public void test69266() throws IOException {
byte[] bytes;
try (Workbook workbook = XSSFTestDataSamples.openSampleWorkbook("sample.xlsx")) {
Sheet sheet = workbook.getSheetAt(0);
// Set Fit to Page options
sheet.setFitToPage(true);
PrintSetup printSetup = sheet.getPrintSetup();
printSetup.setFitWidth((short) 1); // Fit to 1 page wide
printSetup.setFitHeight((short) 2); // Fit to 1 page tall
// Write the modified workbook out
try (ByteArrayOutputStream fos = new ByteArrayOutputStream()) {
workbook.write(fos);
fos.flush();
bytes = fos.toByteArray();
}
}
// verify that information is written out and read in properly again
try (Workbook workbook = WorkbookFactory.create(new ByteArrayInputStream(bytes))) {
Sheet sheet = workbook.getSheetAt(0);
// verify Fit to Page options
assertTrue(sheet.getFitToPage());
PrintSetup printSetup = sheet.getPrintSetup();
assertEquals(1, printSetup.getFitWidth());
assertEquals(2, printSetup.getFitHeight());
}
}
} }