aboutsummaryrefslogtreecommitdiffstats
path: root/src/testcases
diff options
context:
space:
mode:
authorYegor Kozlov <yegor@apache.org>2009-12-15 09:30:30 +0000
committerYegor Kozlov <yegor@apache.org>2009-12-15 09:30:30 +0000
commit9a492d227eaff4d44699dc1061f3600aa3c678f5 (patch)
tree1969a4a378977be7ac900df6f36663076bcb3c73 /src/testcases
parent07d15660b9977ad88df372b65af48488003fe683 (diff)
downloadpoi-9a492d227eaff4d44699dc1061f3600aa3c678f5.tar.gz
poi-9a492d227eaff4d44699dc1061f3600aa3c678f5.zip
preserve POIFS StorageClsid when re-writing existing workbooks, this property is important for embedded objects, see Bugzilla 47920
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@890714 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src/testcases')
-rw-r--r--src/testcases/org/apache/poi/hssf/usermodel/TestHSSFWorkbook.java24
1 files changed, 21 insertions, 3 deletions
diff --git a/src/testcases/org/apache/poi/hssf/usermodel/TestHSSFWorkbook.java b/src/testcases/org/apache/poi/hssf/usermodel/TestHSSFWorkbook.java
index ab7cca3186..39a911c53e 100644
--- a/src/testcases/org/apache/poi/hssf/usermodel/TestHSSFWorkbook.java
+++ b/src/testcases/org/apache/poi/hssf/usermodel/TestHSSFWorkbook.java
@@ -17,9 +17,7 @@
package org.apache.poi.hssf.usermodel;
-import java.io.File;
-import java.io.FileOutputStream;
-import java.io.IOException;
+import java.io.*;
import java.util.List;
import junit.framework.AssertionFailedError;
@@ -37,6 +35,9 @@ import org.apache.poi.hssf.record.formula.Area3DPtg;
import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.TempFile;
import org.apache.poi.ss.usermodel.BaseTestWorkbook;
+import org.apache.poi.poifs.filesystem.POIFSFileSystem;
+import org.apache.poi.POIDataSamples;
+import org.apache.poi.hpsf.ClassID;
/**
* Tests for {@link HSSFWorkbook}
@@ -505,4 +506,21 @@ public final class TestHSSFWorkbook extends BaseTestWorkbook {
nr = wb.getWorkbook().getNameRecord(2);
assertEquals("Sheet2!E:F,Sheet2!$A$9:$IV$12", HSSFFormulaParser.toFormulaString(wb, nr.getNameDefinition())); // E:F,9:12
}
+
+ /**
+ * Test that the storage clsid property is preserved
+ */
+ public void test47920() throws IOException {
+ POIFSFileSystem fs1 = new POIFSFileSystem(POIDataSamples.getSpreadSheetInstance().openResourceAsStream("47920.xls"));
+ HSSFWorkbook wb = new HSSFWorkbook(fs1);
+ ClassID clsid1 = fs1.getRoot().getStorageClsid();
+
+ ByteArrayOutputStream out = new ByteArrayOutputStream(4096);
+ wb.write(out);
+ byte[] bytes = out.toByteArray();
+ POIFSFileSystem fs2 = new POIFSFileSystem(new ByteArrayInputStream(bytes));
+ ClassID clsid2 = fs2.getRoot().getStorageClsid();
+
+ assertTrue(clsid1.equals(clsid2));
+ }
}