Fix unit tests broken by newly added test-file, ignore TestFontRendering as it is inherently unstable currently
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1568744 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
7e63803aa9
commit
dcad3624dc
@ -41,6 +41,7 @@ import javax.imageio.ImageIO;
|
|||||||
import org.apache.poi.POIDataSamples;
|
import org.apache.poi.POIDataSamples;
|
||||||
import org.apache.poi.hslf.model.Slide;
|
import org.apache.poi.hslf.model.Slide;
|
||||||
import org.apache.poi.hslf.model.TextPainter;
|
import org.apache.poi.hslf.model.TextPainter;
|
||||||
|
import org.junit.Ignore;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -49,6 +50,7 @@ import org.junit.Test;
|
|||||||
public class TestFontRendering {
|
public class TestFontRendering {
|
||||||
private static POIDataSamples slTests = POIDataSamples.getSlideShowInstance();
|
private static POIDataSamples slTests = POIDataSamples.getSlideShowInstance();
|
||||||
|
|
||||||
|
@Ignore("This fails on some systems because fonts are rendered slightly different")
|
||||||
@Test
|
@Test
|
||||||
public void bug55902mixedFontWithChineseCharacters() throws Exception {
|
public void bug55902mixedFontWithChineseCharacters() throws Exception {
|
||||||
// font files need to be downloaded first via
|
// font files need to be downloaded first via
|
||||||
|
@ -58,13 +58,7 @@ public class TestReadAllFiles extends TestCase {
|
|||||||
public boolean accept(final File f)
|
public boolean accept(final File f)
|
||||||
{
|
{
|
||||||
// exclude files that we know will fail
|
// exclude files that we know will fail
|
||||||
for(String exclude : excludes) {
|
return f.isFile() && checkExclude(f);
|
||||||
if(f.getAbsolutePath().endsWith(exclude)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return f.isFile();
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -86,4 +80,20 @@ public class TestReadAllFiles extends TestCase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true if the file should be checked, false if it should be excluded.
|
||||||
|
*
|
||||||
|
* @param f
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static boolean checkExclude(File f) {
|
||||||
|
for(String exclude : excludes) {
|
||||||
|
if(f.getAbsolutePath().endsWith(exclude)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -17,43 +17,16 @@
|
|||||||
|
|
||||||
package org.apache.poi.hpsf.basic;
|
package org.apache.poi.hpsf.basic;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.*;
|
||||||
import java.io.ByteArrayOutputStream;
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.FileFilter;
|
|
||||||
import java.io.FileInputStream;
|
|
||||||
import java.io.FileOutputStream;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
|
||||||
import java.io.OutputStream;
|
|
||||||
import java.io.PrintWriter;
|
|
||||||
import java.io.StringWriter;
|
|
||||||
import java.io.UnsupportedEncodingException;
|
|
||||||
import java.nio.charset.Charset;
|
import java.nio.charset.Charset;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import junit.framework.Assert;
|
|
||||||
import junit.framework.TestCase;
|
import junit.framework.TestCase;
|
||||||
|
|
||||||
import org.apache.poi.POIDataSamples;
|
import org.apache.poi.POIDataSamples;
|
||||||
import org.apache.poi.hpsf.ClassID;
|
import org.apache.poi.hpsf.*;
|
||||||
import org.apache.poi.hpsf.HPSFRuntimeException;
|
|
||||||
import org.apache.poi.hpsf.IllegalPropertySetDataException;
|
|
||||||
import org.apache.poi.hpsf.MutableProperty;
|
|
||||||
import org.apache.poi.hpsf.MutablePropertySet;
|
|
||||||
import org.apache.poi.hpsf.MutableSection;
|
|
||||||
import org.apache.poi.hpsf.NoFormatIDException;
|
|
||||||
import org.apache.poi.hpsf.NoPropertySetStreamException;
|
|
||||||
import org.apache.poi.hpsf.PropertySet;
|
|
||||||
import org.apache.poi.hpsf.PropertySetFactory;
|
|
||||||
import org.apache.poi.hpsf.ReadingNotSupportedException;
|
|
||||||
import org.apache.poi.hpsf.Section;
|
|
||||||
import org.apache.poi.hpsf.SummaryInformation;
|
|
||||||
import org.apache.poi.hpsf.UnsupportedVariantTypeException;
|
|
||||||
import org.apache.poi.hpsf.Variant;
|
|
||||||
import org.apache.poi.hpsf.VariantSupport;
|
|
||||||
import org.apache.poi.hpsf.WritingNotSupportedException;
|
|
||||||
import org.apache.poi.hpsf.wellknown.PropertyIDMap;
|
import org.apache.poi.hpsf.wellknown.PropertyIDMap;
|
||||||
import org.apache.poi.hpsf.wellknown.SectionIDMap;
|
import org.apache.poi.hpsf.wellknown.SectionIDMap;
|
||||||
import org.apache.poi.poifs.eventfilesystem.POIFSReader;
|
import org.apache.poi.poifs.eventfilesystem.POIFSReader;
|
||||||
@ -63,6 +36,7 @@ import org.apache.poi.poifs.filesystem.POIFSFileSystem;
|
|||||||
import org.apache.poi.util.CodePageUtil;
|
import org.apache.poi.util.CodePageUtil;
|
||||||
import org.apache.poi.util.LittleEndian;
|
import org.apache.poi.util.LittleEndian;
|
||||||
import org.apache.poi.util.TempFile;
|
import org.apache.poi.util.TempFile;
|
||||||
|
import org.junit.Assert;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Tests HPSF's writing functionality.</p>
|
* <p>Tests HPSF's writing functionality.</p>
|
||||||
@ -665,19 +639,26 @@ public class TestWrite extends TestCase
|
|||||||
* the origin file and check whether they are equal.</p></li>
|
* the origin file and check whether they are equal.</p></li>
|
||||||
*
|
*
|
||||||
* </ul>
|
* </ul>
|
||||||
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
public void testRecreate()
|
public void testRecreate() throws IOException
|
||||||
{
|
{
|
||||||
final File dataDir = _samples.getFile("");
|
final File dataDir = _samples.getFile("");
|
||||||
final File[] fileList = dataDir.listFiles(new FileFilter()
|
final File[] fileList = dataDir.listFiles(new FileFilter()
|
||||||
{
|
{
|
||||||
|
@Override
|
||||||
public boolean accept(final File f)
|
public boolean accept(final File f)
|
||||||
{
|
{
|
||||||
return f.getName().startsWith("Test");
|
return f.getName().startsWith("Test") && TestReadAllFiles.checkExclude(f);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
for (int i = 0; i < fileList.length; i++)
|
for (int i = 0; i < fileList.length; i++) {
|
||||||
testRecreate(fileList[i]);
|
try {
|
||||||
|
testRecreate(fileList[i]);
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new IOException("While handling file " + fileList[i], e);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -687,58 +668,53 @@ public class TestWrite extends TestCase
|
|||||||
* POI filesystem.</p>
|
* POI filesystem.</p>
|
||||||
*
|
*
|
||||||
* @param f the POI filesystem to check
|
* @param f the POI filesystem to check
|
||||||
|
* @throws IOException
|
||||||
|
* @throws HPSFException
|
||||||
*/
|
*/
|
||||||
private void testRecreate(final File f)
|
private void testRecreate(final File f) throws IOException, HPSFException
|
||||||
{
|
{
|
||||||
try
|
/* Read the POI filesystem's property set streams: */
|
||||||
|
final POIFile[] psf1 = Util.readPropertySets(f);
|
||||||
|
|
||||||
|
/* Create a new POI filesystem containing the origin file's
|
||||||
|
* property set streams: */
|
||||||
|
final File copy = TempFile.createTempFile(f.getName(), "");
|
||||||
|
copy.deleteOnExit();
|
||||||
|
final OutputStream out = new FileOutputStream(copy);
|
||||||
|
final POIFSFileSystem poiFs = new POIFSFileSystem();
|
||||||
|
for (int i = 0; i < psf1.length; i++)
|
||||||
{
|
{
|
||||||
/* Read the POI filesystem's property set streams: */
|
final InputStream in =
|
||||||
final POIFile[] psf1 = Util.readPropertySets(f);
|
new ByteArrayInputStream(psf1[i].getBytes());
|
||||||
|
final PropertySet psIn = PropertySetFactory.create(in);
|
||||||
/* Create a new POI filesystem containing the origin file's
|
final MutablePropertySet psOut = new MutablePropertySet(psIn);
|
||||||
* property set streams: */
|
final ByteArrayOutputStream psStream =
|
||||||
final File copy = TempFile.createTempFile(f.getName(), "");
|
new ByteArrayOutputStream();
|
||||||
copy.deleteOnExit();
|
psOut.write(psStream);
|
||||||
final OutputStream out = new FileOutputStream(copy);
|
psStream.close();
|
||||||
final POIFSFileSystem poiFs = new POIFSFileSystem();
|
final byte[] streamData = psStream.toByteArray();
|
||||||
for (int i = 0; i < psf1.length; i++)
|
poiFs.createDocument(new ByteArrayInputStream(streamData),
|
||||||
{
|
psf1[i].getName());
|
||||||
final InputStream in =
|
poiFs.writeFilesystem(out);
|
||||||
new ByteArrayInputStream(psf1[i].getBytes());
|
|
||||||
final PropertySet psIn = PropertySetFactory.create(in);
|
|
||||||
final MutablePropertySet psOut = new MutablePropertySet(psIn);
|
|
||||||
final ByteArrayOutputStream psStream =
|
|
||||||
new ByteArrayOutputStream();
|
|
||||||
psOut.write(psStream);
|
|
||||||
psStream.close();
|
|
||||||
final byte[] streamData = psStream.toByteArray();
|
|
||||||
poiFs.createDocument(new ByteArrayInputStream(streamData),
|
|
||||||
psf1[i].getName());
|
|
||||||
poiFs.writeFilesystem(out);
|
|
||||||
}
|
|
||||||
out.close();
|
|
||||||
|
|
||||||
|
|
||||||
/* Read the property set streams from the POI filesystem just
|
|
||||||
* created. */
|
|
||||||
final POIFile[] psf2 = Util.readPropertySets(copy);
|
|
||||||
for (int i = 0; i < psf2.length; i++)
|
|
||||||
{
|
|
||||||
final byte[] bytes1 = psf1[i].getBytes();
|
|
||||||
final byte[] bytes2 = psf2[i].getBytes();
|
|
||||||
final InputStream in1 = new ByteArrayInputStream(bytes1);
|
|
||||||
final InputStream in2 = new ByteArrayInputStream(bytes2);
|
|
||||||
final PropertySet ps1 = PropertySetFactory.create(in1);
|
|
||||||
final PropertySet ps2 = PropertySetFactory.create(in2);
|
|
||||||
|
|
||||||
/* Compare the property set stream with the corresponding one
|
|
||||||
* from the origin file and check whether they are equal. */
|
|
||||||
assertEquals("Equality for file " + f.getName(), ps1, ps2);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
out.close();
|
||||||
|
|
||||||
|
|
||||||
|
/* Read the property set streams from the POI filesystem just
|
||||||
|
* created. */
|
||||||
|
final POIFile[] psf2 = Util.readPropertySets(copy);
|
||||||
|
for (int i = 0; i < psf2.length; i++)
|
||||||
{
|
{
|
||||||
handle(ex);
|
final byte[] bytes1 = psf1[i].getBytes();
|
||||||
|
final byte[] bytes2 = psf2[i].getBytes();
|
||||||
|
final InputStream in1 = new ByteArrayInputStream(bytes1);
|
||||||
|
final InputStream in2 = new ByteArrayInputStream(bytes2);
|
||||||
|
final PropertySet ps1 = PropertySetFactory.create(in1);
|
||||||
|
final PropertySet ps2 = PropertySetFactory.create(in2);
|
||||||
|
|
||||||
|
/* Compare the property set stream with the corresponding one
|
||||||
|
* from the origin file and check whether they are equal. */
|
||||||
|
assertEquals("Equality for file " + f.getName(), ps1, ps2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -746,51 +722,46 @@ public class TestWrite extends TestCase
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Tests writing and reading back a proper dictionary.</p>
|
* <p>Tests writing and reading back a proper dictionary.</p>
|
||||||
|
* @throws IOException
|
||||||
|
* @throws HPSFException
|
||||||
*/
|
*/
|
||||||
public void testDictionary()
|
public void testDictionary() throws IOException, HPSFException
|
||||||
{
|
{
|
||||||
try
|
final File copy = TempFile.createTempFile("Test-HPSF", "ole2");
|
||||||
{
|
copy.deleteOnExit();
|
||||||
final File copy = TempFile.createTempFile("Test-HPSF", "ole2");
|
|
||||||
copy.deleteOnExit();
|
|
||||||
|
|
||||||
/* Write: */
|
/* Write: */
|
||||||
final OutputStream out = new FileOutputStream(copy);
|
final OutputStream out = new FileOutputStream(copy);
|
||||||
final POIFSFileSystem poiFs = new POIFSFileSystem();
|
final POIFSFileSystem poiFs = new POIFSFileSystem();
|
||||||
final MutablePropertySet ps1 = new MutablePropertySet();
|
final MutablePropertySet ps1 = new MutablePropertySet();
|
||||||
final MutableSection s = (MutableSection) ps1.getSections().get(0);
|
final MutableSection s = (MutableSection) ps1.getSections().get(0);
|
||||||
final Map<Long,String> m = new HashMap<Long,String>(3, 1.0f);
|
final Map<Long,String> m = new HashMap<Long,String>(3, 1.0f);
|
||||||
m.put(Long.valueOf(1), "String 1");
|
m.put(Long.valueOf(1), "String 1");
|
||||||
m.put(Long.valueOf(2), "String 2");
|
m.put(Long.valueOf(2), "String 2");
|
||||||
m.put(Long.valueOf(3), "String 3");
|
m.put(Long.valueOf(3), "String 3");
|
||||||
s.setDictionary(m);
|
s.setDictionary(m);
|
||||||
s.setFormatID(SectionIDMap.DOCUMENT_SUMMARY_INFORMATION_ID[0]);
|
s.setFormatID(SectionIDMap.DOCUMENT_SUMMARY_INFORMATION_ID[0]);
|
||||||
int codepage = CodePageUtil.CP_UNICODE;
|
int codepage = CodePageUtil.CP_UNICODE;
|
||||||
s.setProperty(PropertyIDMap.PID_CODEPAGE, Variant.VT_I2,
|
s.setProperty(PropertyIDMap.PID_CODEPAGE, Variant.VT_I2,
|
||||||
Integer.valueOf(codepage));
|
Integer.valueOf(codepage));
|
||||||
poiFs.createDocument(ps1.toInputStream(), "Test");
|
poiFs.createDocument(ps1.toInputStream(), "Test");
|
||||||
poiFs.writeFilesystem(out);
|
poiFs.writeFilesystem(out);
|
||||||
out.close();
|
out.close();
|
||||||
|
|
||||||
/* Read back: */
|
/* Read back: */
|
||||||
final POIFile[] psf = Util.readPropertySets(copy);
|
final POIFile[] psf = Util.readPropertySets(copy);
|
||||||
Assert.assertEquals(1, psf.length);
|
Assert.assertEquals(1, psf.length);
|
||||||
final byte[] bytes = psf[0].getBytes();
|
final byte[] bytes = psf[0].getBytes();
|
||||||
final InputStream in = new ByteArrayInputStream(bytes);
|
final InputStream in = new ByteArrayInputStream(bytes);
|
||||||
final PropertySet ps2 = PropertySetFactory.create(in);
|
final PropertySet ps2 = PropertySetFactory.create(in);
|
||||||
|
|
||||||
/* Check if the result is a DocumentSummaryInformation stream, as
|
/* Check if the result is a DocumentSummaryInformation stream, as
|
||||||
* specified. */
|
* specified. */
|
||||||
assertTrue(ps2.isDocumentSummaryInformation());
|
assertTrue(ps2.isDocumentSummaryInformation());
|
||||||
|
|
||||||
/* Compare the property set stream with the corresponding one
|
/* Compare the property set stream with the corresponding one
|
||||||
* from the origin file and check whether they are equal. */
|
* from the origin file and check whether they are equal. */
|
||||||
assertEquals(ps1, ps2);
|
assertEquals(ps1, ps2);
|
||||||
}
|
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
handle(ex);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -798,8 +769,10 @@ public class TestWrite extends TestCase
|
|||||||
/**
|
/**
|
||||||
* <p>Tests writing and reading back a proper dictionary with an invalid
|
* <p>Tests writing and reading back a proper dictionary with an invalid
|
||||||
* codepage. (HPSF writes Unicode dictionaries only.)</p>
|
* codepage. (HPSF writes Unicode dictionaries only.)</p>
|
||||||
|
* @throws IOException
|
||||||
|
* @throws HPSFException
|
||||||
*/
|
*/
|
||||||
public void testDictionaryWithInvalidCodepage()
|
public void testDictionaryWithInvalidCodepage() throws IOException, HPSFException
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@ -829,44 +802,6 @@ public class TestWrite extends TestCase
|
|||||||
{
|
{
|
||||||
assertTrue(true);
|
assertTrue(true);
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
|
||||||
{
|
|
||||||
handle(ex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <p>Handles unexpected exceptions in testcases.</p>
|
|
||||||
*
|
|
||||||
* @param ex The exception that has been thrown.
|
|
||||||
*/
|
|
||||||
private void handle(final Exception ex)
|
|
||||||
{
|
|
||||||
final StringWriter sw = new StringWriter();
|
|
||||||
final PrintWriter pw = new PrintWriter(sw);
|
|
||||||
Throwable t = ex;
|
|
||||||
while (t != null)
|
|
||||||
{
|
|
||||||
t.printStackTrace(pw);
|
|
||||||
if (t instanceof HPSFRuntimeException)
|
|
||||||
t = ((HPSFRuntimeException) t).getReason();
|
|
||||||
else
|
|
||||||
t = null;
|
|
||||||
if (t != null)
|
|
||||||
pw.println("Caused by:");
|
|
||||||
}
|
|
||||||
pw.close();
|
|
||||||
try
|
|
||||||
{
|
|
||||||
sw.close();
|
|
||||||
}
|
|
||||||
catch (IOException ex2)
|
|
||||||
{
|
|
||||||
ex.printStackTrace();
|
|
||||||
}
|
|
||||||
fail(sw.toString());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -32,26 +32,13 @@ import java.util.Map;
|
|||||||
|
|
||||||
import junit.framework.TestCase;
|
import junit.framework.TestCase;
|
||||||
|
|
||||||
import org.apache.poi.hpsf.CustomProperties;
|
import org.apache.poi.POIDataSamples;
|
||||||
import org.apache.poi.hpsf.CustomProperty;
|
import org.apache.poi.hpsf.*;
|
||||||
import org.apache.poi.hpsf.DocumentSummaryInformation;
|
|
||||||
import org.apache.poi.hpsf.MarkUnsupportedException;
|
|
||||||
import org.apache.poi.hpsf.MutableProperty;
|
|
||||||
import org.apache.poi.hpsf.MutableSection;
|
|
||||||
import org.apache.poi.hpsf.NoPropertySetStreamException;
|
|
||||||
import org.apache.poi.hpsf.PropertySet;
|
|
||||||
import org.apache.poi.hpsf.PropertySetFactory;
|
|
||||||
import org.apache.poi.hpsf.SummaryInformation;
|
|
||||||
import org.apache.poi.hpsf.UnexpectedPropertySetTypeException;
|
|
||||||
import org.apache.poi.hpsf.Variant;
|
|
||||||
import org.apache.poi.hpsf.VariantSupport;
|
|
||||||
import org.apache.poi.hpsf.WritingNotSupportedException;
|
|
||||||
import org.apache.poi.hpsf.wellknown.SectionIDMap;
|
import org.apache.poi.hpsf.wellknown.SectionIDMap;
|
||||||
import org.apache.poi.poifs.filesystem.DirectoryEntry;
|
import org.apache.poi.poifs.filesystem.DirectoryEntry;
|
||||||
import org.apache.poi.poifs.filesystem.DocumentEntry;
|
import org.apache.poi.poifs.filesystem.DocumentEntry;
|
||||||
import org.apache.poi.poifs.filesystem.DocumentInputStream;
|
import org.apache.poi.poifs.filesystem.DocumentInputStream;
|
||||||
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
|
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
|
||||||
import org.apache.poi.POIDataSamples;
|
|
||||||
import org.apache.poi.util.TempFile;
|
import org.apache.poi.util.TempFile;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -69,6 +56,7 @@ public class TestWriteWellKnown extends TestCase {
|
|||||||
/**
|
/**
|
||||||
* @see TestCase#setUp()
|
* @see TestCase#setUp()
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public void setUp()
|
public void setUp()
|
||||||
{
|
{
|
||||||
VariantSupport.setLogUnsupportedTypes(false);
|
VariantSupport.setLogUnsupportedTypes(false);
|
||||||
@ -92,58 +80,65 @@ public class TestWriteWellKnown extends TestCase {
|
|||||||
final File dataDir = _samples.getFile("");
|
final File dataDir = _samples.getFile("");
|
||||||
final File[] docs = dataDir.listFiles(new FileFilter()
|
final File[] docs = dataDir.listFiles(new FileFilter()
|
||||||
{
|
{
|
||||||
|
@Override
|
||||||
public boolean accept(final File file)
|
public boolean accept(final File file)
|
||||||
{
|
{
|
||||||
return file.isFile() && file.getName().startsWith("Test");
|
return file.isFile() && file.getName().startsWith("Test") && TestReadAllFiles.checkExclude(file);
|
||||||
}});
|
}
|
||||||
|
});
|
||||||
|
|
||||||
for (int i = 0; i < docs.length; i++)
|
for (int i = 0; i < docs.length; i++)
|
||||||
{
|
{
|
||||||
final File doc = docs[i];
|
try {
|
||||||
|
final File doc = docs[i];
|
||||||
|
|
||||||
|
/* Read a test document <em>doc</em> into a POI filesystem. */
|
||||||
|
final POIFSFileSystem poifs = new POIFSFileSystem(new FileInputStream(doc));
|
||||||
|
final DirectoryEntry dir = poifs.getRoot();
|
||||||
|
DocumentEntry dsiEntry = null;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
dsiEntry = (DocumentEntry) dir.getEntry(DocumentSummaryInformation.DEFAULT_STREAM_NAME);
|
||||||
|
}
|
||||||
|
catch (FileNotFoundException ex)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* A missing document summary information stream is not an error
|
||||||
|
* and therefore silently ignored here.
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
/* Read a test document <em>doc</em> into a POI filesystem. */
|
|
||||||
final POIFSFileSystem poifs = new POIFSFileSystem(new FileInputStream(doc));
|
|
||||||
final DirectoryEntry dir = poifs.getRoot();
|
|
||||||
DocumentEntry dsiEntry = null;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
dsiEntry = (DocumentEntry) dir.getEntry(DocumentSummaryInformation.DEFAULT_STREAM_NAME);
|
|
||||||
}
|
|
||||||
catch (FileNotFoundException ex)
|
|
||||||
{
|
|
||||||
/*
|
/*
|
||||||
* A missing document summary information stream is not an error
|
* If there is a document summry information stream, read it from
|
||||||
* and therefore silently ignored here.
|
* the POI filesystem.
|
||||||
*/
|
*/
|
||||||
}
|
if (dsiEntry != null)
|
||||||
|
{
|
||||||
|
final DocumentInputStream dis = new DocumentInputStream(dsiEntry);
|
||||||
|
final PropertySet ps = new PropertySet(dis);
|
||||||
|
final DocumentSummaryInformation dsi = new DocumentSummaryInformation(ps);
|
||||||
|
|
||||||
/*
|
/* Execute the get... methods. */
|
||||||
* If there is a document summry information stream, read it from
|
dsi.getByteCount();
|
||||||
* the POI filesystem.
|
dsi.getByteOrder();
|
||||||
*/
|
dsi.getCategory();
|
||||||
if (dsiEntry != null)
|
dsi.getCompany();
|
||||||
{
|
dsi.getCustomProperties();
|
||||||
final DocumentInputStream dis = new DocumentInputStream(dsiEntry);
|
// FIXME dsi.getDocparts();
|
||||||
final PropertySet ps = new PropertySet(dis);
|
// FIXME dsi.getHeadingPair();
|
||||||
final DocumentSummaryInformation dsi = new DocumentSummaryInformation(ps);
|
dsi.getHiddenCount();
|
||||||
|
dsi.getLineCount();
|
||||||
/* Execute the get... methods. */
|
dsi.getLinksDirty();
|
||||||
dsi.getByteCount();
|
dsi.getManager();
|
||||||
dsi.getByteOrder();
|
dsi.getMMClipCount();
|
||||||
dsi.getCategory();
|
dsi.getNoteCount();
|
||||||
dsi.getCompany();
|
dsi.getParCount();
|
||||||
dsi.getCustomProperties();
|
dsi.getPresentationFormat();
|
||||||
// FIXME dsi.getDocparts();
|
dsi.getScale();
|
||||||
// FIXME dsi.getHeadingPair();
|
dsi.getSlideCount();
|
||||||
dsi.getHiddenCount();
|
}
|
||||||
dsi.getLineCount();
|
} catch (Exception e) {
|
||||||
dsi.getLinksDirty();
|
throw new IOException("While handling file " + docs[i], e);
|
||||||
dsi.getManager();
|
|
||||||
dsi.getMMClipCount();
|
|
||||||
dsi.getNoteCount();
|
|
||||||
dsi.getParCount();
|
|
||||||
dsi.getPresentationFormat();
|
|
||||||
dsi.getScale();
|
|
||||||
dsi.getSlideCount();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -587,6 +582,7 @@ public class TestWriteWellKnown extends TestCase {
|
|||||||
{
|
{
|
||||||
final AllDataFilesTester.TestTask task = new AllDataFilesTester.TestTask()
|
final AllDataFilesTester.TestTask task = new AllDataFilesTester.TestTask()
|
||||||
{
|
{
|
||||||
|
@Override
|
||||||
public void runTest(final File file) throws FileNotFoundException,
|
public void runTest(final File file) throws FileNotFoundException,
|
||||||
IOException, NoPropertySetStreamException,
|
IOException, NoPropertySetStreamException,
|
||||||
MarkUnsupportedException,
|
MarkUnsupportedException,
|
||||||
@ -638,15 +634,20 @@ public class TestWriteWellKnown extends TestCase {
|
|||||||
final File dataDir = _samples.getFile("");
|
final File dataDir = _samples.getFile("");
|
||||||
final File[] docs = dataDir.listFiles(new FileFilter()
|
final File[] docs = dataDir.listFiles(new FileFilter()
|
||||||
{
|
{
|
||||||
|
@Override
|
||||||
public boolean accept(final File file)
|
public boolean accept(final File file)
|
||||||
{
|
{
|
||||||
return file.isFile() && file.getName().startsWith("Test");
|
return file.isFile() && file.getName().startsWith("Test") && TestReadAllFiles.checkExclude(file);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
for (int i = 0; i < docs.length; i++)
|
for (int i = 0; i < docs.length; i++)
|
||||||
{
|
{
|
||||||
task.runTest(docs[i]);
|
try {
|
||||||
|
task.runTest(docs[i]);
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new IOException("While handling file " + docs[i], e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user