Author: fanningpj
Date: Wed Mar 27 21:24:25 2019
New Revision: 1856439
URL: http://svn.apache.org/viewvc?rev=1856439&view=rev
Log:
add test for concurrent use of DataFormatter
Modified:
poi/trunk/src/testcases/org/apache/poi/ss/usermodel/TestDataFormatter.java
Modified:
poi/trunk/src/testcases/org/apache/poi/ss/usermodel/TestDataFormatter.java
URL:
http://svn.apache.org/viewvc/poi/trunk/src/testcases/org/apache/poi/ss/usermodel/TestDataFormatter.java?rev=1856439&r1=1856438&r2=1856439&view=diff
==============================================================================
--- poi/trunk/src/testcases/org/apache/poi/ss/usermodel/TestDataFormatter.java
(original)
+++ poi/trunk/src/testcases/org/apache/poi/ss/usermodel/TestDataFormatter.java
Wed Mar 27 21:24:25 2019
@@ -28,11 +28,9 @@ import static org.junit.Assert.fail;
import java.io.IOException;
import java.text.DateFormat;
-import java.util.Arrays;
-import java.util.Calendar;
-import java.util.Date;
-import java.util.List;
-import java.util.Locale;
+import java.util.*;
+import java.util.concurrent.CompletableFuture;
+import java.util.concurrent.TimeUnit;
import org.apache.poi.hssf.HSSFTestDataSamples;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
@@ -938,4 +936,46 @@ public class TestDataFormatter {
String value = df.formatCellValue(cell,
wb.getCreationHelper().createFormulaEvaluator());
assertEquals("-130", value);
}
+
+ @Test
+ public void testConcurrentCellFormat() throws Exception {
+ int formatIndex = 105;
+ String formatString = "[$-F400]m/d/yy h:mm:ss\\ AM/PM;[$-F400]m/d/yy
h:mm:ss\\ AM/PM;_-* \"\"??_-;_-@_-";
+
+ DataFormatter formatter = new DataFormatter();
+ doFormatTestSequential(formatter, 43551.50990171296, "3/27/19 12:14:15
PM", formatIndex, formatString);
+ doFormatTestSequential(formatter, 36104.424780092595, "11/5/98
10:11:41 AM", formatIndex, formatString);
+
+ doFormatTestConcurrent(formatter, 43551.50990171296, "3/27/19 12:14:15
PM", formatIndex, formatString);
+ doFormatTestConcurrent(formatter, 36104.424780092595, "11/5/98
10:11:41 AM", formatIndex, formatString);
+ }
+
+ private void doFormatTestSequential(DataFormatter formatter, double n,
String expected, int formatIndex,
+ String formatString) {
+ for (int i = 0; i < 1_000; i++) {
+ assertTrue(doFormatTest(formatter, n, expected, formatIndex,
formatString, i));
+ }
+ }
+
+ private void doFormatTestConcurrent(DataFormatter formatter, double n,
String expected, int formatIndex,
+ String formatString) throws Exception {
+ ArrayList<CompletableFuture<Boolean>> futures = new ArrayList<>();
+ for (int i = 0; i < 1_000; i++) {
+ final int iteration = i;
+ CompletableFuture<Boolean> future = CompletableFuture.supplyAsync(
+ () -> { return doFormatTest(formatter, n, expected,
formatIndex, formatString, iteration); });
+ futures.add(future);
+ }
+ for (CompletableFuture<Boolean> future : futures) {
+ assertTrue(future.get(1, TimeUnit.MINUTES));
+ }
+ }
+
+ private static boolean doFormatTest(DataFormatter formatter, double n,
String expected, int formatIndex,
+ String formatString, int iteration) {
+ String actual = formatter.formatRawCellContents(n, formatIndex,
formatString);
+ assertEquals("Failed on iteration " + iteration, expected, actual);
+ return true;
+ }
+
}
\ No newline at end of file
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]