aboutsummaryrefslogtreecommitdiffstats
path: root/src/testcases
diff options
context:
space:
mode:
Diffstat (limited to 'src/testcases')
-rw-r--r--src/testcases/org/apache/poi/ss/usermodel/BaseTestSheetShiftRows.java26
-rw-r--r--src/testcases/org/apache/poi/ss/usermodel/BaseTestWorkbook.java6
-rw-r--r--src/testcases/org/apache/poi/ss/usermodel/TestExcelStyleDateFormatter.java127
-rw-r--r--src/testcases/org/apache/poi/ss/util/TestDateFormatConverter.java138
-rw-r--r--src/testcases/org/apache/poi/ss/util/TestExpandedDouble.java50
-rw-r--r--src/testcases/org/apache/poi/ss/util/TestNumberComparer.java22
-rw-r--r--src/testcases/org/apache/poi/ss/util/TestSheetUtil.java3
-rw-r--r--src/testcases/org/apache/poi/util/TestHexDump.java25
-rw-r--r--src/testcases/org/apache/poi/util/TestIOUtils.java12
9 files changed, 180 insertions, 229 deletions
diff --git a/src/testcases/org/apache/poi/ss/usermodel/BaseTestSheetShiftRows.java b/src/testcases/org/apache/poi/ss/usermodel/BaseTestSheetShiftRows.java
index 4e93a62156..67d351bffc 100644
--- a/src/testcases/org/apache/poi/ss/usermodel/BaseTestSheetShiftRows.java
+++ b/src/testcases/org/apache/poi/ss/usermodel/BaseTestSheetShiftRows.java
@@ -19,6 +19,7 @@ package org.apache.poi.ss.usermodel;
import static org.apache.poi.POITestCase.skipTest;
import static org.apache.poi.POITestCase.testPassesNow;
+import static org.junit.jupiter.api.Assertions.assertDoesNotThrow;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;
@@ -124,12 +125,12 @@ public abstract class BaseTestSheetShiftRows {
*/
@Test
public final void testShiftRow() throws IOException {
- Workbook wb = _testDataProvider.createWorkbook();
- Sheet s = wb.createSheet();
- s.createRow(0).createCell(0).setCellValue("TEST1");
- s.createRow(3).createCell(0).setCellValue("TEST2");
- s.shiftRows(0,4,1);
- wb.close();
+ try (Workbook wb = _testDataProvider.createWorkbook()) {
+ Sheet s = wb.createSheet();
+ s.createRow(0).createCell(0).setCellValue("TEST1");
+ s.createRow(3).createCell(0).setCellValue("TEST2");
+ assertDoesNotThrow(() -> s.shiftRows(0, 4, 1));
+ }
}
/**
@@ -491,13 +492,12 @@ public abstract class BaseTestSheetShiftRows {
@Test
void test47169() throws IOException {
- Workbook wb = _testDataProvider.createWorkbook();
- Sheet sheet = wb.createSheet();
- sheet.createRow(30);
- sheet.shiftRows(29, 29, 1, true, true);
- sheet.createRow(30);
-
- wb.close();
+ try (Workbook wb = _testDataProvider.createWorkbook()) {
+ Sheet sheet = wb.createSheet();
+ sheet.createRow(30);
+ sheet.shiftRows(29, 29, 1, true, true);
+ assertDoesNotThrow(() -> sheet.createRow(30));
+ }
}
/**
diff --git a/src/testcases/org/apache/poi/ss/usermodel/BaseTestWorkbook.java b/src/testcases/org/apache/poi/ss/usermodel/BaseTestWorkbook.java
index 6de40bb4b4..11bb3c9357 100644
--- a/src/testcases/org/apache/poi/ss/usermodel/BaseTestWorkbook.java
+++ b/src/testcases/org/apache/poi/ss/usermodel/BaseTestWorkbook.java
@@ -18,6 +18,7 @@
package org.apache.poi.ss.usermodel;
import static org.junit.jupiter.api.Assertions.assertArrayEquals;
+import static org.junit.jupiter.api.Assertions.assertDoesNotThrow;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertFalse;
import static org.junit.jupiter.api.Assertions.assertNotNull;
@@ -765,8 +766,7 @@ public abstract class BaseTestWorkbook {
@Test
void test58499() throws IOException {
- try (Workbook workbook = _testDataProvider.createWorkbook();
- OutputStream os = new NullOutputStream()) {
+ try (Workbook workbook = _testDataProvider.createWorkbook()) {
Sheet sheet = workbook.createSheet();
for (int i = 0; i < 900; i++) {
Row r = sheet.createRow(i);
@@ -775,7 +775,7 @@ public abstract class BaseTestWorkbook {
c.setCellStyle(cs);
c.setCellValue("AAA");
}
- workbook.write(os);
+ assertDoesNotThrow(() -> workbook.write(new NullOutputStream()));
}
}
diff --git a/src/testcases/org/apache/poi/ss/usermodel/TestExcelStyleDateFormatter.java b/src/testcases/org/apache/poi/ss/usermodel/TestExcelStyleDateFormatter.java
index fd904ab1b5..e27557e9b9 100644
--- a/src/testcases/org/apache/poi/ss/usermodel/TestExcelStyleDateFormatter.java
+++ b/src/testcases/org/apache/poi/ss/usermodel/TestExcelStyleDateFormatter.java
@@ -17,6 +17,7 @@
package org.apache.poi.ss.usermodel;
+import static org.junit.jupiter.api.Assertions.assertDoesNotThrow;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;
import static org.junit.jupiter.api.Assertions.assertTrue;
@@ -25,6 +26,7 @@ import java.text.DateFormatSymbols;
import java.text.FieldPosition;
import java.text.ParseException;
import java.text.SimpleDateFormat;
+import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
@@ -35,111 +37,88 @@ import java.util.stream.Stream;
import org.apache.poi.util.LocaleUtil;
import org.junit.jupiter.api.Test;
+import org.junit.jupiter.params.ParameterizedTest;
+import org.junit.jupiter.params.provider.Arguments;
+import org.junit.jupiter.params.provider.MethodSource;
class TestExcelStyleDateFormatter {
private static final String EXCEL_DATE_FORMAT = "MMMMM";
private static final SimpleDateFormat DATE_FORMAT = new SimpleDateFormat("yyyy-MM-dd", Locale.ROOT);
- private final int jreVersion;
-
- public TestExcelStyleDateFormatter() {
- jreVersion = Integer.parseInt(System.getProperty("java.version")
- .replace("1.8", "8").replaceAll("(\\d+).*", "$1"));
- }
+ private static final int jreVersion =
+ Integer.parseInt(System.getProperty("java.version").replaceAll("^(?:1\\.)?(\\d+).*", "$1"));
+ private static final String provider = System.getProperty("java.locale.providers");
+ private static final FieldPosition fp = new FieldPosition(java.text.DateFormat.MONTH_FIELD);
+ private static final ExcelStyleDateFormatter formatter = new ExcelStyleDateFormatter(EXCEL_DATE_FORMAT);
/**
* [Bug 60369] Month format 'MMMMM' issue with TEXT-formula and Java 8
*/
- @Test
- void test60369() {
- Map<Locale, String> testMap = initializeLocales();
-
- // We have to set up dates as well.
- List<Date> testDates = Stream.of("1980-01-12", "1995-02-11", "2045-03-10", "2016-04-09", "2017-05-08",
- "1945-06-07", "1998-07-06", "2099-08-05", "1988-09-04", "2023-10-03", "1978-11-02", "1890-12-01")
- .map(this::parseDate).collect(Collectors.toList());
-
+ @ParameterizedTest
+ @MethodSource("initializeLocales")
+ void test60369(Locale locale, String expected, Date d, int month) {
// Let's iterate over the test setup.
- final String provider = System.getProperty("java.locale.providers");
- final FieldPosition fp = new FieldPosition(java.text.DateFormat.MONTH_FIELD);
- final ExcelStyleDateFormatter formatter = new ExcelStyleDateFormatter(EXCEL_DATE_FORMAT);
final StringBuffer sb = new StringBuffer();
- for (Map.Entry<Locale,String> me : testMap.entrySet()) {
- final Locale locale = me.getKey();
- final String expected = me.getValue();
- formatter.setDateFormatSymbols(DateFormatSymbols.getInstance(locale));
- int month = 0;
- for (Date d : testDates) {
- sb.setLength(0);
- String result = formatter.format(d, sb, fp).toString();
- String msg = "Failed testDates for locale " + locale + ", provider: " + provider +
- " and date " + d + ", having: " + result;
-
- int actIdx = localeIndex(locale);
-
- assertNotNull(result, msg);
- assertTrue(result.length() > actIdx, msg);
- assertEquals(expected.charAt(month), result.charAt(actIdx), msg);
- month++;
- }
- }
+ formatter.setDateFormatSymbols(DateFormatSymbols.getInstance(locale));
+ String result = formatter.format(d, sb, fp).toString();
+ String msg = "Failed testDates for locale " + locale + ", provider: " + provider +
+ " and date " + d + ", having: " + result;
+
+ int actIdx = localeIndex(locale);
+
+ assertNotNull(result, msg);
+ assertTrue(result.length() > actIdx, msg);
+ assertEquals(expected.charAt(month), result.charAt(actIdx), msg);
}
/**
* Depending on the JRE version, the provider setting and the locale, a different result
* is expected and selected via an index
*/
- private int localeIndex(Locale locale) {
- final String provider = System.getProperty("java.locale.providers");
+ private static int localeIndex(Locale locale) {
return jreVersion < 9 ||
!locale.equals (Locale.CHINESE) ||
(provider != null && (provider.startsWith("JRE") || provider.startsWith("COMPAT")))
? 0 : 1;
}
- private Date parseDate(String dateStr) {
- try {
- return DATE_FORMAT.parse(dateStr);
- } catch (ParseException e) {
- return new Date(0);
- }
- }
-
/**
* Setting up the locale to be tested together with a list of asserted
* unicode-formatted results and put them in a map.
*/
- private Map<Locale, String> initializeLocales() {
- Map<Locale, String> testMap = new HashMap<>();
-
- testMap.put(Locale.GERMAN, "JFMAMJJASOND");
- testMap.put(new Locale("de", "AT"), "JFMAMJJASOND");
- testMap.put(Locale.UK, "JFMAMJJASOND");
- testMap.put(new Locale("en", "IN"), "JFMAMJJASOND");
- testMap.put(new Locale("in", "ID"), "JFMAMJJASOND");
- testMap.put(Locale.FRENCH, "jfmamjjasond");
-
- testMap.put(new Locale("ru", "RU"),
- "\u044f\u0444\u043c\u0430\u043c\u0438\u0438\u0430\u0441\u043e\u043d\u0434");
-
- testMap.put(Locale.CHINESE, new String[]{
- "\u4e00\u4e8c\u4e09\u56db\u4e94\u516d\u4e03\u516b\u4e5d\u5341\u5341\u5341",
- "123456789111"
- }[localeIndex(Locale.CHINESE)]);
-
- testMap.put(new Locale("tr", "TR"),
- "\u004f\u015e\u004d\u004e\u004d\u0048\u0054\u0041\u0045\u0045\u004b\u0041");
-
- testMap.put(new Locale("hu", "HU"),
- "\u006a\u0066\u006d\u00e1\u006d\u006a\u006a\u0061\u0073\u006f\u006e\u0064");
-
- return testMap;
+ public static Stream<Arguments> initializeLocales() throws ParseException {
+ Object[][] locExps = {
+ { Locale.GERMAN, "JFMAMJJASOND" },
+ { new Locale("de", "AT"), "JFMAMJJASOND" },
+ { Locale.UK, "JFMAMJJASOND" },
+ { new Locale("en", "IN"), "JFMAMJJASOND" },
+ { new Locale("in", "ID"), "JFMAMJJASOND" },
+ { Locale.FRENCH, "jfmamjjasond" },
+ { new Locale("ru", "RU"), "\u044f\u0444\u043c\u0430\u043c\u0438\u0438\u0430\u0441\u043e\u043d\u0434" },
+ { Locale.CHINESE, localeIndex(Locale.CHINESE) == 0 ? "\u4e00\u4e8c\u4e09\u56db\u4e94\u516d\u4e03\u516b\u4e5d\u5341\u5341\u5341" : "123456789111" },
+ { new Locale("tr", "TR"), "\u004f\u015e\u004d\u004e\u004d\u0048\u0054\u0041\u0045\u0045\u004b\u0041" },
+ { new Locale("hu", "HU"), "\u006a\u0066\u006d\u00e1\u006d\u006a\u006a\u0061\u0073\u006f\u006e\u0064" }
+ };
+
+ String[] dates = {
+ "1980-01-12", "1995-02-11", "2045-03-10", "2016-04-09", "2017-05-08",
+ "1945-06-07", "1998-07-06", "2099-08-05", "1988-09-04", "2023-10-03", "1978-11-02", "1890-12-01"
+ };
+
+ List<Arguments> list = new ArrayList<>(locExps.length * dates.length);
+ for (Object[] locExp : locExps) {
+ int month = 0;
+ for (String date : dates) {
+ list.add(Arguments.of(locExp[0], locExp[1], DATE_FORMAT.parse(date), month++));
+ }
+ }
+ return list.stream();
}
@Test
void testConstruct() {
- new ExcelStyleDateFormatter(EXCEL_DATE_FORMAT, LocaleUtil.getUserLocale());
- new ExcelStyleDateFormatter(EXCEL_DATE_FORMAT);
+ assertDoesNotThrow(() -> new ExcelStyleDateFormatter(EXCEL_DATE_FORMAT, LocaleUtil.getUserLocale()));
+ assertDoesNotThrow(() -> new ExcelStyleDateFormatter(EXCEL_DATE_FORMAT));
}
@Test
diff --git a/src/testcases/org/apache/poi/ss/util/TestDateFormatConverter.java b/src/testcases/org/apache/poi/ss/util/TestDateFormatConverter.java
index 3113bc95e9..00697bbdb4 100644
--- a/src/testcases/org/apache/poi/ss/util/TestDateFormatConverter.java
+++ b/src/testcases/org/apache/poi/ss/util/TestDateFormatConverter.java
@@ -19,6 +19,9 @@
package org.apache.poi.ss.util;
+import static java.text.DateFormat.getDateInstance;
+import static java.text.DateFormat.getDateTimeInstance;
+import static java.text.DateFormat.getTimeInstance;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;
@@ -45,22 +48,34 @@ import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.util.LocaleID;
+import org.apache.poi.util.NullOutputStream;
import org.apache.poi.util.TempFile;
import org.junit.jupiter.api.Test;
+import org.junit.jupiter.params.ParameterizedTest;
+import org.junit.jupiter.params.provider.CsvSource;
final class TestDateFormatConverter {
- private void outputLocaleDataFormats( Date date, boolean dates, boolean times, int style, String styleName ) throws Exception {
+ @ParameterizedTest
+ @CsvSource({
+ "true, false, " + DateFormat.DEFAULT + ", Default",
+ "true, false, " + DateFormat.SHORT + ", Short",
+ "true, false, " + DateFormat.MEDIUM + ", Medium",
+ "true, false, " + DateFormat.LONG + ", Long",
+ "true, false, " + DateFormat.FULL + ", Full",
+ "true, true, " + DateFormat.DEFAULT + ", Default",
+ "true, true, " + DateFormat.SHORT + ", Short",
+ "true, true, " + DateFormat.MEDIUM + ", Medium",
+ "true, true, " + DateFormat.LONG + ", Long",
+ "true, true, " + DateFormat.FULL + ", Full",
+ "false, true, " + DateFormat.DEFAULT + ", Default",
+ "false, true, " + DateFormat.SHORT + ", Short",
+ "false, true, " + DateFormat.MEDIUM + ", Medium",
+ "false, true, " + DateFormat.LONG + ", Long",
+ "false, true, " + DateFormat.FULL + ", Full"
+ })
+ void testJavaDateFormatsInExcel(boolean dates, boolean times, int style, String styleName ) throws Exception {
try (Workbook workbook = new HSSFWorkbook()) {
- String sheetName;
- if (dates) {
- if (times) {
- sheetName = "DateTimes";
- } else {
- sheetName = "Dates";
- }
- } else {
- sheetName = "Times";
- }
+ String sheetName = (dates) ? ((times) ? "DateTimes" : "Dates") : "Times";
Sheet sheet = workbook.createSheet(sheetName);
Row header = sheet.createRow(0);
header.createCell(0).setCellValue("locale");
@@ -73,90 +88,51 @@ final class TestDateFormatConverter {
int rowNum = 1;
for (Locale locale : DateFormat.getAvailableLocales()) {
- try {
- Row row = sheet.createRow(rowNum++);
-
- row.createCell(0).setCellValue(locale.toString());
- row.createCell(1).setCellValue(locale.getDisplayName(Locale.ROOT));
-
- DateFormat dateFormat;
- if (dates) {
- if (times) {
- dateFormat = DateFormat.getDateTimeInstance(style, style, locale);
- } else {
- dateFormat = DateFormat.getDateInstance(style, locale);
- }
- } else {
- dateFormat = DateFormat.getTimeInstance(style, locale);
- }
-
- Cell cell = row.createCell(2);
-
- cell.setCellValue(date);
- CellStyle cellStyle = row.getSheet().getWorkbook().createCellStyle();
-
- String javaDateFormatPattern = ((SimpleDateFormat) dateFormat).toPattern();
- String excelFormatPattern = DateFormatConverter.convert(locale, javaDateFormatPattern);
-
- DataFormat poiFormat = row.getSheet().getWorkbook().createDataFormat();
- cellStyle.setDataFormat(poiFormat.getFormat(excelFormatPattern));
- row.createCell(3).setCellValue(dateFormat.format(date));
-
- cell.setCellStyle(cellStyle);
-
- // the formula returns TRUE is the formatted date in column C equals to the string in column D
- row.createCell(4).setCellFormula("TEXT(C" + rowNum + ",G" + rowNum + ")=D" + rowNum);
- row.createCell(5).setCellValue(javaDateFormatPattern);
- row.createCell(6).setCellValue(excelFormatPattern);
- } catch (Exception e) {
- throw new RuntimeException(
- "Failed for locale: " + locale + " and style " + style + "\n" +
- "Having locales: " + Arrays.toString(DateFormat.getAvailableLocales()), e);
- }
- }
+ Row row = sheet.createRow(rowNum++);
+
+ row.createCell(0).setCellValue(locale.toString());
+ row.createCell(1).setCellValue(locale.getDisplayName(Locale.ROOT));
+
+ DateFormat dateFormat = (dates)
+ ? (times ? getDateTimeInstance(style, style, locale) : getDateInstance(style, locale))
+ : getTimeInstance(style, locale);
+
+ Cell cell = row.createCell(2);
+ Date date = new Date();
+ cell.setCellValue(date);
+ CellStyle cellStyle = row.getSheet().getWorkbook().createCellStyle();
- File outputFile = TempFile.createTempFile("Locale" + sheetName + styleName, ".xlsx");
- try (FileOutputStream outputStream = new FileOutputStream(outputFile)) {
- workbook.write(outputStream);
+ String javaDateFormatPattern = ((SimpleDateFormat) dateFormat).toPattern();
+ String excelFormatPattern = DateFormatConverter.convert(locale, javaDateFormatPattern);
+
+ DataFormat poiFormat = row.getSheet().getWorkbook().createDataFormat();
+ cellStyle.setDataFormat(poiFormat.getFormat(excelFormatPattern));
+ row.createCell(3).setCellValue(dateFormat.format(date));
+
+ cell.setCellStyle(cellStyle);
+
+ // the formula returns TRUE is the formatted date in column C equals to the string in column D
+ row.createCell(4).setCellFormula("TEXT(C" + rowNum + ",G" + rowNum + ")=D" + rowNum);
+ row.createCell(5).setCellValue(javaDateFormatPattern);
+ row.createCell(6).setCellValue(excelFormatPattern);
}
- //System.out.println("Open " + outputFile.getAbsolutePath() + " in Excel");
+ workbook.write(new NullOutputStream());
}
}
@Test
- void testJavaDateFormatsInExcel() throws Exception {
- Date date = new Date();
-
- outputLocaleDataFormats(date, true, false, DateFormat.DEFAULT, "Default" );
- outputLocaleDataFormats(date, true, false, DateFormat.SHORT, "Short" );
- outputLocaleDataFormats(date, true, false, DateFormat.MEDIUM, "Medium" );
- outputLocaleDataFormats(date, true, false, DateFormat.LONG, "Long" );
- outputLocaleDataFormats(date, true, false, DateFormat.FULL, "Full" );
-
- outputLocaleDataFormats(date, true, true, DateFormat.DEFAULT, "Default" );
- outputLocaleDataFormats(date, true, true, DateFormat.SHORT, "Short" );
- outputLocaleDataFormats(date, true, true, DateFormat.MEDIUM, "Medium" );
- outputLocaleDataFormats(date, true, true, DateFormat.LONG, "Long" );
- outputLocaleDataFormats(date, true, true, DateFormat.FULL, "Full" );
-
- outputLocaleDataFormats(date, false, true, DateFormat.DEFAULT, "Default" );
- outputLocaleDataFormats(date, false, true, DateFormat.SHORT, "Short" );
- outputLocaleDataFormats(date, false, true, DateFormat.MEDIUM, "Medium" );
- outputLocaleDataFormats(date, false, true, DateFormat.LONG, "Long" );
- outputLocaleDataFormats(date, false, true, DateFormat.FULL, "Full" );
- }
-
- @Test
void testJDK8EmptyLocale() {
// JDK 8 seems to add an empty locale-string to the list returned via DateFormat.getAvailableLocales()
// therefore we now cater for this special locale as well
- DateFormatConverter.getPrefixForLocale(new Locale(""));
+ String prefix = DateFormatConverter.getPrefixForLocale(new Locale(""));
+ assertEquals("", prefix);
}
@Test
void testJDK11MyLocale() {
- DateFormat.getDateTimeInstance(DateFormat.DEFAULT, DateFormat.DEFAULT, Locale.forLanguageTag("my"));
+ DateFormat df = getDateTimeInstance(DateFormat.DEFAULT, DateFormat.DEFAULT, Locale.forLanguageTag("my"));
+ assertNotNull(df);
}
@Test
diff --git a/src/testcases/org/apache/poi/ss/util/TestExpandedDouble.java b/src/testcases/org/apache/poi/ss/util/TestExpandedDouble.java
index 30f84a3eb7..9465619b79 100644
--- a/src/testcases/org/apache/poi/ss/util/TestExpandedDouble.java
+++ b/src/testcases/org/apache/poi/ss/util/TestExpandedDouble.java
@@ -24,6 +24,8 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
import java.math.BigInteger;
import org.junit.jupiter.api.Test;
+import org.junit.jupiter.params.ParameterizedTest;
+import org.junit.jupiter.params.provider.ValueSource;
/**
* Tests for {@link ExpandedDouble}
@@ -54,33 +56,27 @@ final class TestExpandedDouble {
/**
* Tests specific values for conversion from {@link ExpandedDouble} to {@link NormalisedDecimal} and back
*/
- @Test
- void testRoundTripShifting() {
- long[] rawValues = {
- 0x4010000000000004L,
- 0x7010000000000004L,
- 0x1010000000000004L,
- 0x0010000000000001L, // near lowest normal number
- 0x0010000000000000L, // lowest normal number
- 0x000FFFFFFFFFFFFFL, // highest subnormal number
- 0x0008000000000000L, // subnormal number
-
- 0xC010000000000004L,
- 0xE230100010001004L,
- 0x403CE0FFFFFFFFF2L,
- 0x0000000000000001L, // smallest non-zero number (subnormal)
- 0x6230100010000FFEL,
- 0x6230100010000FFFL,
- 0x6230100010001000L,
- 0x403CE0FFFFFFFFF0L, // has single digit round trip error
- 0x2B2BFFFF10001079L,
- };
- for (int i = 0; i < rawValues.length; i++) {
- confirmRoundTrip(i, rawValues[i]);
- }
- }
-
- public static void confirmRoundTrip(int i, long rawBitsA) {
+ @ParameterizedTest
+ @ValueSource(longs = {
+ 0x4010000000000004L,
+ 0x7010000000000004L,
+ 0x1010000000000004L,
+ 0x0010000000000001L, // near lowest normal number
+ 0x0010000000000000L, // lowest normal number
+ 0x000FFFFFFFFFFFFFL, // highest subnormal number
+ 0x0008000000000000L, // subnormal number
+
+ 0xC010000000000004L,
+ 0xE230100010001004L,
+ 0x403CE0FFFFFFFFF2L,
+ 0x0000000000000001L, // smallest non-zero number (subnormal)
+ 0x6230100010000FFEL,
+ 0x6230100010000FFFL,
+ 0x6230100010001000L,
+ 0x403CE0FFFFFFFFF0L, // has single digit round trip error
+ 0x2B2BFFFF10001079L,
+ })
+ void confirmRoundTrip(long rawBitsA) {
double a = Double.longBitsToDouble(rawBitsA);
if (a == 0.0) {
// Can't represent 0.0 or -0.0 with NormalisedDecimal
diff --git a/src/testcases/org/apache/poi/ss/util/TestNumberComparer.java b/src/testcases/org/apache/poi/ss/util/TestNumberComparer.java
index 42a0edd841..225d9f835c 100644
--- a/src/testcases/org/apache/poi/ss/util/TestNumberComparer.java
+++ b/src/testcases/org/apache/poi/ss/util/TestNumberComparer.java
@@ -17,6 +17,7 @@
package org.apache.poi.ss.util;
+import static org.junit.jupiter.api.Assertions.assertDoesNotThrow;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotEquals;
import static org.junit.jupiter.api.Assertions.assertTrue;
@@ -24,6 +25,8 @@ import static org.junit.jupiter.api.Assertions.assertTrue;
import org.apache.poi.ss.util.NumberComparisonExamples.ComparisonExample;
import org.apache.poi.util.HexDump;
import org.junit.jupiter.api.Test;
+import org.junit.jupiter.params.ParameterizedTest;
+import org.junit.jupiter.params.provider.MethodSource;
/**
* Tests for {@link NumberComparer}
@@ -46,22 +49,15 @@ final class TestNumberComparer {
assertTrue(success, "One or more cases failed. See stderr");
}
- @Test
- void testRoundTripOnComparisonExamples() {
- ComparisonExample[] examples = NumberComparisonExamples.getComparisonExamples();
- for(int i=0;i<examples.length; i++) {
- ComparisonExample ce = examples[i];
- confirmRoundTrip(i, ce.getA());
- confirmRoundTrip(i, ce.getNegA());
- confirmRoundTrip(i, ce.getB());
- confirmRoundTrip(i, ce.getNegB());
+ @ParameterizedTest
+ @MethodSource("org.apache.poi.ss.util.NumberComparisonExamples#getComparisonExamples")
+ void testRoundTripOnComparisonExamples(ComparisonExample ce) {
+ double[] vals = { ce.getA(), ce.getNegA(), ce.getB(), ce.getNegB() };
+ for (double a : vals) {
+ assertDoesNotThrow(() -> new TestExpandedDouble().confirmRoundTrip(Double.doubleToLongBits(a)));
}
}
- private void confirmRoundTrip(int i, double a) {
- TestExpandedDouble.confirmRoundTrip(i, Double.doubleToLongBits(a));
- }
-
/**
* The actual example from bug 47598
*/
diff --git a/src/testcases/org/apache/poi/ss/util/TestSheetUtil.java b/src/testcases/org/apache/poi/ss/util/TestSheetUtil.java
index c61ba56401..1731d46371 100644
--- a/src/testcases/org/apache/poi/ss/util/TestSheetUtil.java
+++ b/src/testcases/org/apache/poi/ss/util/TestSheetUtil.java
@@ -17,6 +17,7 @@
package org.apache.poi.ss.util;
+import static org.junit.jupiter.api.Assertions.assertDoesNotThrow;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;
import static org.junit.jupiter.api.Assertions.assertNull;
@@ -93,7 +94,7 @@ final class TestSheetUtil {
void testCanComputeWidthHSSF() throws IOException {
try (Workbook wb = new HSSFWorkbook()) {
// cannot check on result because on some machines we get back false here!
- SheetUtil.canComputeColumnWidth(wb.getFontAt(0));
+ assertDoesNotThrow(() -> SheetUtil.canComputeColumnWidth(wb.getFontAt(0)));
}
}
diff --git a/src/testcases/org/apache/poi/util/TestHexDump.java b/src/testcases/org/apache/poi/util/TestHexDump.java
index 4b87b976ae..4a465cb4be 100644
--- a/src/testcases/org/apache/poi/util/TestHexDump.java
+++ b/src/testcases/org/apache/poi/util/TestHexDump.java
@@ -30,6 +30,8 @@ import java.io.UnsupportedEncodingException;
import org.junit.jupiter.api.AfterAll;
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.Test;
+import org.junit.jupiter.params.ParameterizedTest;
+import org.junit.jupiter.params.provider.ValueSource;
class TestHexDump {
@@ -168,21 +170,18 @@ class TestHexDump {
assertTrue(dump.contains("123456789:;<=>?@"), "Had: \n" + dump);
}
- @Test
- void testDumpToStringOutOfIndex1() {
- assertThrows(ArrayIndexOutOfBoundsException.class, () -> HexDump.dump(new byte[1], 0, -1));
- assertThrows(ArrayIndexOutOfBoundsException.class, () -> HexDump.dump(new byte[1], 0, 2));
- assertThrows(ArrayIndexOutOfBoundsException.class, () -> HexDump.dump(new byte[1], 0, 1));
+ @ParameterizedTest
+ @ValueSource(ints = {-1, 2, 1})
+ void testDumpToStringOutOfIndex1(int index) {
+ assertThrows(ArrayIndexOutOfBoundsException.class, () ->
+ HexDump.dump(new byte[1], 0, index));
}
- @Test
- void testDumpToStringNoDataEOL1() {
- HexDump.dump(new byte[0], 0, 1);
- }
-
- @Test
- void testDumpToStringNoDataEOL2() {
- HexDump.dump(new byte[0], 0, 0);
+ @ParameterizedTest
+ @ValueSource(ints = {0, 1})
+ void testDumpToStringNoDataEOL(int index) {
+ String s = HexDump.dump(new byte[0], 0, index);
+ assertEquals("No Data", s.trim());
}
private static byte[] testArray() {
diff --git a/src/testcases/org/apache/poi/util/TestIOUtils.java b/src/testcases/org/apache/poi/util/TestIOUtils.java
index 196fcf401b..c39efacfe2 100644
--- a/src/testcases/org/apache/poi/util/TestIOUtils.java
+++ b/src/testcases/org/apache/poi/util/TestIOUtils.java
@@ -181,7 +181,8 @@ final class TestIOUtils {
@Test
void testSkipFullyBug61294() throws IOException {
- IOUtils.skipFully(new ByteArrayInputStream(new byte[0]), 1);
+ long skipped = IOUtils.skipFully(new ByteArrayInputStream(new byte[0]), 1);
+ assertEquals(-1L, skipped);
}
@Test
@@ -215,9 +216,12 @@ final class TestIOUtils {
@Test
void testMaxLengthIgnored() throws IOException {
try (InputStream is = new FileInputStream(TMP)) {
- IOUtils.toByteArray(is, 90, Integer.MAX_VALUE);
- IOUtils.toByteArray(is, 90, 100);
- IOUtils.toByteArray(is, Integer.MAX_VALUE, Integer.MAX_VALUE);
+ int len = IOUtils.toByteArray(is, 90, Integer.MAX_VALUE).length;
+ assertEquals(90, len);
+ len = IOUtils.toByteArray(is, 90, 100).length;
+ assertEquals(90, len);
+ len = IOUtils.toByteArray(is, Integer.MAX_VALUE, Integer.MAX_VALUE).length;
+ assertTrue(len > 300-2*90);
}
}