]> source.dussan.org Git - xmlgraphics-fop.git/commitdiff
Clean-up:
authorJeremias Maerki <jeremias@apache.org>
Tue, 15 Feb 2005 10:06:07 +0000 (10:06 +0000)
committerJeremias Maerki <jeremias@apache.org>
Tue, 15 Feb 2005 10:06:07 +0000 (10:06 +0000)
table2 split into table2 (margins and spaces only) and table-border-separate1.
table-cell5 renamed to table-border-separate2.
table-cell5a renamed to table-border-separate2a.
table-cell7 renamed to table-border-separate3

git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@198429 13f79535-47bb-0310-9956-ffa450edef68

test/layoutengine/testcases/table-border-separate1.xml [new file with mode: 0644]
test/layoutengine/testcases/table-border-separate2.xml [new file with mode: 0644]
test/layoutengine/testcases/table-border-separate2a.xml [new file with mode: 0644]
test/layoutengine/testcases/table-border-separate3.xml [new file with mode: 0644]
test/layoutengine/testcases/table-cell5.xml [deleted file]
test/layoutengine/testcases/table-cell5a.xml [deleted file]
test/layoutengine/testcases/table-cell7.xml [deleted file]
test/layoutengine/testcases/table2.xml

diff --git a/test/layoutengine/testcases/table-border-separate1.xml b/test/layoutengine/testcases/table-border-separate1.xml
new file mode 100644 (file)
index 0000000..04f2288
--- /dev/null
@@ -0,0 +1,120 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+  Copyright 2005 The Apache Software Foundation
+
+  Licensed under the Apache License, Version 2.0 (the "License");
+  you may not use this file except in compliance with the License.
+  You may obtain a copy of the License at
+
+       http://www.apache.org/licenses/LICENSE-2.0
+
+  Unless required by applicable law or agreed to in writing, software
+  distributed under the License is distributed on an "AS IS" BASIS,
+  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+  See the License for the specific language governing permissions and
+  limitations under the License.
+-->
+<!-- $Id$ -->
+<testcase>
+  <info>
+    <p>
+      This test checks tables with separate border model. Tests borders and padding on table-level.
+    </p>
+  </info>
+  <fo>
+    <fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:svg="http://www.w3.org/2000/svg">
+      <fo:layout-master-set>
+        <fo:simple-page-master master-name="normal" page-width="5in" page-height="5in">
+          <fo:region-body/>
+        </fo:simple-page-master>
+      </fo:layout-master-set>
+      <fo:page-sequence master-reference="normal" white-space-collapse="true">
+        <fo:flow flow-name="xsl-region-body">
+          <fo:block background-color="orange">before table</fo:block>
+          <fo:table table-layout="fixed" border-collapse="separate" margin="0pt" border="solid 5pt" padding="5pt" width="4in + 10pt + 10pt" background-color="lightgray">
+            <fo:table-column column-width="2in"/>
+            <fo:table-column column-width="2in"/>
+            <fo:table-body start-indent="0pt" end-indent="0pt">
+              <fo:table-row>
+                <fo:table-cell>
+                  <fo:block>cell1</fo:block>
+                </fo:table-cell>
+                <fo:table-cell background-color="yellow">
+                  <fo:block>cell2</fo:block>
+                </fo:table-cell>
+              </fo:table-row>
+              <fo:table-row>
+                <fo:table-cell background-color="orange">
+                  <fo:block text-align="end">cell3</fo:block>
+                </fo:table-cell>
+                <fo:table-cell>
+                  <fo:block>cell4</fo:block>
+                </fo:table-cell>
+              </fo:table-row>
+            </fo:table-body>
+          </fo:table>
+          <fo:block background-color="orange">after table</fo:block>
+          <fo:block-container width="4in + 10pt + 10pt" background-color="lightgray">
+            <fo:block margin="0pt" border="solid 5pt" padding="5pt">
+              reference block
+            </fo:block>
+          </fo:block-container>
+        </fo:flow>
+      </fo:page-sequence>
+    </fo:root>
+  </fo>
+  <checks>
+    <!-- table dimensions -->
+    <eval expected="308000" xpath="//flow/block[2]/@ipda"/>
+    <eval expected="288000" xpath="//flow/block[2]/@ipd"/>
+    <eval expected="48800" xpath="//flow/block[2]/@bpda"/>
+    <eval expected="28800" xpath="//flow/block[2]/@bpd"/>
+    <eval expected="10000 10000 10000 10000" xpath="//flow/block[2]/@bap"/>
+    <eval expected="(133,#000000,5000)" xpath="//flow/block[2]/@border-start"/>
+    <eval expected="(133,#000000,5000)" xpath="//flow/block[2]/@border-end"/>
+    <eval expected="(133,#000000,5000)" xpath="//flow/block[2]/@border-before"/>
+    <eval expected="(133,#000000,5000)" xpath="//flow/block[2]/@border-after"/>
+    
+    <!-- cell 1 -->
+    <true xpath="//flow/block[2]/block[1]/@is-reference-area"/>
+    <eval expected="10000" xpath="//flow/block[2]/block[1]/@left-offset"/>
+    <true xpath="not(boolean(//flow/block[2]/block[1]/@top-offset)) or (//flow/block[3]/block[1]/@top-offset = 0)"/>
+    <eval expected="144000" xpath="//flow/block[2]/block[1]/@ipd"/>
+    <eval expected="14400" xpath="//flow/block[2]/block[1]/@bpd"/>
+    <eval expected="144000" xpath="//flow/block[2]/block[1]/block[1]/@ipd"/>
+    <eval expected="14400" xpath="//flow/block[2]/block[1]/block[1]/@bpd"/>
+    <eval expected="cell1" xpath="//flow/block[2]/block[1]/block[1]/lineArea"/>
+
+    <!-- cell 2 -->
+    <true xpath="//flow/block[2]/block[2]/@is-reference-area"/>
+    <eval expected="154000" xpath="//flow/block[2]/block[2]/@left-offset"/>
+    <true xpath="not(boolean(//flow/block[2]/block[2]/@top-offset)) or (//flow/block[3]/block[2]/@top-offset = 0)"/>
+    <eval expected="144000" xpath="//flow/block[2]/block[2]/@ipd"/>
+    <eval expected="14400" xpath="//flow/block[2]/block[2]/@bpd"/>
+    <eval expected="144000" xpath="//flow/block[2]/block[2]/block[1]/@ipd"/>
+    <eval expected="14400" xpath="//flow/block[2]/block[2]/block[1]/@bpd"/>
+    <eval expected="cell2" xpath="//flow/block[2]/block[2]/block[1]/lineArea"/>
+    <eval expected="color=#ffff00,repeat=0,horiz=0,vertical=0" xpath="//flow/block[2]/block[2]/@background"/>
+
+    <!-- cell 3 -->
+    <true xpath="//flow/block[2]/block[3]/@is-reference-area"/>
+    <eval expected="10000" xpath="//flow/block[2]/block[3]/@left-offset"/>
+    <eval expected="14400" xpath="//flow/block[2]/block[3]/@top-offset"/>
+    <eval expected="144000" xpath="//flow/block[2]/block[3]/@ipd"/>
+    <eval expected="14400" xpath="//flow/block[2]/block[3]/@bpd"/>
+    <eval expected="144000" xpath="//flow/block[2]/block[3]/block[1]/@ipd"/>
+    <eval expected="14400" xpath="//flow/block[2]/block[3]/block[1]/@bpd"/>
+    <eval expected="cell3" xpath="//flow/block[2]/block[3]/block[1]/lineArea"/>
+    <eval expected="color=#ffa500,repeat=0,horiz=0,vertical=0" xpath="//flow/block[2]/block[3]/@background"/>
+
+    <!-- cell 4 -->
+    <true xpath="//flow/block[2]/block[4]/@is-reference-area"/>
+    <eval expected="154000" xpath="//flow/block[2]/block[4]/@left-offset"/>
+    <eval expected="14400" xpath="//flow/block[2]/block[4]/@top-offset"/>
+    <eval expected="144000" xpath="//flow/block[2]/block[4]/@ipd"/>
+    <eval expected="14400" xpath="//flow/block[2]/block[4]/@bpd"/>
+    <eval expected="144000" xpath="//flow/block[2]/block[4]/block[1]/@ipd"/>
+    <eval expected="14400" xpath="//flow/block[2]/block[4]/block[1]/@bpd"/>
+    <eval expected="cell4" xpath="//flow/block[2]/block[4]/block[1]/lineArea"/>
+  </checks>
+</testcase>
diff --git a/test/layoutengine/testcases/table-border-separate2.xml b/test/layoutengine/testcases/table-border-separate2.xml
new file mode 100644 (file)
index 0000000..9d9e975
--- /dev/null
@@ -0,0 +1,117 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+  Copyright 2005 The Apache Software Foundation
+
+  Licensed under the Apache License, Version 2.0 (the "License");
+  you may not use this file except in compliance with the License.
+  You may obtain a copy of the License at
+
+       http://www.apache.org/licenses/LICENSE-2.0
+
+  Unless required by applicable law or agreed to in writing, software
+  distributed under the License is distributed on an "AS IS" BASIS,
+  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+  See the License for the specific language governing permissions and
+  limitations under the License.
+-->
+<!-- $Id$ -->
+<testcase>
+  <info>
+    <p>
+      This test checks tables, especially table-cells. This test: simple borders with border-collapse="separate".
+    </p>
+  </info>
+  <fo>
+    <fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:svg="http://www.w3.org/2000/svg">
+      <fo:layout-master-set>
+        <fo:simple-page-master master-name="normal" page-width="5in" page-height="5in">
+          <fo:region-body/>
+        </fo:simple-page-master>
+      </fo:layout-master-set>
+      <fo:page-sequence master-reference="normal" white-space-collapse="true">
+        <fo:flow flow-name="xsl-region-body">
+          <fo:table table-layout="fixed" border-collapse="separate">
+            <fo:table-column column-width="160pt"/>
+            <fo:table-column column-width="200pt"/>
+            <fo:table-body>
+              <fo:table-row>
+                <fo:table-cell background-color="lightgreen">
+                  <fo:block>cell1</fo:block>
+                </fo:table-cell>
+                <fo:table-cell background-color="green" border="solid 5pt black">
+                  <fo:block>cell2</fo:block>
+                </fo:table-cell>
+              </fo:table-row>
+              <fo:table-row>
+                <fo:table-cell background-color="yellow" border="solid 5pt" padding="5pt">
+                  <fo:block>cell3</fo:block>
+                </fo:table-cell>
+                <fo:table-cell height="20pt" background-color="orange" border-top="solid 5pt red" border-bottom="solid 10pt red" border-left="solid 15pt red" border-right="solid 20pt red">
+                  <fo:block text-align="center">cell4</fo:block>
+                </fo:table-cell>
+              </fo:table-row>
+            </fo:table-body>
+          </fo:table>
+        </fo:flow>
+      </fo:page-sequence>
+    </fo:root>
+  </fo>
+  <checks>
+    <eval expected="59400" xpath="//flow/block[1]/@bpda"/>
+    <eval expected="59400" xpath="//flow/block[1]/@bpd"/>
+    <eval expected="360000" xpath="//flow/block[1]/@ipda"/>
+    <eval expected="360000" xpath="//flow/block[1]/@ipd"/>
+    
+    <!-- cell 1 -->
+    <eval expected="24400" xpath="//flow/block[1]/block[1]/@bpda"/>
+    <eval expected="24400" xpath="//flow/block[1]/block[1]/@bpd"/>
+    <eval expected="160000" xpath="//flow/block[1]/block[1]/@ipda"/>
+    <eval expected="160000" xpath="//flow/block[1]/block[1]/@ipd"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[1]/block[1]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[1]/block[1]/@bpd"/>
+    <eval expected="160000" xpath="//flow/block[1]/block[1]/block[1]/@ipda"/>
+    <eval expected="160000" xpath="//flow/block[1]/block[1]/block[1]/@ipd"/>
+
+    <!-- cell 2 -->
+    <eval expected="24400" xpath="//flow/block[1]/block[2]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[2]/@bpd"/>
+    <eval expected="200000" xpath="//flow/block[1]/block[2]/@ipda"/>
+    <eval expected="190000" xpath="//flow/block[1]/block[2]/@ipd"/>
+    <eval expected="165000" xpath="//flow/block[1]/block[2]/@left-offset"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[2]/block[1]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[2]/block[1]/@bpd"/>
+    <eval expected="190000" xpath="//flow/block[1]/block[2]/block[1]/@ipda"/>
+    <eval expected="190000" xpath="//flow/block[1]/block[2]/block[1]/@ipd"/>
+    <eval expected="5000 5000 5000 5000" xpath="//flow/block[1]/block[2]/@bap"/>
+
+    <!-- cell 3 -->
+    <eval expected="35000" xpath="//flow/block[1]/block[3]/@bpda"/>
+    <eval expected="15000" xpath="//flow/block[1]/block[3]/@bpd"/>
+    <eval expected="160000" xpath="//flow/block[1]/block[3]/@ipda"/>
+    <eval expected="140000" xpath="//flow/block[1]/block[3]/@ipd"/>
+    <eval expected="10000" xpath="//flow/block[1]/block[3]/@left-offset"/>
+    <eval expected="24400" xpath="//flow/block[1]/block[3]/@top-offset"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[3]/block[1]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[3]/block[1]/@bpd"/>
+    <eval expected="140000" xpath="//flow/block[1]/block[3]/block[1]/@ipda"/>
+    <eval expected="140000" xpath="//flow/block[1]/block[3]/block[1]/@ipd"/>
+    <eval expected="10000 10000 10000 10000" xpath="//flow/block[1]/block[3]/@bap"/>
+    <eval expected="5000" xpath="//flow/block[1]/block[3]/@padding-before"/>
+    <eval expected="5000" xpath="//flow/block[1]/block[3]/@padding-after"/>
+    <eval expected="5000" xpath="//flow/block[1]/block[3]/@padding-start"/>
+    <eval expected="5000" xpath="//flow/block[1]/block[3]/@padding-end"/>
+
+    <!-- cell 4 -->
+    <eval expected="35000" xpath="//flow/block[1]/block[4]/@bpda"/>
+    <eval expected="20000" xpath="//flow/block[1]/block[4]/@bpd"/>
+    <eval expected="200000" xpath="//flow/block[1]/block[4]/@ipda"/>
+    <eval expected="165000" xpath="//flow/block[1]/block[4]/@ipd"/>
+    <eval expected="175000" xpath="//flow/block[1]/block[4]/@left-offset"/>
+    <eval expected="24400" xpath="//flow/block[1]/block[4]/@top-offset"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[4]/block[1]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[4]/block[1]/@bpd"/>
+    <eval expected="165000" xpath="//flow/block[1]/block[4]/block[1]/@ipda"/>
+    <eval expected="165000" xpath="//flow/block[1]/block[4]/block[1]/@ipd"/>
+    <eval expected="15000 20000 5000 10000" xpath="//flow/block[1]/block[4]/@bap"/>
+  </checks>
+</testcase>
diff --git a/test/layoutengine/testcases/table-border-separate2a.xml b/test/layoutengine/testcases/table-border-separate2a.xml
new file mode 100644 (file)
index 0000000..9b74280
--- /dev/null
@@ -0,0 +1,200 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+  Copyright 2005 The Apache Software Foundation
+
+  Licensed under the Apache License, Version 2.0 (the "License");
+  you may not use this file except in compliance with the License.
+  You may obtain a copy of the License at
+
+       http://www.apache.org/licenses/LICENSE-2.0
+
+  Unless required by applicable law or agreed to in writing, software
+  distributed under the License is distributed on an "AS IS" BASIS,
+  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+  See the License for the specific language governing permissions and
+  limitations under the License.
+-->
+<!-- $Id$ -->
+<testcase>
+  <info>
+    <p>
+      This test checks tables, especially table-cells. This test: simple borders with border-collapse="separate", 
+      this time with horizontal border-spacing or border-separation.inline-progression-direction.
+    </p>
+  </info>
+  <fo>
+    <fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:svg="http://www.w3.org/2000/svg">
+      <fo:layout-master-set>
+        <fo:simple-page-master master-name="normal" page-width="5in" page-height="5in">
+          <fo:region-body/>
+        </fo:simple-page-master>
+      </fo:layout-master-set>
+      <fo:page-sequence master-reference="normal" white-space-collapse="true">
+        <fo:flow flow-name="xsl-region-body">
+          <fo:table table-layout="fixed" border-collapse="separate" border-spacing="5pt 0pt">
+            <fo:table-column column-width="160pt"/>
+            <fo:table-column column-width="160pt"/>
+            <fo:table-body>
+              <fo:table-row>
+                <fo:table-cell>
+                  <fo:block>cell1</fo:block>
+                </fo:table-cell>
+                <fo:table-cell border="solid 5pt black">
+                  <fo:block>cell2</fo:block>
+                </fo:table-cell>
+              </fo:table-row>
+              <fo:table-row>
+                <fo:table-cell border="solid 5pt">
+                  <fo:block>cell3</fo:block>
+                </fo:table-cell>
+                <fo:table-cell height="20pt" border="solid 10pt red">
+                  <fo:block>cell4</fo:block>
+                </fo:table-cell>
+              </fo:table-row>
+            </fo:table-body>
+          </fo:table>
+          <!-- this block is to visually check that there are no overlaps. -->
+          <fo:block border="solid 0.1pt">Reference block</fo:block>
+          <fo:table table-layout="fixed" border-collapse="separate" 
+                border-separation.inline-progression-direction="5pt" border-separation.block-progression-direction="0pt"
+                margin="0pt" border="solid 5pt" padding="5pt">
+            <fo:table-column column-width="160pt"/>
+            <fo:table-column column-width="160pt"/>
+            <fo:table-body start-indent="0pt" end-indent="0pt">
+              <fo:table-row>
+                <fo:table-cell>
+                  <fo:block>cell1</fo:block>
+                </fo:table-cell>
+                <fo:table-cell border="solid 5pt black">
+                  <fo:block>cell2</fo:block>
+                </fo:table-cell>
+              </fo:table-row>
+              <fo:table-row>
+                <fo:table-cell border="solid 5pt">
+                  <fo:block>cell3</fo:block>
+                </fo:table-cell>
+                <fo:table-cell height="20pt" border="solid 10pt red">
+                  <fo:block>cell4</fo:block>
+                </fo:table-cell>
+              </fo:table-row>
+            </fo:table-body>
+          </fo:table>
+          <!-- this block is to visually check that there are no overlaps. -->
+          <fo:block border="solid 0.1pt">Reference block</fo:block>
+        </fo:flow>
+      </fo:page-sequence>
+    </fo:root>
+  </fo>
+  <checks>
+    <eval expected="64400" xpath="//flow/block[1]/@bpda"/>
+    <eval expected="64400" xpath="//flow/block[1]/@bpd"/>
+    <eval expected="360000" xpath="//flow/block[1]/@ipda"/>
+    <eval expected="360000" xpath="//flow/block[1]/@ipd"/>
+    
+    <!-- cell 1 -->
+    <eval expected="24400" xpath="//flow/block[1]/block[1]/@bpda"/>
+    <eval expected="24400" xpath="//flow/block[1]/block[1]/@bpd"/>
+    <eval expected="155000" xpath="//flow/block[1]/block[1]/@ipda"/>
+    <eval expected="155000" xpath="//flow/block[1]/block[1]/@ipd"/>
+    <eval expected="2500" xpath="//flow/block[1]/block[1]/@left-offset"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[1]/block[1]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[1]/block[1]/@bpd"/>
+    <eval expected="155000" xpath="//flow/block[1]/block[1]/block[1]/@ipda"/>
+    <eval expected="155000" xpath="//flow/block[1]/block[1]/block[1]/@ipd"/>
+
+    <!-- cell 2 -->
+    <eval expected="24400" xpath="//flow/block[1]/block[2]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[2]/@bpd"/>
+    <eval expected="155000" xpath="//flow/block[1]/block[2]/@ipda"/>
+    <eval expected="145000" xpath="//flow/block[1]/block[2]/@ipd"/>
+    <eval expected="167500" xpath="//flow/block[1]/block[2]/@left-offset"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[2]/block[1]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[2]/block[1]/@bpd"/>
+    <eval expected="145000" xpath="//flow/block[1]/block[2]/block[1]/@ipda"/>
+    <eval expected="145000" xpath="//flow/block[1]/block[2]/block[1]/@ipd"/>
+    <eval expected="5000 5000 5000 5000" xpath="//flow/block[1]/block[2]/@bap"/>
+
+    <!-- cell 3 -->
+    <eval expected="40000" xpath="//flow/block[1]/block[3]/@bpda"/>
+    <eval expected="30000" xpath="//flow/block[1]/block[3]/@bpd"/>
+    <eval expected="155000" xpath="//flow/block[1]/block[3]/@ipda"/>
+    <eval expected="145000" xpath="//flow/block[1]/block[3]/@ipd"/>
+    <eval expected="7500" xpath="//flow/block[1]/block[3]/@left-offset"/>
+    <eval expected="24400" xpath="//flow/block[1]/block[3]/@top-offset"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[3]/block[1]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[3]/block[1]/@bpd"/>
+    <eval expected="145000" xpath="//flow/block[1]/block[3]/block[1]/@ipda"/>
+    <eval expected="145000" xpath="//flow/block[1]/block[3]/block[1]/@ipd"/>
+    <eval expected="5000 5000 5000 5000" xpath="//flow/block[1]/block[3]/@bap"/>
+
+    <!-- cell 4 -->
+    <eval expected="40000" xpath="//flow/block[1]/block[4]/@bpda"/>
+    <eval expected="20000" xpath="//flow/block[1]/block[4]/@bpd"/>
+    <eval expected="155000" xpath="//flow/block[1]/block[4]/@ipda"/>
+    <eval expected="135000" xpath="//flow/block[1]/block[4]/@ipd"/>
+    <eval expected="172500" xpath="//flow/block[1]/block[4]/@left-offset"/>
+    <eval expected="24400" xpath="//flow/block[1]/block[4]/@top-offset"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[4]/block[1]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[1]/block[4]/block[1]/@bpd"/>
+    <eval expected="135000" xpath="//flow/block[1]/block[4]/block[1]/@ipda"/>
+    <eval expected="135000" xpath="//flow/block[1]/block[4]/block[1]/@ipd"/>
+    <eval expected="10000 10000 10000 10000" xpath="//flow/block[1]/block[4]/@bap"/>
+
+    <!-- *** table 2 with border-separation instead of border-spacing *** -->
+    <!-- *** only left-offsets should be different because of table border and padding *** -->
+    <eval expected="84400" xpath="//flow/block[3]/@bpda"/>
+    <eval expected="64400" xpath="//flow/block[3]/@bpd"/>
+    <eval expected="360000" xpath="//flow/block[3]/@ipda"/>
+    <eval expected="340000" xpath="//flow/block[3]/@ipd"/>
+    
+    <!-- cell 1 -->
+    <eval expected="24400" xpath="//flow/block[3]/block[1]/@bpda"/>
+    <eval expected="24400" xpath="//flow/block[3]/block[1]/@bpd"/>
+    <eval expected="155000" xpath="//flow/block[3]/block[1]/@ipda"/>
+    <eval expected="155000" xpath="//flow/block[3]/block[1]/@ipd"/>
+    <eval expected="12500" xpath="//flow/block[3]/block[1]/@left-offset"/>
+    <eval expected="14400" xpath="//flow/block[3]/block[1]/block[1]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[3]/block[1]/block[1]/@bpd"/>
+    <eval expected="155000" xpath="//flow/block[3]/block[1]/block[1]/@ipda"/>
+    <eval expected="155000" xpath="//flow/block[3]/block[1]/block[1]/@ipd"/>
+
+    <!-- cell 2 -->
+    <eval expected="24400" xpath="//flow/block[3]/block[2]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[3]/block[2]/@bpd"/>
+    <eval expected="155000" xpath="//flow/block[3]/block[2]/@ipda"/>
+    <eval expected="145000" xpath="//flow/block[3]/block[2]/@ipd"/>
+    <eval expected="177500" xpath="//flow/block[3]/block[2]/@left-offset"/>
+    <eval expected="14400" xpath="//flow/block[3]/block[2]/block[1]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[3]/block[2]/block[1]/@bpd"/>
+    <eval expected="145000" xpath="//flow/block[3]/block[2]/block[1]/@ipda"/>
+    <eval expected="145000" xpath="//flow/block[3]/block[2]/block[1]/@ipd"/>
+    <eval expected="5000 5000 5000 5000" xpath="//flow/block[3]/block[2]/@bap"/>
+
+    <!-- cell 3 -->
+    <eval expected="40000" xpath="//flow/block[3]/block[3]/@bpda"/>
+    <eval expected="30000" xpath="//flow/block[3]/block[3]/@bpd"/>
+    <eval expected="155000" xpath="//flow/block[3]/block[3]/@ipda"/>
+    <eval expected="145000" xpath="//flow/block[3]/block[3]/@ipd"/>
+    <eval expected="17500" xpath="//flow/block[3]/block[3]/@left-offset"/>
+    <eval expected="24400" xpath="//flow/block[3]/block[3]/@top-offset"/>
+    <eval expected="14400" xpath="//flow/block[3]/block[3]/block[1]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[3]/block[3]/block[1]/@bpd"/>
+    <eval expected="145000" xpath="//flow/block[3]/block[3]/block[1]/@ipda"/>
+    <eval expected="145000" xpath="//flow/block[3]/block[3]/block[1]/@ipd"/>
+    <eval expected="5000 5000 5000 5000" xpath="//flow/block[3]/block[3]/@bap"/>
+
+    <!-- cell 4 -->
+    <eval expected="40000" xpath="//flow/block[3]/block[4]/@bpda"/>
+    <eval expected="20000" xpath="//flow/block[3]/block[4]/@bpd"/>
+    <eval expected="155000" xpath="//flow/block[3]/block[4]/@ipda"/>
+    <eval expected="135000" xpath="//flow/block[3]/block[4]/@ipd"/>
+    <eval expected="182500" xpath="//flow/block[3]/block[4]/@left-offset"/>
+    <eval expected="24400" xpath="//flow/block[3]/block[4]/@top-offset"/>
+    <eval expected="14400" xpath="//flow/block[3]/block[4]/block[1]/@bpda"/>
+    <eval expected="14400" xpath="//flow/block[3]/block[4]/block[1]/@bpd"/>
+    <eval expected="135000" xpath="//flow/block[3]/block[4]/block[1]/@ipda"/>
+    <eval expected="135000" xpath="//flow/block[3]/block[4]/block[1]/@ipd"/>
+    <eval expected="10000 10000 10000 10000" xpath="//flow/block[3]/block[4]/@bap"/>
+
+  </checks>
+</testcase>
diff --git a/test/layoutengine/testcases/table-border-separate3.xml b/test/layoutengine/testcases/table-border-separate3.xml
new file mode 100644 (file)
index 0000000..77d9110
--- /dev/null
@@ -0,0 +1,80 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+  Copyright 2005 The Apache Software Foundation
+
+  Licensed under the Apache License, Version 2.0 (the "License");
+  you may not use this file except in compliance with the License.
+  You may obtain a copy of the License at
+
+       http://www.apache.org/licenses/LICENSE-2.0
+
+  Unless required by applicable law or agreed to in writing, software
+  distributed under the License is distributed on an "AS IS" BASIS,
+  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+  See the License for the specific language governing permissions and
+  limitations under the License.
+-->
+<!-- $Id$ -->
+<testcase>
+  <info>
+    <p>
+      This test checks tables, especially table-cells. This test: borders in conjunction with empty-cells.
+    </p>
+  </info>
+  <fo>
+    <fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:svg="http://www.w3.org/2000/svg">
+      <fo:layout-master-set>
+        <fo:simple-page-master master-name="normal" page-width="5in" page-height="5in">
+          <fo:region-body/>
+        </fo:simple-page-master>
+      </fo:layout-master-set>
+      <fo:page-sequence master-reference="normal" white-space-collapse="true">
+        <fo:flow flow-name="xsl-region-body">
+          <fo:table table-layout="fixed" border-collapse="separate">
+            <fo:table-column column-width="160pt"/>
+            <fo:table-column column-width="200pt"/>
+            <fo:table-body>
+              <fo:table-row>
+                <fo:table-cell background-color="yellow" border="solid 5pt">
+                  <fo:block/>
+                </fo:table-cell>
+                <fo:table-cell border="solid 5pt">
+                  <fo:block>cell2</fo:block>
+                </fo:table-cell>
+              </fo:table-row>
+              <fo:table-row empty-cells="show">
+                <fo:table-cell background-color="yellow" border="solid 5pt">
+                  <fo:block/>
+                </fo:table-cell>
+                <fo:table-cell border="solid 5pt">
+                  <fo:block>cell4</fo:block>
+                </fo:table-cell>
+              </fo:table-row>
+              <fo:table-row empty-cells="hide">
+                <fo:table-cell background-color="yellow" border="solid 5pt">
+                  <fo:block/>
+                </fo:table-cell>
+                <fo:table-cell border="solid 5pt">
+                  <fo:block>cell6</fo:block>
+                </fo:table-cell>
+              </fo:table-row>
+            </fo:table-body>
+          </fo:table>
+        </fo:flow>
+      </fo:page-sequence>
+    </fo:root>
+  </fo>
+  <checks>
+    <eval expected="color=#ffff00,repeat=0,horiz=0,vertical=0" xpath="//flow/block[1]/block[1]/@background"/>
+    <eval expected="5000 5000 5000 5000" xpath="//flow/block[1]/block[1]/@bap"/>
+    <eval expected="cell2" xpath="//flow/block[1]/block[2]/block[1]/lineArea"/>
+
+    <eval expected="color=#ffff00,repeat=0,horiz=0,vertical=0" xpath="//flow/block[1]/block[3]/@background"/>
+    <eval expected="5000 5000 5000 5000" xpath="//flow/block[1]/block[3]/@bap"/>
+    <eval expected="cell4" xpath="//flow/block[1]/block[4]/block[1]/lineArea"/>
+
+    <true xpath="not(boolean(//flow/block[1]/block[5]/@background))"/>
+    <eval expected="0 0 0 0" xpath="//flow/block[1]/block[5]/@bap"/>
+    <eval expected="cell6" xpath="//flow/block[1]/block[6]/block[1]/lineArea"/>
+  </checks>
+</testcase>
diff --git a/test/layoutengine/testcases/table-cell5.xml b/test/layoutengine/testcases/table-cell5.xml
deleted file mode 100644 (file)
index 9d9e975..0000000
+++ /dev/null
@@ -1,117 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-  Copyright 2005 The Apache Software Foundation
-
-  Licensed under the Apache License, Version 2.0 (the "License");
-  you may not use this file except in compliance with the License.
-  You may obtain a copy of the License at
-
-       http://www.apache.org/licenses/LICENSE-2.0
-
-  Unless required by applicable law or agreed to in writing, software
-  distributed under the License is distributed on an "AS IS" BASIS,
-  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-  See the License for the specific language governing permissions and
-  limitations under the License.
--->
-<!-- $Id$ -->
-<testcase>
-  <info>
-    <p>
-      This test checks tables, especially table-cells. This test: simple borders with border-collapse="separate".
-    </p>
-  </info>
-  <fo>
-    <fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:svg="http://www.w3.org/2000/svg">
-      <fo:layout-master-set>
-        <fo:simple-page-master master-name="normal" page-width="5in" page-height="5in">
-          <fo:region-body/>
-        </fo:simple-page-master>
-      </fo:layout-master-set>
-      <fo:page-sequence master-reference="normal" white-space-collapse="true">
-        <fo:flow flow-name="xsl-region-body">
-          <fo:table table-layout="fixed" border-collapse="separate">
-            <fo:table-column column-width="160pt"/>
-            <fo:table-column column-width="200pt"/>
-            <fo:table-body>
-              <fo:table-row>
-                <fo:table-cell background-color="lightgreen">
-                  <fo:block>cell1</fo:block>
-                </fo:table-cell>
-                <fo:table-cell background-color="green" border="solid 5pt black">
-                  <fo:block>cell2</fo:block>
-                </fo:table-cell>
-              </fo:table-row>
-              <fo:table-row>
-                <fo:table-cell background-color="yellow" border="solid 5pt" padding="5pt">
-                  <fo:block>cell3</fo:block>
-                </fo:table-cell>
-                <fo:table-cell height="20pt" background-color="orange" border-top="solid 5pt red" border-bottom="solid 10pt red" border-left="solid 15pt red" border-right="solid 20pt red">
-                  <fo:block text-align="center">cell4</fo:block>
-                </fo:table-cell>
-              </fo:table-row>
-            </fo:table-body>
-          </fo:table>
-        </fo:flow>
-      </fo:page-sequence>
-    </fo:root>
-  </fo>
-  <checks>
-    <eval expected="59400" xpath="//flow/block[1]/@bpda"/>
-    <eval expected="59400" xpath="//flow/block[1]/@bpd"/>
-    <eval expected="360000" xpath="//flow/block[1]/@ipda"/>
-    <eval expected="360000" xpath="//flow/block[1]/@ipd"/>
-    
-    <!-- cell 1 -->
-    <eval expected="24400" xpath="//flow/block[1]/block[1]/@bpda"/>
-    <eval expected="24400" xpath="//flow/block[1]/block[1]/@bpd"/>
-    <eval expected="160000" xpath="//flow/block[1]/block[1]/@ipda"/>
-    <eval expected="160000" xpath="//flow/block[1]/block[1]/@ipd"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[1]/block[1]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[1]/block[1]/@bpd"/>
-    <eval expected="160000" xpath="//flow/block[1]/block[1]/block[1]/@ipda"/>
-    <eval expected="160000" xpath="//flow/block[1]/block[1]/block[1]/@ipd"/>
-
-    <!-- cell 2 -->
-    <eval expected="24400" xpath="//flow/block[1]/block[2]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[2]/@bpd"/>
-    <eval expected="200000" xpath="//flow/block[1]/block[2]/@ipda"/>
-    <eval expected="190000" xpath="//flow/block[1]/block[2]/@ipd"/>
-    <eval expected="165000" xpath="//flow/block[1]/block[2]/@left-offset"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[2]/block[1]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[2]/block[1]/@bpd"/>
-    <eval expected="190000" xpath="//flow/block[1]/block[2]/block[1]/@ipda"/>
-    <eval expected="190000" xpath="//flow/block[1]/block[2]/block[1]/@ipd"/>
-    <eval expected="5000 5000 5000 5000" xpath="//flow/block[1]/block[2]/@bap"/>
-
-    <!-- cell 3 -->
-    <eval expected="35000" xpath="//flow/block[1]/block[3]/@bpda"/>
-    <eval expected="15000" xpath="//flow/block[1]/block[3]/@bpd"/>
-    <eval expected="160000" xpath="//flow/block[1]/block[3]/@ipda"/>
-    <eval expected="140000" xpath="//flow/block[1]/block[3]/@ipd"/>
-    <eval expected="10000" xpath="//flow/block[1]/block[3]/@left-offset"/>
-    <eval expected="24400" xpath="//flow/block[1]/block[3]/@top-offset"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[3]/block[1]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[3]/block[1]/@bpd"/>
-    <eval expected="140000" xpath="//flow/block[1]/block[3]/block[1]/@ipda"/>
-    <eval expected="140000" xpath="//flow/block[1]/block[3]/block[1]/@ipd"/>
-    <eval expected="10000 10000 10000 10000" xpath="//flow/block[1]/block[3]/@bap"/>
-    <eval expected="5000" xpath="//flow/block[1]/block[3]/@padding-before"/>
-    <eval expected="5000" xpath="//flow/block[1]/block[3]/@padding-after"/>
-    <eval expected="5000" xpath="//flow/block[1]/block[3]/@padding-start"/>
-    <eval expected="5000" xpath="//flow/block[1]/block[3]/@padding-end"/>
-
-    <!-- cell 4 -->
-    <eval expected="35000" xpath="//flow/block[1]/block[4]/@bpda"/>
-    <eval expected="20000" xpath="//flow/block[1]/block[4]/@bpd"/>
-    <eval expected="200000" xpath="//flow/block[1]/block[4]/@ipda"/>
-    <eval expected="165000" xpath="//flow/block[1]/block[4]/@ipd"/>
-    <eval expected="175000" xpath="//flow/block[1]/block[4]/@left-offset"/>
-    <eval expected="24400" xpath="//flow/block[1]/block[4]/@top-offset"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[4]/block[1]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[4]/block[1]/@bpd"/>
-    <eval expected="165000" xpath="//flow/block[1]/block[4]/block[1]/@ipda"/>
-    <eval expected="165000" xpath="//flow/block[1]/block[4]/block[1]/@ipd"/>
-    <eval expected="15000 20000 5000 10000" xpath="//flow/block[1]/block[4]/@bap"/>
-  </checks>
-</testcase>
diff --git a/test/layoutengine/testcases/table-cell5a.xml b/test/layoutengine/testcases/table-cell5a.xml
deleted file mode 100644 (file)
index 9b74280..0000000
+++ /dev/null
@@ -1,200 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-  Copyright 2005 The Apache Software Foundation
-
-  Licensed under the Apache License, Version 2.0 (the "License");
-  you may not use this file except in compliance with the License.
-  You may obtain a copy of the License at
-
-       http://www.apache.org/licenses/LICENSE-2.0
-
-  Unless required by applicable law or agreed to in writing, software
-  distributed under the License is distributed on an "AS IS" BASIS,
-  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-  See the License for the specific language governing permissions and
-  limitations under the License.
--->
-<!-- $Id$ -->
-<testcase>
-  <info>
-    <p>
-      This test checks tables, especially table-cells. This test: simple borders with border-collapse="separate", 
-      this time with horizontal border-spacing or border-separation.inline-progression-direction.
-    </p>
-  </info>
-  <fo>
-    <fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:svg="http://www.w3.org/2000/svg">
-      <fo:layout-master-set>
-        <fo:simple-page-master master-name="normal" page-width="5in" page-height="5in">
-          <fo:region-body/>
-        </fo:simple-page-master>
-      </fo:layout-master-set>
-      <fo:page-sequence master-reference="normal" white-space-collapse="true">
-        <fo:flow flow-name="xsl-region-body">
-          <fo:table table-layout="fixed" border-collapse="separate" border-spacing="5pt 0pt">
-            <fo:table-column column-width="160pt"/>
-            <fo:table-column column-width="160pt"/>
-            <fo:table-body>
-              <fo:table-row>
-                <fo:table-cell>
-                  <fo:block>cell1</fo:block>
-                </fo:table-cell>
-                <fo:table-cell border="solid 5pt black">
-                  <fo:block>cell2</fo:block>
-                </fo:table-cell>
-              </fo:table-row>
-              <fo:table-row>
-                <fo:table-cell border="solid 5pt">
-                  <fo:block>cell3</fo:block>
-                </fo:table-cell>
-                <fo:table-cell height="20pt" border="solid 10pt red">
-                  <fo:block>cell4</fo:block>
-                </fo:table-cell>
-              </fo:table-row>
-            </fo:table-body>
-          </fo:table>
-          <!-- this block is to visually check that there are no overlaps. -->
-          <fo:block border="solid 0.1pt">Reference block</fo:block>
-          <fo:table table-layout="fixed" border-collapse="separate" 
-                border-separation.inline-progression-direction="5pt" border-separation.block-progression-direction="0pt"
-                margin="0pt" border="solid 5pt" padding="5pt">
-            <fo:table-column column-width="160pt"/>
-            <fo:table-column column-width="160pt"/>
-            <fo:table-body start-indent="0pt" end-indent="0pt">
-              <fo:table-row>
-                <fo:table-cell>
-                  <fo:block>cell1</fo:block>
-                </fo:table-cell>
-                <fo:table-cell border="solid 5pt black">
-                  <fo:block>cell2</fo:block>
-                </fo:table-cell>
-              </fo:table-row>
-              <fo:table-row>
-                <fo:table-cell border="solid 5pt">
-                  <fo:block>cell3</fo:block>
-                </fo:table-cell>
-                <fo:table-cell height="20pt" border="solid 10pt red">
-                  <fo:block>cell4</fo:block>
-                </fo:table-cell>
-              </fo:table-row>
-            </fo:table-body>
-          </fo:table>
-          <!-- this block is to visually check that there are no overlaps. -->
-          <fo:block border="solid 0.1pt">Reference block</fo:block>
-        </fo:flow>
-      </fo:page-sequence>
-    </fo:root>
-  </fo>
-  <checks>
-    <eval expected="64400" xpath="//flow/block[1]/@bpda"/>
-    <eval expected="64400" xpath="//flow/block[1]/@bpd"/>
-    <eval expected="360000" xpath="//flow/block[1]/@ipda"/>
-    <eval expected="360000" xpath="//flow/block[1]/@ipd"/>
-    
-    <!-- cell 1 -->
-    <eval expected="24400" xpath="//flow/block[1]/block[1]/@bpda"/>
-    <eval expected="24400" xpath="//flow/block[1]/block[1]/@bpd"/>
-    <eval expected="155000" xpath="//flow/block[1]/block[1]/@ipda"/>
-    <eval expected="155000" xpath="//flow/block[1]/block[1]/@ipd"/>
-    <eval expected="2500" xpath="//flow/block[1]/block[1]/@left-offset"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[1]/block[1]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[1]/block[1]/@bpd"/>
-    <eval expected="155000" xpath="//flow/block[1]/block[1]/block[1]/@ipda"/>
-    <eval expected="155000" xpath="//flow/block[1]/block[1]/block[1]/@ipd"/>
-
-    <!-- cell 2 -->
-    <eval expected="24400" xpath="//flow/block[1]/block[2]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[2]/@bpd"/>
-    <eval expected="155000" xpath="//flow/block[1]/block[2]/@ipda"/>
-    <eval expected="145000" xpath="//flow/block[1]/block[2]/@ipd"/>
-    <eval expected="167500" xpath="//flow/block[1]/block[2]/@left-offset"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[2]/block[1]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[2]/block[1]/@bpd"/>
-    <eval expected="145000" xpath="//flow/block[1]/block[2]/block[1]/@ipda"/>
-    <eval expected="145000" xpath="//flow/block[1]/block[2]/block[1]/@ipd"/>
-    <eval expected="5000 5000 5000 5000" xpath="//flow/block[1]/block[2]/@bap"/>
-
-    <!-- cell 3 -->
-    <eval expected="40000" xpath="//flow/block[1]/block[3]/@bpda"/>
-    <eval expected="30000" xpath="//flow/block[1]/block[3]/@bpd"/>
-    <eval expected="155000" xpath="//flow/block[1]/block[3]/@ipda"/>
-    <eval expected="145000" xpath="//flow/block[1]/block[3]/@ipd"/>
-    <eval expected="7500" xpath="//flow/block[1]/block[3]/@left-offset"/>
-    <eval expected="24400" xpath="//flow/block[1]/block[3]/@top-offset"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[3]/block[1]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[3]/block[1]/@bpd"/>
-    <eval expected="145000" xpath="//flow/block[1]/block[3]/block[1]/@ipda"/>
-    <eval expected="145000" xpath="//flow/block[1]/block[3]/block[1]/@ipd"/>
-    <eval expected="5000 5000 5000 5000" xpath="//flow/block[1]/block[3]/@bap"/>
-
-    <!-- cell 4 -->
-    <eval expected="40000" xpath="//flow/block[1]/block[4]/@bpda"/>
-    <eval expected="20000" xpath="//flow/block[1]/block[4]/@bpd"/>
-    <eval expected="155000" xpath="//flow/block[1]/block[4]/@ipda"/>
-    <eval expected="135000" xpath="//flow/block[1]/block[4]/@ipd"/>
-    <eval expected="172500" xpath="//flow/block[1]/block[4]/@left-offset"/>
-    <eval expected="24400" xpath="//flow/block[1]/block[4]/@top-offset"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[4]/block[1]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[1]/block[4]/block[1]/@bpd"/>
-    <eval expected="135000" xpath="//flow/block[1]/block[4]/block[1]/@ipda"/>
-    <eval expected="135000" xpath="//flow/block[1]/block[4]/block[1]/@ipd"/>
-    <eval expected="10000 10000 10000 10000" xpath="//flow/block[1]/block[4]/@bap"/>
-
-    <!-- *** table 2 with border-separation instead of border-spacing *** -->
-    <!-- *** only left-offsets should be different because of table border and padding *** -->
-    <eval expected="84400" xpath="//flow/block[3]/@bpda"/>
-    <eval expected="64400" xpath="//flow/block[3]/@bpd"/>
-    <eval expected="360000" xpath="//flow/block[3]/@ipda"/>
-    <eval expected="340000" xpath="//flow/block[3]/@ipd"/>
-    
-    <!-- cell 1 -->
-    <eval expected="24400" xpath="//flow/block[3]/block[1]/@bpda"/>
-    <eval expected="24400" xpath="//flow/block[3]/block[1]/@bpd"/>
-    <eval expected="155000" xpath="//flow/block[3]/block[1]/@ipda"/>
-    <eval expected="155000" xpath="//flow/block[3]/block[1]/@ipd"/>
-    <eval expected="12500" xpath="//flow/block[3]/block[1]/@left-offset"/>
-    <eval expected="14400" xpath="//flow/block[3]/block[1]/block[1]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[3]/block[1]/block[1]/@bpd"/>
-    <eval expected="155000" xpath="//flow/block[3]/block[1]/block[1]/@ipda"/>
-    <eval expected="155000" xpath="//flow/block[3]/block[1]/block[1]/@ipd"/>
-
-    <!-- cell 2 -->
-    <eval expected="24400" xpath="//flow/block[3]/block[2]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[3]/block[2]/@bpd"/>
-    <eval expected="155000" xpath="//flow/block[3]/block[2]/@ipda"/>
-    <eval expected="145000" xpath="//flow/block[3]/block[2]/@ipd"/>
-    <eval expected="177500" xpath="//flow/block[3]/block[2]/@left-offset"/>
-    <eval expected="14400" xpath="//flow/block[3]/block[2]/block[1]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[3]/block[2]/block[1]/@bpd"/>
-    <eval expected="145000" xpath="//flow/block[3]/block[2]/block[1]/@ipda"/>
-    <eval expected="145000" xpath="//flow/block[3]/block[2]/block[1]/@ipd"/>
-    <eval expected="5000 5000 5000 5000" xpath="//flow/block[3]/block[2]/@bap"/>
-
-    <!-- cell 3 -->
-    <eval expected="40000" xpath="//flow/block[3]/block[3]/@bpda"/>
-    <eval expected="30000" xpath="//flow/block[3]/block[3]/@bpd"/>
-    <eval expected="155000" xpath="//flow/block[3]/block[3]/@ipda"/>
-    <eval expected="145000" xpath="//flow/block[3]/block[3]/@ipd"/>
-    <eval expected="17500" xpath="//flow/block[3]/block[3]/@left-offset"/>
-    <eval expected="24400" xpath="//flow/block[3]/block[3]/@top-offset"/>
-    <eval expected="14400" xpath="//flow/block[3]/block[3]/block[1]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[3]/block[3]/block[1]/@bpd"/>
-    <eval expected="145000" xpath="//flow/block[3]/block[3]/block[1]/@ipda"/>
-    <eval expected="145000" xpath="//flow/block[3]/block[3]/block[1]/@ipd"/>
-    <eval expected="5000 5000 5000 5000" xpath="//flow/block[3]/block[3]/@bap"/>
-
-    <!-- cell 4 -->
-    <eval expected="40000" xpath="//flow/block[3]/block[4]/@bpda"/>
-    <eval expected="20000" xpath="//flow/block[3]/block[4]/@bpd"/>
-    <eval expected="155000" xpath="//flow/block[3]/block[4]/@ipda"/>
-    <eval expected="135000" xpath="//flow/block[3]/block[4]/@ipd"/>
-    <eval expected="182500" xpath="//flow/block[3]/block[4]/@left-offset"/>
-    <eval expected="24400" xpath="//flow/block[3]/block[4]/@top-offset"/>
-    <eval expected="14400" xpath="//flow/block[3]/block[4]/block[1]/@bpda"/>
-    <eval expected="14400" xpath="//flow/block[3]/block[4]/block[1]/@bpd"/>
-    <eval expected="135000" xpath="//flow/block[3]/block[4]/block[1]/@ipda"/>
-    <eval expected="135000" xpath="//flow/block[3]/block[4]/block[1]/@ipd"/>
-    <eval expected="10000 10000 10000 10000" xpath="//flow/block[3]/block[4]/@bap"/>
-
-  </checks>
-</testcase>
diff --git a/test/layoutengine/testcases/table-cell7.xml b/test/layoutengine/testcases/table-cell7.xml
deleted file mode 100644 (file)
index 77d9110..0000000
+++ /dev/null
@@ -1,80 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-  Copyright 2005 The Apache Software Foundation
-
-  Licensed under the Apache License, Version 2.0 (the "License");
-  you may not use this file except in compliance with the License.
-  You may obtain a copy of the License at
-
-       http://www.apache.org/licenses/LICENSE-2.0
-
-  Unless required by applicable law or agreed to in writing, software
-  distributed under the License is distributed on an "AS IS" BASIS,
-  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-  See the License for the specific language governing permissions and
-  limitations under the License.
--->
-<!-- $Id$ -->
-<testcase>
-  <info>
-    <p>
-      This test checks tables, especially table-cells. This test: borders in conjunction with empty-cells.
-    </p>
-  </info>
-  <fo>
-    <fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:svg="http://www.w3.org/2000/svg">
-      <fo:layout-master-set>
-        <fo:simple-page-master master-name="normal" page-width="5in" page-height="5in">
-          <fo:region-body/>
-        </fo:simple-page-master>
-      </fo:layout-master-set>
-      <fo:page-sequence master-reference="normal" white-space-collapse="true">
-        <fo:flow flow-name="xsl-region-body">
-          <fo:table table-layout="fixed" border-collapse="separate">
-            <fo:table-column column-width="160pt"/>
-            <fo:table-column column-width="200pt"/>
-            <fo:table-body>
-              <fo:table-row>
-                <fo:table-cell background-color="yellow" border="solid 5pt">
-                  <fo:block/>
-                </fo:table-cell>
-                <fo:table-cell border="solid 5pt">
-                  <fo:block>cell2</fo:block>
-                </fo:table-cell>
-              </fo:table-row>
-              <fo:table-row empty-cells="show">
-                <fo:table-cell background-color="yellow" border="solid 5pt">
-                  <fo:block/>
-                </fo:table-cell>
-                <fo:table-cell border="solid 5pt">
-                  <fo:block>cell4</fo:block>
-                </fo:table-cell>
-              </fo:table-row>
-              <fo:table-row empty-cells="hide">
-                <fo:table-cell background-color="yellow" border="solid 5pt">
-                  <fo:block/>
-                </fo:table-cell>
-                <fo:table-cell border="solid 5pt">
-                  <fo:block>cell6</fo:block>
-                </fo:table-cell>
-              </fo:table-row>
-            </fo:table-body>
-          </fo:table>
-        </fo:flow>
-      </fo:page-sequence>
-    </fo:root>
-  </fo>
-  <checks>
-    <eval expected="color=#ffff00,repeat=0,horiz=0,vertical=0" xpath="//flow/block[1]/block[1]/@background"/>
-    <eval expected="5000 5000 5000 5000" xpath="//flow/block[1]/block[1]/@bap"/>
-    <eval expected="cell2" xpath="//flow/block[1]/block[2]/block[1]/lineArea"/>
-
-    <eval expected="color=#ffff00,repeat=0,horiz=0,vertical=0" xpath="//flow/block[1]/block[3]/@background"/>
-    <eval expected="5000 5000 5000 5000" xpath="//flow/block[1]/block[3]/@bap"/>
-    <eval expected="cell4" xpath="//flow/block[1]/block[4]/block[1]/lineArea"/>
-
-    <true xpath="not(boolean(//flow/block[1]/block[5]/@background))"/>
-    <eval expected="0 0 0 0" xpath="//flow/block[1]/block[5]/@bap"/>
-    <eval expected="cell6" xpath="//flow/block[1]/block[6]/block[1]/lineArea"/>
-  </checks>
-</testcase>
index ff9be4501ce6c7415ef714599554713e7965f0f7..96bcd070bfcad3a8b3b4b4c7b9ce78476457ab26 100644 (file)
@@ -18,7 +18,7 @@
 <testcase>
   <info>
     <p>
