From f2cd7ed8f519be5ff22bc64b781d8db7250e6b64 Mon Sep 17 00:00:00 2001 From: Dominik Stadler Date: Sun, 20 Sep 2015 20:05:36 +0000 Subject: [PATCH] Bug 58332: Adjust implementation of dev-util 'MemoryUsage' to print out information if limits are reached instead of OOM git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1704182 13f79535-47bb-0310-9956-ffa450edef68 --- .../org/apache/poi/xssf/util/MemoryUsage.java | 40 ++++++++++++++----- 1 file changed, 30 insertions(+), 10 deletions(-) diff --git a/src/ooxml/testcases/org/apache/poi/xssf/util/MemoryUsage.java b/src/ooxml/testcases/org/apache/poi/xssf/util/MemoryUsage.java index c0df4b609..812a92125 100644 --- a/src/ooxml/testcases/org/apache/poi/xssf/util/MemoryUsage.java +++ b/src/ooxml/testcases/org/apache/poi/xssf/util/MemoryUsage.java @@ -37,6 +37,10 @@ import java.util.ArrayList; */ public class MemoryUsage extends TestCase { private static final int NUM_COLUMNS = 255; + + private static void printMemoryUsage(String msg) { + System.out.println(" Memory (" + msg + "): " + Runtime.getRuntime().totalMemory()/(1024*1024) + "MB"); + } /** * Generate a spreadsheet until OutOfMemoryError @@ -50,7 +54,7 @@ public class MemoryUsage extends TestCase { public static void mixedSpreadsheet(Workbook wb, int numCols){ System.out.println("Testing " + wb.getClass().getName()); - System.out.println("Memory: " + Runtime.getRuntime().totalMemory()/(1024*1024) + "MB"); + printMemoryUsage("before"); int i=0, cnt=0; try { Sheet sh = wb.createSheet(); @@ -65,8 +69,11 @@ public class MemoryUsage extends TestCase { } } catch (OutOfMemoryError er){ System.out.println("Failed at row=" + i + ", objects : " + cnt); + } catch (final Exception e) { + System.out.println("Unable to reach an OutOfMemoryError"); + System.out.println(e.getClass().getName() + ": " + e.getMessage()); } - System.out.println("Memory: " + Runtime.getRuntime().totalMemory()/(1024*1024) + "MB"); + printMemoryUsage("after"); } /** @@ -74,7 +81,7 @@ public class MemoryUsage extends TestCase { * The data is generated until OutOfMemoryError. *

* as compared to {@link #mixedSpreadsheet(org.apache.poi.ss.usermodel.Workbook, int)}, - * this method does not set string values and, hence, does not invole the Shared Strings Table. + * this method does not set string values and, hence, does not involve the Shared Strings Table. *

* * @param wb the workbook to write to @@ -83,7 +90,7 @@ public class MemoryUsage extends TestCase { public static void numberSpreadsheet(Workbook wb, int numCols){ System.out.println("Testing " + wb.getClass().getName()); - System.out.println("Memory: " + Runtime.getRuntime().totalMemory()/(1024*1024) + "MB"); + printMemoryUsage("before"); int i=0, cnt=0; try { Sheet sh = wb.createSheet(); @@ -97,8 +104,11 @@ public class MemoryUsage extends TestCase { } } catch (OutOfMemoryError er){ System.out.println("Failed at row=" + i + ", objects : " + cnt); + } catch (final Exception e) { + System.out.println("Unable to reach an OutOfMemoryError"); + System.out.println(e.getClass().getName() + ": " + e.getMessage()); } - System.out.println("Memory: " + Runtime.getRuntime().totalMemory()/(1024*1024) + "MB"); + printMemoryUsage("after"); } /** @@ -111,7 +121,7 @@ public class MemoryUsage extends TestCase { */ public static void xmlBeans(int numCols) { int i = 0, cnt = 0; - System.out.println("Memory: " + Runtime.getRuntime().totalMemory() / (1024 * 1024) + "MB"); + printMemoryUsage("before"); CTWorksheet sh = CTWorksheet.Factory.newInstance(); CTSheetData data = sh.addNewSheetData(); @@ -128,8 +138,11 @@ public class MemoryUsage extends TestCase { } } catch (OutOfMemoryError er) { System.out.println("Failed at row=" + i + ", objects: " + cnt); + } catch (final Exception e) { + System.out.println("Unable to reach an OutOfMemoryError"); + System.out.println(e.getClass().getName() + ": " + e.getMessage()); } - System.out.println("Memory: " + Runtime.getRuntime().totalMemory() / (1024 * 1024) + "MB"); + printMemoryUsage("after"); } /** @@ -149,17 +162,21 @@ public class MemoryUsage extends TestCase { } } catch (OutOfMemoryError er) { System.out.println("Failed at row=" + i); + } catch (final Exception e) { + System.out.println("Unable to reach an OutOfMemoryError"); + System.out.println(e.getClass().getName() + ": " + e.getMessage()); } - System.out.println("Memory: " + Runtime.getRuntime().totalMemory() / (1024 * 1024) + "MB"); + printMemoryUsage("after"); } /** - * Generate atatched (having a parent bean) Xml beans until OutOfMemoryError. + * Generate attached (having a parent bean) Xml beans until OutOfMemoryError. * This is MUCH more memory-efficient than {@link #testXmlDetached()} * * @see #testXmlAttached() */ public void testXmlAttached(){ + printMemoryUsage("before"); List rows = new ArrayList(); int i = 0; //top-level element in sheet.xml @@ -174,8 +191,11 @@ public class MemoryUsage extends TestCase { } } catch (OutOfMemoryError er) { System.out.println("Failed at row=" + i); + } catch (final Exception e) { + System.out.println("Unable to reach an OutOfMemoryError"); + System.out.println(e.getClass().getName() + ": " + e.getMessage()); } - System.out.println("Memory: " + Runtime.getRuntime().totalMemory() / (1024 * 1024) + "MB"); + printMemoryUsage("after"); } public void testMixedHSSF(){