aboutsummaryrefslogtreecommitdiffstats
path: root/src/testcases/org/apache/poi/poifs/macros
diff options
context:
space:
mode:
authorJaven O'Neal <onealj@apache.org>2016-07-09 05:39:56 +0000
committerJaven O'Neal <onealj@apache.org>2016-07-09 05:39:56 +0000
commit1f76abf1b66ffe8f66c5bd3e0765d5aae3ec3979 (patch)
treeaed727a00a1e1ec4d240783da8fe7dbba5e79b7b /src/testcases/org/apache/poi/poifs/macros
parented7dc7e8fafa4095a0efd8e38c80e10d67790065 (diff)
downloadpoi-1f76abf1b66ffe8f66c5bd3e0765d5aae3ec3979.tar.gz
poi-1f76abf1b66ffe8f66c5bd3e0765d5aae3ec3979.zip
bug 59830: add context to why no more bytes could be read from input stream
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1751982 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src/testcases/org/apache/poi/poifs/macros')
-rw-r--r--src/testcases/org/apache/poi/poifs/macros/TestVBAMacroReader.java40
1 files changed, 29 insertions, 11 deletions
diff --git a/src/testcases/org/apache/poi/poifs/macros/TestVBAMacroReader.java b/src/testcases/org/apache/poi/poifs/macros/TestVBAMacroReader.java
index 2f2feee072..4d844a6db7 100644
--- a/src/testcases/org/apache/poi/poifs/macros/TestVBAMacroReader.java
+++ b/src/testcases/org/apache/poi/poifs/macros/TestVBAMacroReader.java
@@ -17,12 +17,9 @@
package org.apache.poi.poifs.macros;
-import org.apache.poi.POIDataSamples;
-import org.apache.poi.poifs.filesystem.NPOIFSFileSystem;
-import org.apache.poi.util.IOUtils;
-import org.apache.poi.util.StringUtil;
-import org.junit.Ignore;
-import org.junit.Test;
+import static org.apache.poi.POITestCase.assertContains;
+import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertNotNull;
import java.io.File;
import java.io.FileInputStream;
@@ -32,9 +29,12 @@ import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
-import static org.apache.poi.POITestCase.assertContains;
-import static org.junit.Assert.assertFalse;
-import static org.junit.Assert.assertNotNull;
+import org.apache.poi.POIDataSamples;
+import org.apache.poi.poifs.filesystem.NPOIFSFileSystem;
+import org.apache.poi.util.IOUtils;
+import org.apache.poi.util.StringUtil;
+import org.junit.Ignore;
+import org.junit.Test;
public class TestVBAMacroReader {
private static final Map<POIDataSamples, String> expectedMacroContents;
@@ -178,7 +178,7 @@ public class TestVBAMacroReader {
}
}
- protected void fromStream(POIDataSamples dataSamples, String filename) throws IOException {
+ protected void fromStream(POIDataSamples dataSamples, String filename) throws IOException {
InputStream fis = dataSamples.openResourceAsStream(filename);
try {
VBAMacroReader r = new VBAMacroReader(fis);
@@ -192,7 +192,7 @@ public class TestVBAMacroReader {
}
}
- protected void fromNPOIFS(POIDataSamples dataSamples, String filename) throws IOException {
+ protected void fromNPOIFS(POIDataSamples dataSamples, String filename) throws IOException {
File f = dataSamples.getFile(filename);
NPOIFSFileSystem fs = new NPOIFSFileSystem(f);
try {
@@ -241,4 +241,22 @@ public class TestVBAMacroReader {
String testMacroNoSub = expectedMacroContents.get(samples);
assertContains(content, testMacroNoSub);
}
+
+ @Ignore
+ @Test
+ public void bug59830() throws IOException {
+ // This file is intentionally omitted from the test-data directory
+ // unless we can extract the vbaProject.bin from this Word 97-2003 file
+ // so that it's less likely to be opened and executed on a Windows computer.
+ // The file is attached to bug 59830.
+ // The Macro Virus only affects Windows computers, as it makes a
+ // subprocess call to powershell.exe with an encoded payload
+ // The document contains macros that execute on workbook open if macros
+ // are enabled
+ File doc = POIDataSamples.getDocumentInstance().getFile("macro_virus.doc.do_not_open");
+ VBAMacroReader reader = new VBAMacroReader(doc);
+ Map<String, String> macros = reader.readMacros();
+ assertNotNull(macros);
+ reader.close();
+ }
}