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:
Dominik Stadler 2014-02-16 09:11:28 +00:00
parent 7e63803aa9
commit dcad3624dc
4 changed files with 177 additions and 229 deletions

View File

@ -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

View File

@ -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;
}
} }

View File

@ -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());
} }

View File

@ -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);
}
} }
} }