-      This test checks basic tables. Tests spaces table spaces, borders and padding.
+      This test checks basic tables. Tests table spaces and margins.
     </p>
   </info>
   <fo>
@@ -31,7 +31,7 @@
       <fo:page-sequence master-reference="normal" white-space-collapse="true">
         <fo:flow flow-name="xsl-region-body">
           <fo:block background-color="orange">before table</fo:block>
-          <fo:table table-layout="fixed" space-before="5pt" space-after="10pt" margin-left="5pt" margin-right="10pt" border="solid 5pt" padding="5pt" width="4in + 15pt + 10pt + 10pt">
+          <fo:table table-layout="fixed" space-before="5pt" space-after="10pt" margin-left="5pt" margin-right="10pt" width="4in + 15pt" background-color="lightgray">
             <fo:table-column column-width="2in"/>
             <fo:table-column column-width="2in"/>
             <fo:table-body start-indent="0pt" end-indent="0pt">
             </fo:table-body>
           </fo:table>
           <fo:block background-color="orange">after table</fo:block>
-          <fo:block space-before="5pt" space-after="10pt" margin-left="5pt" margin-right="10pt" border="solid 5pt" padding="5pt" width="100%">
-            reference block
-          </fo:block>
+          <fo:block-container width="4in + 15pt">
+            <fo:block space-before="5pt" space-after="10pt" margin-left="5pt" margin-right="10pt" background-color="lightgray">
+              reference block
+            </fo:block>
+          </fo:block-container>
         </fo:flow>
       </fo:page-sequence>
     </fo:root>
     <eval expected="10000" xpath="//flow/block[4]/@bpd"/>
 
     <!-- table dimensions -->
