summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiklos Vajna <vmiklos@suse.cz>2013-02-19 21:03:48 +0100
committerMiklos Vajna <vmiklos@suse.cz>2013-02-20 10:41:36 +0100
commit39dd9b64ddb0afefab88c8d6627c9f9c13b4ed37 (patch)
treea7517e2b658d564325c937a8244875e19cf189b9
parent5fb8aa777445d4bf150172459fe8f2581a35d854 (diff)
testcase for 349e9248f801d23735478abafe5328f79dfe4378
Change-Id: I27ca3b21427cb4d6e6b54ae5f0b3b86e18b550a2
-rw-r--r--sw/qa/extras/ooxmlexport/data/cell-btlr.docxbin0 -> 4392 bytes
-rw-r--r--sw/qa/extras/ooxmlexport/ooxmlexport.cxx62
2 files changed, 62 insertions, 0 deletions
diff --git a/sw/qa/extras/ooxmlexport/data/cell-btlr.docx b/sw/qa/extras/ooxmlexport/data/cell-btlr.docx
new file mode 100644
index 000000000000..f05f114da095
--- /dev/null
+++ b/sw/qa/extras/ooxmlexport/data/cell-btlr.docx
Binary files differ
diff --git a/sw/qa/extras/ooxmlexport/ooxmlexport.cxx b/sw/qa/extras/ooxmlexport/ooxmlexport.cxx
index d39489a9b7aa..433160fd4a07 100644
--- a/sw/qa/extras/ooxmlexport/ooxmlexport.cxx
+++ b/sw/qa/extras/ooxmlexport/ooxmlexport.cxx
@@ -41,8 +41,13 @@
#include <com/sun/star/text/XPageCursor.hpp>
#include <unotools/tempfile.hxx>
+#include <unotools/ucbstreamhelper.hxx>
+#include <rtl/strbuf.hxx>
#include <swmodeltestbase.hxx>
+#include <libxml/xpathInternals.h>
+#include <libxml/parserInternals.h>
+
class Test : public SwModelTestBase
{
public:
@@ -74,6 +79,7 @@ public:
void testTextFrames();
void testTextFrameBorders();
void testTextframeGradient();
+ void testCellBtlr();
CPPUNIT_TEST_SUITE(Test);
#if !defined(MACOSX) && !defined(WNT)
@@ -116,6 +122,7 @@ void Test::run()
{"textframes.odt", &Test::testTextFrames},
{"textframe-borders.docx", &Test::testTextFrameBorders},
{"textframe-gradient.docx", &Test::testTextframeGradient},
+ {"cell-btlr.docx", &Test::testCellBtlr},
};
// Don't test the first import of these, for some reason those tests fail
const char* aBlacklist[] = {
@@ -564,6 +571,61 @@ void Test::testTextframeGradient()
CPPUNIT_ASSERT_EQUAL(awt::GradientStyle_AXIAL, aGradient.Style);
}
+void Test::testCellBtlr()
+{
+ /*
+ * The problem was that the exporter didn't mirror the workaround of the
+ * importer, regarding the btLr text direction: the <w:textDirection
+ * w:val="btLr"/> token was completely missing in the output.
+ *
+ * Given that this doesn't affect the result in the importer, we test the
+ * resulting file directly, by opening the zip file, parsing an xml stream,
+ * and asserting an XPath expression. This can be extracted to a helper
+ * method, once it's clear what is common in such tests.
+ */
+
+ // Create the zip file.
+ utl::TempFile aTempFile;
+ aTempFile.EnableKillingFile();
+ uno::Reference<frame::XStorable> xStorable(mxComponent, uno::UNO_QUERY);
+ uno::Sequence<beans::PropertyValue> aFilterArgs(1);
+ aFilterArgs[0].Name = "FilterName";
+ aFilterArgs[0].Value <<= OUString("Office Open XML Text");
+ xStorable->storeToURL(aTempFile.GetURL(), aFilterArgs);
+
+ // Read the XML stream we're interested in.
+ uno::Sequence<uno::Any> aArgs(1);
+ aArgs[0] <<= OUString(aTempFile.GetURL());
+ uno::Reference<container::XNameAccess> xNameAccess(m_xSFactory->createInstanceWithArguments("com.sun.star.packages.zip.ZipFileAccess", aArgs), uno::UNO_QUERY);
+ uno::Reference<io::XInputStream> xInputStream(xNameAccess->getByName("word/document.xml"), uno::UNO_QUERY);
+ boost::shared_ptr<SvStream> pStream(utl::UcbStreamHelper::CreateStream(xInputStream, sal_True));
+ pStream->Seek(STREAM_SEEK_TO_END);
+ sal_Size nSize = pStream->Tell();
+ pStream->Seek(0);
+ OStringBuffer aDocument(nSize);
+ char ch;
+ for (sal_Size i = 0; i < nSize; ++i)
+ {
+ *pStream >> ch;
+ aDocument.append(ch);
+ }
+
+ // Parse the XML.
+ xmlDocPtr pXmlDoc = xmlParseMemory((const char*)aDocument.getStr(), aDocument.getLength());
+
+ // Assert the XPath expression.
+ xmlXPathContextPtr pXmlXpathCtx = xmlXPathNewContext(pXmlDoc);
+ xmlXPathRegisterNs(pXmlXpathCtx, BAD_CAST("w"), BAD_CAST("http://schemas.openxmlformats.org/wordprocessingml/2006/main"));
+ OString aXPath = "/w:document/w:body/w:tbl/w:tr/w:tc/w:tcPr/w:textDirection";
+ xmlXPathObjectPtr pXmlXpathObj = xmlXPathEvalExpression(BAD_CAST(aXPath.getStr()), pXmlXpathCtx);
+ xmlNodeSetPtr pXmlNodes = pXmlXpathObj->nodesetval;
+ CPPUNIT_ASSERT_EQUAL(1, xmlXPathNodeSetGetLength(pXmlNodes));
+ xmlNodePtr pXmlNode = pXmlNodes->nodeTab[0];
+ OString aAttribute = "val";
+ OUString aValue = OUString::createFromAscii((const char*)xmlGetProp(pXmlNode, BAD_CAST(aAttribute.getStr())));
+ CPPUNIT_ASSERT_EQUAL(OUString("btLr"), aValue);
+}
+
CPPUNIT_TEST_SUITE_REGISTRATION(Test);
CPPUNIT_PLUGIN_IMPLEMENT();