Test correct processing of "sprmPItap" (0x6649) and "sprmPFInTable" (0x2416)

git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1142867 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Sergey Vladimirov 2011-07-05 01:19:31 +00:00
parent ea2b11ea0a
commit 7be1716674
2 changed files with 60 additions and 22 deletions

View File

@ -27,35 +27,73 @@ import java.io.InputStream;
import junit.framework.TestCase; import junit.framework.TestCase;
import org.apache.poi.POIDataSamples; import org.apache.poi.POIDataSamples;
import org.apache.poi.hwpf.HWPFDocument; import org.apache.poi.hwpf.HWPFDocument;
import org.apache.poi.hwpf.usermodel.Paragraph;
import org.apache.poi.hwpf.usermodel.Range;
public class TestSprms extends TestCase
{
private static HWPFDocument reload( HWPFDocument hwpfDocument )
throws IOException
{
ByteArrayOutputStream baos = new ByteArrayOutputStream();
hwpfDocument.write( baos );
return new HWPFDocument( new ByteArrayInputStream( baos.toByteArray() ) );
}
/**
* Test correct processing of "sprmPItap" (0x6649) and "sprmPFInTable"
* (0x2416)
*/
public void testInnerTable() throws Exception
{
InputStream resourceAsStream = POIDataSamples.getDocumentInstance()
.openResourceAsStream( "innertable.doc" );
HWPFDocument hwpfDocument = new HWPFDocument( resourceAsStream );
resourceAsStream.close();
testInnerTable( hwpfDocument );
hwpfDocument = reload( hwpfDocument );
testInnerTable( hwpfDocument );
}
private void testInnerTable( HWPFDocument hwpfDocument )
{
Range range = hwpfDocument.getRange();
for ( int p = 0; p < range.numParagraphs(); p++ )
{
Paragraph paragraph = range.getParagraph( p );
char first = paragraph.text().toLowerCase().charAt( 0 );
if ( '1' <= first && first < '4' )
{
assertTrue( paragraph.isInTable() );
assertEquals( 2, paragraph.getTableLevel() );
}
if ( 'a' <= first && first < 'z' )
{
assertTrue( paragraph.isInTable() );
assertEquals( 1, paragraph.getTableLevel() );
}
}
}
public class TestSprms extends TestCase {
/** /**
* Test correct processing of "sprmPJc" by uncompressor * Test correct processing of "sprmPJc" by uncompressor
*/ */
public void testSprmPJc() throws IOException { public void testSprmPJc() throws IOException
{
InputStream resourceAsStream = POIDataSamples.getDocumentInstance() InputStream resourceAsStream = POIDataSamples.getDocumentInstance()
.openResourceAsStream("Bug49820.doc"); .openResourceAsStream( "Bug49820.doc" );
HWPFDocument hwpfDocument = new HWPFDocument(resourceAsStream); HWPFDocument hwpfDocument = new HWPFDocument( resourceAsStream );
assertEquals(1, hwpfDocument.getStyleSheet().getParagraphStyle(8)
.getJustification());
resourceAsStream.close();
}
/**
* Test correct processing of "sprmPJc" by compressor and uncompressor
*/
public void testSprmPJcResave() throws IOException {
InputStream resourceAsStream = POIDataSamples.getDocumentInstance()
.openResourceAsStream("Bug49820.doc");
HWPFDocument hwpfDocument = new HWPFDocument(resourceAsStream);
resourceAsStream.close(); resourceAsStream.close();
ByteArrayOutputStream baos = new ByteArrayOutputStream(); assertEquals( 1, hwpfDocument.getStyleSheet().getParagraphStyle( 8 )
hwpfDocument.write(baos); .getJustification() );
hwpfDocument = new HWPFDocument(
new ByteArrayInputStream(baos.toByteArray())); hwpfDocument = reload( hwpfDocument );
assertEquals( 1, hwpfDocument.getStyleSheet().getParagraphStyle( 8 )
.getJustification() );
assertEquals(1, hwpfDocument.getStyleSheet().getParagraphStyle(8)
.getJustification());
} }
} }

Binary file not shown.