-    <eval expected="308000" xpath="//flow/block[3]/@ipda"/>
+    <eval expected="288000" xpath="//flow/block[3]/@ipda"/>
     <eval expected="288000" xpath="//flow/block[3]/@ipd"/>
-    <eval expected="48800" xpath="//flow/block[3]/@bpda"/>
+    <eval expected="28800" xpath="//flow/block[3]/@bpda"/>
     <eval expected="28800" xpath="//flow/block[3]/@bpd"/>
     
     <!-- cell 1 -->
     <true xpath="//flow/block[3]/block[1]/@is-reference-area"/>
-    <eval expected="15000" xpath="//flow/block[3]/block[1]/@left-offset"/>
+    <eval expected="5000" xpath="//flow/block[3]/block[1]/@left-offset"/>
     <true xpath="not(boolean(//flow/block[3]/block[1]/@top-offset)) or (//flow/block[3]/block[1]/@top-offset = 0)"/>
     <eval expected="144000" xpath="//flow/block[3]/block[1]/@ipd"/>
     <eval expected="14400" xpath="//flow/block[3]/block[1]/@bpd"/>
@@ -84,7 +86,7 @@
 
     <!-- cell 2 -->
     <true xpath="//flow/block[3]/block[2]/@is-reference-area"/>
-    <eval expected="159000" xpath="//flow/block[3]/block[2]/@left-offset"/>
+    <eval expected="149000" xpath="//flow/block[3]/block[2]/@left-offset"/>
     <true xpath="not(boolean(//flow/block[3]/block[2]/@top-offset)) or (//flow/block[3]/block[2]/@top-offset = 0)"/>
     <eval expected="144000" xpath="//flow/block[3]/block[2]/@ipd"/>
     <eval expected="14400" xpath="//flow/block[3]/block[2]/@bpd"/>
@@ -95,7 +97,7 @@
 
     <!-- cell 3 -->
     <true xpath="//flow/block[3]/block[3]/@is-reference-area"/>
-    <eval expected="15000" xpath="//flow/block[3]/block[3]/@left-offset"/>
+    <eval expected="5000" xpath="//flow/block[3]/block[3]/@left-offset"/>
     <eval expected="14400" xpath="//flow/block[3]/block[3]/@top-offset"/>
     <eval expected="144000" xpath="//flow/block[3]/block[3]/@ipd"/>
     <eval expected="14400" xpath="//flow/block[3]/block[3]/@bpd"/>
 
     <!-- cell 4 -->
     <true xpath="//flow/block[3]/block[4]/@is-reference-area"/>
-    <eval expected="159000" xpath="//flow/block[3]/block[4]/@left-offset"/>
+    <eval expected="149000" xpath="//flow/block[3]/block[4]/@left-offset"/>
     <eval expected="14400" xpath="//flow/block[3]/block[4]/@top-offset"/>
     <eval expected="144000" xpath="//flow/block[3]/block[4]/@ipd"/>
     <eval expected="14400" xpath="//flow/block[3]/block[4]/@bpd"/>