1105 lines
44 KiB
C++
1105 lines
44 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/*
|
|
* This file is part of the LibreOffice project.
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*/
|
|
|
|
#include <swmodeltestbase.hxx>
|
|
|
|
#include <com/sun/star/document/XDocumentPropertiesSupplier.hpp>
|
|
#include <com/sun/star/drawing/FillStyle.hpp>
|
|
#include <com/sun/star/drawing/PointSequenceSequence.hpp>
|
|
#include <com/sun/star/style/BreakType.hpp>
|
|
#include <com/sun/star/style/PageStyleLayout.hpp>
|
|
#include <com/sun/star/text/FontEmphasis.hpp>
|
|
#include <com/sun/star/text/TableColumnSeparator.hpp>
|
|
#include <com/sun/star/text/XPageCursor.hpp>
|
|
#include <com/sun/star/text/XTextViewCursorSupplier.hpp>
|
|
#include <com/sun/star/text/WritingMode2.hpp>
|
|
#include <com/sun/star/text/XTextColumns.hpp>
|
|
#include <com/sun/star/text/HoriOrientation.hpp>
|
|
#include <com/sun/star/text/XTextTable.hpp>
|
|
#include <com/sun/star/text/XTextFieldsSupplier.hpp>
|
|
#include <com/sun/star/text/XTextFramesSupplier.hpp>
|
|
#include <com/sun/star/text/XTextTablesSupplier.hpp>
|
|
#include <com/sun/star/text/XBookmarksSupplier.hpp>
|
|
|
|
#include <comphelper/sequenceashashmap.hxx>
|
|
#include <tools/UnitConversion.hxx>
|
|
|
|
using namespace css;
|
|
|
|
namespace
|
|
{
|
|
class Test : public SwModelTestBase
|
|
{
|
|
public:
|
|
Test()
|
|
: SwModelTestBase(u"/sw/qa/extras/rtfexport/data/"_ustr, u"Rich Text Format"_ustr)
|
|
{
|
|
}
|
|
};
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testPictureWrapPolygon)
|
|
{
|
|
auto verify = [this]() {
|
|
// The problem was that the wrap polygon was ignored during import.
|
|
drawing::PointSequenceSequence aSeqSeq
|
|
= getProperty<drawing::PointSequenceSequence>(getShape(1), u"ContourPolyPolygon"_ustr);
|
|
// This was 0: the polygon list was empty.
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(1), aSeqSeq.getLength());
|
|
|
|
drawing::PointSequence aSeq = aSeqSeq[0];
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(11), aSeq.getLength());
|
|
|
|
// The shape also didn't have negative top / left coordinates.
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(convertTwipToMm100(-1177)),
|
|
getProperty<sal_Int32>(getShape(1), u"HoriOrientPosition"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(convertTwipToMm100(-67)),
|
|
getProperty<sal_Int32>(getShape(1), u"VertOrientPosition"_ustr));
|
|
};
|
|
createSwDoc("picture-wrap-polygon.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf113408)
|
|
{
|
|
auto verify = [this]() {
|
|
// This was 0, left margin was not inherited from style properly.
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(1270),
|
|
getProperty<sal_Int32>(getParagraph(1), u"ParaLeftMargin"_ustr));
|
|
};
|
|
createSwDoc("tdf113408.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testAbi10039)
|
|
{
|
|
loadAndReload("abi10039.odt");
|
|
CPPUNIT_ASSERT_EQUAL(1, getShapes());
|
|
CPPUNIT_ASSERT_EQUAL(1, getPages());
|
|
// Make sure we don't just crash on export, and additionally the shape should not be inline (as it's at-page anchored originally).
|
|
CPPUNIT_ASSERT(text::TextContentAnchorType_AS_CHARACTER
|
|
!= getProperty<text::TextContentAnchorType>(getShape(1), u"AnchorType"_ustr));
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testAbi10076)
|
|
{
|
|
loadAndReload("abi10076.odt");
|
|
CPPUNIT_ASSERT_EQUAL(2, getPages());
|
|
// Just make sure that we don't crash after exporting a fully calculated layout.
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testEm)
|
|
{
|
|
auto verify = [this]() {
|
|
// Test all possible \acc* control words.
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
text::FontEmphasis::NONE,
|
|
getProperty<sal_Int16>(getRun(getParagraph(1), 1), u"CharEmphasis"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
text::FontEmphasis::DOT_ABOVE,
|
|
getProperty<sal_Int16>(getRun(getParagraph(1), 2), u"CharEmphasis"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
text::FontEmphasis::ACCENT_ABOVE,
|
|
getProperty<sal_Int16>(getRun(getParagraph(1), 3), u"CharEmphasis"_ustr));
|
|
// This was missing.
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
text::FontEmphasis::CIRCLE_ABOVE,
|
|
getProperty<sal_Int16>(getRun(getParagraph(1), 4), u"CharEmphasis"_ustr));
|
|
// This one, too.
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
text::FontEmphasis::DOT_BELOW,
|
|
getProperty<sal_Int16>(getRun(getParagraph(1), 5), u"CharEmphasis"_ustr));
|
|
};
|
|
createSwDoc("em.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testNumberingFont)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<beans::XPropertySet> xStyle(
|
|
getStyles(u"CharacterStyles"_ustr)->getByName(u"ListLabel 1"_ustr), uno::UNO_QUERY);
|
|
// This was Liberation Serif, i.e. custom font of the numbering itself ("1.\t") was lost on import.
|
|
CPPUNIT_ASSERT_EQUAL(u"Impact"_ustr, getProperty<OUString>(xStyle, u"CharFontName"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(72.f, getProperty<float>(xStyle, u"CharHeight"_ustr));
|
|
};
|
|
createSwDoc("numbering-font.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testFdo82860)
|
|
{
|
|
loadAndReload("fdo82860.odt");
|
|
CPPUNIT_ASSERT_EQUAL(1, getShapes());
|
|
CPPUNIT_ASSERT_EQUAL(1, getPages());
|
|
// The problem was that:
|
|
// 1) The import tried to use fieldmarks for SHAPE fields
|
|
// 2) The exporter did not handle "shape with textbox" text.
|
|
uno::Reference<text::XTextRange> xTextRange(getShape(1), uno::UNO_QUERY);
|
|
uno::Reference<text::XText> xText = xTextRange->getText();
|
|
CPPUNIT_ASSERT_EQUAL(u"hello"_ustr, getParagraphOfText(1, xText)->getString());
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testFdo82858)
|
|
{
|
|
loadAndReload("fdo82858.docx");
|
|
// This was table::BorderLineStyle::SOLID, exporter failed to write explicit no line when line color was written.
|
|
CPPUNIT_ASSERT_EQUAL(table::BorderLineStyle::NONE,
|
|
getProperty<table::BorderLine2>(getShape(1), u"TopBorder"_ustr).LineStyle);
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf104936)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextRange> xShape1(getShape(1), uno::UNO_QUERY);
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(0),
|
|
getProperty<sal_Int32>(xShape1, u"ZOrder"_ustr));
|
|
// This failed, the shape without text covered the shape with text.
|
|
CPPUNIT_ASSERT(xShape1->getString().isEmpty());
|
|
uno::Reference<text::XTextRange> xShape2(getShape(2), uno::UNO_QUERY);
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(1),
|
|
getProperty<sal_Int32>(xShape2, u"ZOrder"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(u"Hello"_ustr, xShape2->getString());
|
|
};
|
|
createSwDoc("tdf104936.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTableRtl)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextTablesSupplier> xTablesSupplier(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<container::XIndexAccess> xTables(xTablesSupplier->getTextTables(),
|
|
uno::UNO_QUERY);
|
|
uno::Reference<text::XTextTable> xTable(xTables->getByIndex(0), uno::UNO_QUERY);
|
|
// This was text::WritingMode2::LR_TB, i.e. direction of the table was ignored.
|
|
CPPUNIT_ASSERT_EQUAL(text::WritingMode2::RL_TB,
|
|
getProperty<sal_Int16>(xTable, u"WritingMode"_ustr));
|
|
};
|
|
createSwDoc("table-rtl.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testNumOverrideStart)
|
|
{
|
|
auto verify = [this]() {
|
|
// The numbering on the second level was "3.1", not "1.3".
|
|
uno::Reference<container::XIndexAccess> xRules
|
|
= getProperty<uno::Reference<container::XIndexAccess>>(
|
|
getStyles(u"NumberingStyles"_ustr)->getByName(u"WWNum1"_ustr),
|
|
u"NumberingRules"_ustr);
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int16(1),
|
|
comphelper::SequenceAsHashMap(xRules->getByIndex(0))[u"StartWith"_ustr]
|
|
.get<sal_Int16>());
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int16(3),
|
|
comphelper::SequenceAsHashMap(xRules->getByIndex(1))[u"StartWith"_ustr]
|
|
.get<sal_Int16>());
|
|
};
|
|
createSwDoc("num-override-start.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testFdo82006)
|
|
{
|
|
auto verify = [this]() {
|
|
// These were 176 (100 twips), as \sbauto and \sbbefore were ignored.
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(0),
|
|
getProperty<sal_Int32>(getParagraph(1), u"ParaTopMargin"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(convertTwipToMm100(280)),
|
|
getProperty<sal_Int32>(getParagraph(1), u"ParaBottomMargin"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(convertTwipToMm100(280)),
|
|
getProperty<sal_Int32>(getParagraph(2), u"ParaTopMargin"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(convertTwipToMm100(280)),
|
|
getProperty<sal_Int32>(getParagraph(2), u"ParaBottomMargin"_ustr));
|
|
};
|
|
createSwDoc("fdo82006.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf104081)
|
|
{
|
|
auto verify = [this]() {
|
|
// These were 494 (280 twips), as \htmautsp was ignored.
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(convertTwipToMm100(100)),
|
|
getProperty<sal_Int32>(getParagraph(1), u"ParaTopMargin"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(convertTwipToMm100(100)),
|
|
getProperty<sal_Int32>(getParagraph(1), u"ParaBottomMargin"_ustr));
|
|
};
|
|
createSwDoc("tdf104081.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf88583)
|
|
{
|
|
loadAndReload("tdf88583.odt");
|
|
CPPUNIT_ASSERT_EQUAL(1, getPages());
|
|
// This was FillStyle_NONE, as background color was missing from the color table during export.
|
|
CPPUNIT_ASSERT_EQUAL(drawing::FillStyle_SOLID,
|
|
getProperty<drawing::FillStyle>(getParagraph(1), u"FillStyle"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(Color(0x00cc00), getProperty<Color>(getParagraph(1), u"FillColor"_ustr));
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testMargmirror)
|
|
{
|
|
auto verify = [this]() {
|
|
// \margmirror was not handled, this was PageStyleLayout_ALL.
|
|
uno::Reference<beans::XPropertySet> xPageStyle(
|
|
getStyles(u"PageStyles"_ustr)->getByName(u"Standard"_ustr), uno::UNO_QUERY);
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
style::PageStyleLayout_MIRRORED,
|
|
getProperty<style::PageStyleLayout>(xPageStyle, u"PageStyleLayout"_ustr));
|
|
};
|
|
createSwDoc("margmirror.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testSautoupd)
|
|
{
|
|
auto verify = [this]() {
|
|
// \sautoupd was ignored during import and export.
|
|
uno::Reference<beans::XPropertySet> xHeading1(
|
|
getStyles(u"ParagraphStyles"_ustr)->getByName(u"Heading 1"_ustr), uno::UNO_QUERY);
|
|
CPPUNIT_ASSERT_EQUAL(true, getProperty<bool>(xHeading1, u"IsAutoUpdate"_ustr));
|
|
uno::Reference<beans::XPropertySet> xHeading2(
|
|
getStyles(u"ParagraphStyles"_ustr)->getByName(u"Heading 2"_ustr), uno::UNO_QUERY);
|
|
CPPUNIT_ASSERT_EQUAL(false, getProperty<bool>(xHeading2, u"IsAutoUpdate"_ustr));
|
|
};
|
|
createSwDoc("sautoupd.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testHyphauto)
|
|
{
|
|
auto verify = [this]() {
|
|
CPPUNIT_ASSERT_EQUAL(true, getProperty<bool>(getParagraph(1), u"ParaIsHyphenation"_ustr));
|
|
};
|
|
createSwDoc("hyphauto.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testHyphpar)
|
|
{
|
|
auto verify = [this]() {
|
|
// Hyphenation was enabled for all 3 paragraphs, but it should be disabled for the 2nd one.
|
|
CPPUNIT_ASSERT_EQUAL(false, getProperty<bool>(getParagraph(2), u"ParaIsHyphenation"_ustr));
|
|
};
|
|
createSwDoc("hyphpar.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf108955)
|
|
{
|
|
auto verify = [this]() {
|
|
CPPUNIT_ASSERT_EQUAL(drawing::FillStyle_SOLID,
|
|
getProperty<drawing::FillStyle>(getParagraph(1), u"FillStyle"_ustr));
|
|
// This was 0xffffff, i.e. non-white background was overwritten from the paragraph style.
|
|
CPPUNIT_ASSERT_EQUAL(Color(0xffff99),
|
|
getProperty<Color>(getParagraph(1), u"FillColor"_ustr));
|
|
};
|
|
createSwDoc("tdf108955.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf80708)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextTablesSupplier> xTextTablesSupplier(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<container::XIndexAccess> xTables(xTextTablesSupplier->getTextTables(),
|
|
uno::UNO_QUERY);
|
|
uno::Reference<text::XTextTable> xTable(xTables->getByIndex(1), uno::UNO_QUERY);
|
|
uno::Reference<table::XTableRows> xTableRows = xTable->getRows();
|
|
// This was 2, i.e. the second table had 3 cols, now 2 as expected.
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(1),
|
|
getProperty<uno::Sequence<text::TableColumnSeparator>>(
|
|
xTableRows->getByIndex(0), u"TableColumnSeparators"_ustr)
|
|
.getLength());
|
|
};
|
|
createSwDoc("tdf80708.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testHyperlinkWithoutURL)
|
|
{
|
|
createSwDoc("tdf90421.fodt");
|
|
// Change the hyperlink, so its URL is empty.
|
|
uno::Reference<beans::XPropertySet> xRun(getRun(getParagraph(1), 2), uno::UNO_QUERY);
|
|
xRun->setPropertyValue(u"HyperLinkURL"_ustr, uno::Any(OUString()));
|
|
saveAndReload(u"Rich Text Format"_ustr);
|
|
SvMemoryStream aMemoryStream;
|
|
SvFileStream aStream(maTempFile.GetURL(), StreamMode::READ);
|
|
aStream.ReadStream(aMemoryStream);
|
|
OString aData(static_cast<const char*>(aMemoryStream.GetData()), aMemoryStream.GetSize());
|
|
// This was some positive number, i.e. we exported a hyperlink with an empty URL.
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(-1), aData.indexOf("HYPERLINK"));
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf92521)
|
|
{
|
|
loadAndReload("tdf92521.odt");
|
|
// There should be a page break that's in the middle of the document: right after the table.
|
|
// But there wasn't, so this was 1.
|
|
CPPUNIT_ASSERT_EQUAL(2, getPages());
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf114309)
|
|
{
|
|
auto verify = [this]() {
|
|
// Without the fix in place, this test would have failed with
|
|
// - the property is of unexpected type or void: TextSection
|
|
auto xTextSection = getProperty<uno::Reference<beans::XPropertySet>>(getParagraph(1),
|
|
u"TextSection"_ustr);
|
|
auto xTextColumns
|
|
= getProperty<uno::Reference<text::XTextColumns>>(xTextSection, u"TextColumns"_ustr);
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int16(2), xTextColumns->getColumnCount());
|
|
};
|
|
createSwDoc("tdf114309.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf94043)
|
|
{
|
|
auto verify = [this]() {
|
|
auto xTextSection = getProperty<uno::Reference<beans::XPropertySet>>(getParagraph(2),
|
|
u"TextSection"_ustr);
|
|
auto xTextColumns
|
|
= getProperty<uno::Reference<text::XTextColumns>>(xTextSection, u"TextColumns"_ustr);
|
|
// This was 0, the separator line was not visible due to 0 width.
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(2),
|
|
getProperty<sal_Int32>(xTextColumns, u"SeparatorLineWidth"_ustr));
|
|
|
|
CPPUNIT_ASSERT_EQUAL(7, getParagraphs());
|
|
};
|
|
createSwDoc("tdf94043.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf94377)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextFieldsSupplier> xTextFieldsSupplier(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<container::XEnumerationAccess> xFieldsAccess(
|
|
xTextFieldsSupplier->getTextFields());
|
|
uno::Reference<container::XEnumeration> xFields(xFieldsAccess->createEnumeration());
|
|
uno::Reference<beans::XPropertySet> xPropertySet(xFields->nextElement(), uno::UNO_QUERY);
|
|
auto xText = getProperty<uno::Reference<text::XText>>(xPropertySet, u"TextRange"_ustr);
|
|
// This failed, as:
|
|
// 1) multiple paragraphs were not exported, so the text was "Asdf10asdf12".
|
|
// 2) direct formatting of runs were not exported, so this was 12 (the document default).
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
10.f, getProperty<float>(getRun(getParagraphOfText(1, xText, u"Asdf10"_ustr), 1),
|
|
u"CharHeight"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
12.f, getProperty<float>(getRun(getParagraphOfText(2, xText, u"asdf12"_ustr), 1),
|
|
u"CharHeight"_ustr));
|
|
};
|
|
createSwDoc("tdf94377.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf104079)
|
|
{
|
|
auto verify = [this]() {
|
|
bool bFound = false;
|
|
int nIndex = 0;
|
|
while (!bFound)
|
|
{
|
|
uno::Reference<text::XTextRange> xParagraph = getParagraph(++nIndex);
|
|
if (!xParagraph->getString().startsWith("toc3"))
|
|
continue;
|
|
|
|
bFound = true;
|
|
// This was 0, 3rd paragraph of ToC lost its bottom paragraph margin.
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(212),
|
|
getProperty<sal_Int32>(xParagraph, u"ParaBottomMargin"_ustr));
|
|
}
|
|
};
|
|
createSwDoc("tdf104079.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testPageBackground)
|
|
{
|
|
auto verify = [this]() {
|
|
// The problem was that \background was ignored.
|
|
uno::Reference<beans::XPropertySet> xPageStyle(
|
|
getStyles(u"PageStyles"_ustr)->getByName(u"Standard"_ustr), uno::UNO_QUERY);
|
|
CPPUNIT_ASSERT_EQUAL(Color(0x92D050), getProperty<Color>(xPageStyle, u"BackColor"_ustr));
|
|
};
|
|
createSwDoc("page-background.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf96175)
|
|
{
|
|
auto verify = [this]() {
|
|
// The problem that a user defined property named "Company" was lost on export.
|
|
uno::Reference<document::XDocumentPropertiesSupplier> xDocumentPropertiesSupplier(
|
|
mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<document::XDocumentProperties> xDocumentProperties
|
|
= xDocumentPropertiesSupplier->getDocumentProperties();
|
|
uno::Reference<beans::XPropertyContainer> xUserDefinedProperties
|
|
= xDocumentProperties->getUserDefinedProperties();
|
|
// This resulted in a beans::UnknownPropertyException.
|
|
CPPUNIT_ASSERT_EQUAL(u"foobar"_ustr,
|
|
getProperty<OUString>(xUserDefinedProperties, u"Company"_ustr));
|
|
};
|
|
createSwDoc("tdf96175.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testRedline)
|
|
{
|
|
auto verify = [this]() {
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
u"Rebecca Lopez"_ustr,
|
|
getProperty<OUString>(getRun(getParagraph(1), 2), u"RedlineAuthor"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
u"Dorothy Jones"_ustr,
|
|
getProperty<OUString>(getRun(getParagraph(2), 2), u"RedlineAuthor"_ustr));
|
|
};
|
|
createSwDoc("redline.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testCustomDocProps)
|
|
{
|
|
auto verify = [this]() {
|
|
// Custom document properties were not improved, this resulted in a beans::UnknownPropertyException.
|
|
uno::Reference<document::XDocumentPropertiesSupplier> xDocumentPropertiesSupplier(
|
|
mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<document::XDocumentProperties> xDocumentProperties
|
|
= xDocumentPropertiesSupplier->getDocumentProperties();
|
|
uno::Reference<beans::XPropertyContainer> xUserDefinedProperties
|
|
= xDocumentProperties->getUserDefinedProperties();
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
u"2016-03-08T10:55:18,531376147"_ustr,
|
|
getProperty<OUString>(
|
|
xUserDefinedProperties,
|
|
u"urn:bails:IntellectualProperty:Authorization:StartValidity"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
u"None"_ustr, getProperty<OUString>(
|
|
xUserDefinedProperties,
|
|
u"urn:bails:IntellectualProperty:Authorization:StopValidity"_ustr));
|
|
// Test roundtrip of numbers. This failed as getProperty() did not find "n".
|
|
CPPUNIT_ASSERT_EQUAL(42.0, getProperty<double>(xUserDefinedProperties, u"n"_ustr));
|
|
// Test boolean "yes".
|
|
CPPUNIT_ASSERT(getProperty<bool>(xUserDefinedProperties, u"by"_ustr));
|
|
// Test boolean "no".
|
|
CPPUNIT_ASSERT(!getProperty<bool>(xUserDefinedProperties, u"bn"_ustr));
|
|
|
|
// Test roundtrip of date in general, and year/month/day in particular.
|
|
util::DateTime aDate = getProperty<util::DateTime>(xUserDefinedProperties, u"d"_ustr);
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int16>(2016), aDate.Year);
|
|
CPPUNIT_ASSERT_EQUAL(o3tl::narrowing<sal_uInt16>(1), aDate.Month);
|
|
CPPUNIT_ASSERT_EQUAL(o3tl::narrowing<sal_uInt16>(30), aDate.Day);
|
|
|
|
// Test real number.
|
|
CPPUNIT_ASSERT_EQUAL(3.14, getProperty<double>(xUserDefinedProperties, u"pi"_ustr));
|
|
};
|
|
createSwDoc("custom-doc-props.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf65642)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<container::XNameAccess> xPageStyles = getStyles(u"PageStyles"_ustr);
|
|
uno::Reference<frame::XModel> xModel(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<text::XTextViewCursorSupplier> xTextViewCursorSupplier(
|
|
xModel->getCurrentController(), uno::UNO_QUERY);
|
|
uno::Reference<text::XPageCursor> xCursor(xTextViewCursorSupplier->getViewCursor(),
|
|
uno::UNO_QUERY);
|
|
xCursor->jumpToLastPage();
|
|
OUString pageStyleName = getProperty<OUString>(xCursor, u"PageStyleName"_ustr);
|
|
// The second page's numbering type: this was style::NumberingType::ARABIC.
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
style::NumberingType::CHARS_UPPER_LETTER_N,
|
|
getProperty<sal_Int16>(xPageStyles->getByName(pageStyleName), u"NumberingType"_ustr));
|
|
// The second page's restart value: this was 0.
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(1),
|
|
getProperty<sal_Int32>(getParagraph(2), u"PageNumberOffset"_ustr));
|
|
};
|
|
createSwDoc("tdf65642.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testPgnlcltr)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<container::XNameAccess> xPageStyles = getStyles(u"PageStyles"_ustr);
|
|
uno::Reference<frame::XModel> xModel(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<text::XTextViewCursorSupplier> xTextViewCursorSupplier(
|
|
xModel->getCurrentController(), uno::UNO_QUERY);
|
|
uno::Reference<text::XPageCursor> xCursor(xTextViewCursorSupplier->getViewCursor(),
|
|
uno::UNO_QUERY);
|
|
xCursor->jumpToLastPage();
|
|
OUString pageStyleName = getProperty<OUString>(xCursor, u"PageStyleName"_ustr);
|
|
// The second page's numbering type: this was style::NumberingType::ARABIC.
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
style::NumberingType::CHARS_LOWER_LETTER_N,
|
|
getProperty<sal_Int16>(xPageStyles->getByName(pageStyleName), u"NumberingType"_ustr));
|
|
};
|
|
createSwDoc("pgnlcltr.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testPgnucrm)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<container::XNameAccess> xPageStyles = getStyles(u"PageStyles"_ustr);
|
|
uno::Reference<frame::XModel> xModel(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<text::XTextViewCursorSupplier> xTextViewCursorSupplier(
|
|
xModel->getCurrentController(), uno::UNO_QUERY);
|
|
uno::Reference<text::XPageCursor> xCursor(xTextViewCursorSupplier->getViewCursor(),
|
|
uno::UNO_QUERY);
|
|
xCursor->jumpToLastPage();
|
|
OUString pageStyleName = getProperty<OUString>(xCursor, u"PageStyleName"_ustr);
|
|
// The second page's numbering type: this was style::NumberingType::ARABIC.
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
style::NumberingType::ROMAN_UPPER,
|
|
getProperty<sal_Int16>(xPageStyles->getByName(pageStyleName), u"NumberingType"_ustr));
|
|
};
|
|
createSwDoc("pgnucrm.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testPgnlcrm)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<container::XNameAccess> xPageStyles = getStyles(u"PageStyles"_ustr);
|
|
uno::Reference<frame::XModel> xModel(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<text::XTextViewCursorSupplier> xTextViewCursorSupplier(
|
|
xModel->getCurrentController(), uno::UNO_QUERY);
|
|
uno::Reference<text::XPageCursor> xCursor(xTextViewCursorSupplier->getViewCursor(),
|
|
uno::UNO_QUERY);
|
|
xCursor->jumpToLastPage();
|
|
OUString pageStyleName = getProperty<OUString>(xCursor, u"PageStyleName"_ustr);
|
|
// The second page's numbering type: this was style::NumberingType::ARABIC.
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
style::NumberingType::ROMAN_LOWER,
|
|
getProperty<sal_Int16>(xPageStyles->getByName(pageStyleName), u"NumberingType"_ustr));
|
|
};
|
|
createSwDoc("pgnlcrm.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testPgndec)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<container::XNameAccess> xPageStyles = getStyles(u"PageStyles"_ustr);
|
|
uno::Reference<frame::XModel> xModel(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<text::XTextViewCursorSupplier> xTextViewCursorSupplier(
|
|
xModel->getCurrentController(), uno::UNO_QUERY);
|
|
uno::Reference<text::XPageCursor> xCursor(xTextViewCursorSupplier->getViewCursor(),
|
|
uno::UNO_QUERY);
|
|
xCursor->jumpToLastPage();
|
|
OUString pageStyleName = getProperty<OUString>(xCursor, u"PageStyleName"_ustr);
|
|
// The second page's numbering type: this was style::NumberingType::ROMAN_LOWER.
|
|
CPPUNIT_ASSERT_EQUAL(
|
|
style::NumberingType::ARABIC,
|
|
getProperty<sal_Int16>(xPageStyles->getByName(pageStyleName), u"NumberingType"_ustr));
|
|
|
|
// tdf#82111 ensure a paragraph exists before a section break.
|
|
// This was only two paragraphs, and both page number fields were in one para on page 2 ("11").
|
|
getParagraph(2, u"1"_ustr);
|
|
CPPUNIT_ASSERT_EQUAL(3, getParagraphs());
|
|
};
|
|
createSwDoc("pgndec.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf98806)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XBookmarksSupplier> xBookmarksSupplier(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<text::XTextContent> xBookmark(
|
|
xBookmarksSupplier->getBookmarks()->getByName(u"bookmark"_ustr), uno::UNO_QUERY);
|
|
// This was empty, bookmark in table wasn't imported correctly.
|
|
CPPUNIT_ASSERT_EQUAL(u"BBB"_ustr, xBookmark->getAnchor()->getString());
|
|
};
|
|
createSwDoc("tdf98806.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf61901)
|
|
{
|
|
createSwDoc("tdf61901.rtf");
|
|
save(mpFilter);
|
|
// Test the file directly, as current RTF import gives the correct font name with and without the fix.
|
|
SvStream* pStream = maTempFile.GetStream(StreamMode::READ);
|
|
OString sLine;
|
|
while (pStream->ReadLine(sLine))
|
|
{
|
|
sal_Int32 nIndex = sLine.indexOf("\\loch\\loch");
|
|
if (nIndex != -1)
|
|
{
|
|
// Make sure that \hich is always written after a \loch\loch.
|
|
OString sRemaining = sLine.copy(nIndex);
|
|
CPPUNIT_ASSERT(sRemaining.indexOf("\\hich") != -1);
|
|
}
|
|
}
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf103925)
|
|
{
|
|
auto verify = [this]() {
|
|
// This was true, \animtext0 resulted in setting the blinking font effect.
|
|
CPPUNIT_ASSERT_EQUAL(false,
|
|
getProperty<bool>(getRun(getParagraph(1), 1), u"CharFlash"_ustr));
|
|
};
|
|
createSwDoc("tdf103925.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf104228)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextTable> xTable(getParagraphOrTable(2), uno::UNO_QUERY);
|
|
uno::Reference<text::XTextRange> xCell(xTable->getCellByName(u"C1"_ustr), uno::UNO_QUERY);
|
|
uno::Reference<text::XTextRange> xParagraph = getParagraphOfText(1, xCell->getText());
|
|
// This was 2103, implicit 0 as direct formatting was ignored on the
|
|
// paragraph (and the style had this larger value).
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(0),
|
|
getProperty<sal_Int32>(xParagraph, u"ParaLeftMargin"_ustr));
|
|
};
|
|
createSwDoc("tdf104228.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf104085)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextRange> xPara(getParagraph(1));
|
|
uno::Reference<beans::XPropertySet> properties(xPara, uno::UNO_QUERY);
|
|
uno::Reference<container::XIndexAccess> xLevels(
|
|
properties->getPropertyValue(u"NumberingRules"_ustr), uno::UNO_QUERY);
|
|
uno::Sequence<beans::PropertyValue> aProps;
|
|
xLevels->getByIndex(0) >>= aProps;
|
|
for (beans::PropertyValue const& prop : aProps)
|
|
{
|
|
if (prop.Name == "BulletChar")
|
|
return;
|
|
}
|
|
CPPUNIT_FAIL("no BulletChar property");
|
|
};
|
|
createSwDoc("tdf104085.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf113550)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextTable> xTable(getParagraphOrTable(1), uno::UNO_QUERY);
|
|
uno::Reference<text::XTextRange> xCell(xTable->getCellByName(u"A1"_ustr), uno::UNO_QUERY);
|
|
uno::Reference<text::XTextRange> xParagraph = getParagraphOfText(1, xCell->getText());
|
|
// This was 2501, 0 as direct formatting was ignored on the paragraph (and
|
|
// the style had this larger value).
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(0),
|
|
getProperty<sal_Int32>(xParagraph, u"ParaLeftMargin"_ustr));
|
|
};
|
|
createSwDoc("tdf113550.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testLeveljcCenter)
|
|
{
|
|
auto verify = [this]() {
|
|
// Tests that \leveljc1 is mapped to Adjust=Center for a numbering rule.
|
|
uno::Reference<text::XTextRange> xPara(getParagraph(1));
|
|
uno::Reference<beans::XPropertySet> properties(xPara, uno::UNO_QUERY);
|
|
uno::Reference<container::XIndexAccess> xLevels(
|
|
properties->getPropertyValue(u"NumberingRules"_ustr), uno::UNO_QUERY);
|
|
uno::Sequence<beans::PropertyValue> aProps;
|
|
xLevels->getByIndex(0) >>= aProps;
|
|
for (beans::PropertyValue const& prop : aProps)
|
|
{
|
|
if (prop.Name == "Adjust")
|
|
{
|
|
sal_Int16 nValue = 0;
|
|
CPPUNIT_ASSERT(prop.Value >>= nValue);
|
|
CPPUNIT_ASSERT_EQUAL(text::HoriOrientation::CENTER, nValue);
|
|
return;
|
|
}
|
|
}
|
|
CPPUNIT_FAIL("no Adjust property");
|
|
};
|
|
createSwDoc("leveljc-center.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testHyperlinkTarget)
|
|
{
|
|
auto verify = [this]() {
|
|
// This was empty, hyperlink target was lost on import.
|
|
CPPUNIT_ASSERT_EQUAL(u"_blank"_ustr, getProperty<OUString>(getRun(getParagraph(1), 1),
|
|
u"HyperLinkTarget"_ustr));
|
|
};
|
|
createSwDoc("hyperlink-target.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf107620)
|
|
{
|
|
loadAndReload("tdf107620.docx");
|
|
// This failed, RTF export didn't write the \htmautsp compat flag, the
|
|
// original bugdoc resulting in 2 pages instead of 1.
|
|
uno::Reference<lang::XMultiServiceFactory> xFactory(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<beans::XPropertySet> xSettings(
|
|
xFactory->createInstance(u"com.sun.star.document.Settings"_ustr), uno::UNO_QUERY);
|
|
bool bAddParaTableSpacing = true;
|
|
xSettings->getPropertyValue(u"AddParaTableSpacing"_ustr) >>= bAddParaTableSpacing;
|
|
CPPUNIT_ASSERT(!bAddParaTableSpacing);
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf104937)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextTablesSupplier> xTextTablesSupplier(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<container::XIndexAccess> xTables(xTextTablesSupplier->getTextTables(),
|
|
uno::UNO_QUERY);
|
|
uno::Reference<text::XTextTable> xTable(xTables->getByIndex(0), uno::UNO_QUERY);
|
|
uno::Reference<table::XTableRows> xTableRows = xTable->getRows();
|
|
auto aSeparators = getProperty<uno::Sequence<text::TableColumnSeparator>>(
|
|
xTableRows->getByIndex(1), u"TableColumnSeparators"_ustr);
|
|
// First table's second row had 9 cells (so 8 separators).
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(8), aSeparators.getLength());
|
|
// This was 3174, i.e. last cell was wider than expected, while others were
|
|
// narrower.
|
|
CPPUNIT_ASSERT_GREATER(static_cast<sal_Int16>(4500), aSeparators[7].Position);
|
|
};
|
|
createSwDoc("tdf104937.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf112507)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextTablesSupplier> xTextTablesSupplier(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<container::XIndexAccess> xTables(xTextTablesSupplier->getTextTables(),
|
|
uno::UNO_QUERY);
|
|
uno::Reference<text::XTextTable> xTable(xTables->getByIndex(0), uno::UNO_QUERY);
|
|
uno::Reference<table::XTableRows> xTableRows = xTable->getRows();
|
|
auto aSeparators = getProperty<uno::Sequence<text::TableColumnSeparator>>(
|
|
xTableRows->getByIndex(1), u"TableColumnSeparators"_ustr);
|
|
// First table's second row had 3 cells (so 2 separators).
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(2), aSeparators.getLength());
|
|
// This was 3333, i.e. the B2 cell was too narrow and the text needed 2 lines.
|
|
CPPUNIT_ASSERT_GREATEREQUAL(5000, aSeparators[1].Position - aSeparators[0].Position);
|
|
};
|
|
createSwDoc("tdf112507.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf107480)
|
|
{
|
|
auto verify = [this]() {
|
|
// These were 176 (100 twips), as \htmautsp was parsed too late.
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(0),
|
|
getProperty<sal_Int32>(getParagraph(1), u"ParaTopMargin"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(convertTwipToMm100(280)),
|
|
getProperty<sal_Int32>(getParagraph(1), u"ParaBottomMargin"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(convertTwipToMm100(280)),
|
|
getProperty<sal_Int32>(getParagraph(2), u"ParaTopMargin"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(convertTwipToMm100(280)),
|
|
getProperty<sal_Int32>(getParagraph(2), u"ParaBottomMargin"_ustr));
|
|
};
|
|
createSwDoc("tdf107480.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testWatermark)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextRange> xShape(getShape(1), uno::UNO_QUERY);
|
|
CPPUNIT_ASSERT_EQUAL(u"WatermarkRTF"_ustr, xShape->getString());
|
|
|
|
uno::Reference<beans::XPropertySet> xPropertySet(xShape, uno::UNO_QUERY);
|
|
OUString aFont;
|
|
float nFontSize;
|
|
|
|
// Check transparency
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int16(50),
|
|
getProperty<sal_Int16>(xShape, u"FillTransparence"_ustr));
|
|
|
|
// Check font family
|
|
CPPUNIT_ASSERT(xPropertySet->getPropertyValue(u"CharFontName"_ustr) >>= aFont);
|
|
CPPUNIT_ASSERT_EQUAL(u"DejaVu Serif"_ustr, aFont);
|
|
|
|
// Check font size
|
|
CPPUNIT_ASSERT(xPropertySet->getPropertyValue(u"CharHeight"_ustr) >>= nFontSize);
|
|
CPPUNIT_ASSERT_EQUAL(float(66), nFontSize);
|
|
};
|
|
createSwDoc("watermark.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf153194Compat)
|
|
{
|
|
auto verify = [this]() {
|
|
CPPUNIT_ASSERT_EQUAL(2, getPages());
|
|
// no \spltpgpar => paragraph 2 on page 1
|
|
CPPUNIT_ASSERT_EQUAL(style::BreakType_NONE,
|
|
getProperty<style::BreakType>(getParagraph(1), u"BreakType"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(style::BreakType_PAGE_BEFORE,
|
|
getProperty<style::BreakType>(getParagraph(2), u"BreakType"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(style::BreakType_NONE,
|
|
getProperty<style::BreakType>(getParagraph(3), u"BreakType"_ustr));
|
|
};
|
|
createSwDoc("page-break-emptyparas.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf153194New)
|
|
{
|
|
auto verify = [this]() {
|
|
CPPUNIT_ASSERT_EQUAL(2, getPages());
|
|
// \spltpgpar => paragraph 2 on page 2
|
|
CPPUNIT_ASSERT_EQUAL(style::BreakType_NONE,
|
|
getProperty<style::BreakType>(getParagraph(1), u"BreakType"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(style::BreakType_NONE,
|
|
getProperty<style::BreakType>(getParagraph(2), u"BreakType"_ustr));
|
|
CPPUNIT_ASSERT_EQUAL(style::BreakType_PAGE_BEFORE,
|
|
getProperty<style::BreakType>(getParagraph(3), u"BreakType"_ustr));
|
|
};
|
|
createSwDoc("page-break-emptyparas-spltpgpar.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf153178)
|
|
{
|
|
auto verify = [this]() {
|
|
// the problem was that a frame was created
|
|
uno::Reference<text::XTextFramesSupplier> xTextFramesSupplier(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<container::XIndexAccess> xIndexAccess(xTextFramesSupplier->getTextFrames(),
|
|
uno::UNO_QUERY);
|
|
CPPUNIT_ASSERT_EQUAL(sal_Int32(0), xIndexAccess->getCount());
|
|
};
|
|
createSwDoc("tdf153178.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf109790)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextTable> xTable(getParagraphOrTable(2), uno::UNO_QUERY);
|
|
uno::Reference<text::XTextRange> xCell(xTable->getCellByName(u"A1"_ustr), uno::UNO_QUERY);
|
|
// Style information was reset, which caused character height to be 22.
|
|
CPPUNIT_ASSERT_EQUAL(10.f,
|
|
getProperty<float>(getRun(getParagraphOfText(1, xCell->getText()), 1),
|
|
u"CharHeight"_ustr));
|
|
};
|
|
createSwDoc("tdf109790.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf112211)
|
|
{
|
|
auto verify = [this]() {
|
|
// This was 0, \fi in a list level definition was not imported.
|
|
auto xRules = getProperty<uno::Reference<container::XIndexAccess>>(
|
|
getStyles(u"NumberingStyles"_ustr)->getByName(u"WWNum1"_ustr), u"NumberingRules"_ustr);
|
|
comphelper::SequenceAsHashMap aRule(xRules->getByIndex(0));
|
|
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(-635),
|
|
aRule[u"FirstLineIndent"_ustr].get<sal_Int32>());
|
|
};
|
|
createSwDoc("tdf112211.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf113202)
|
|
{
|
|
auto verify = [this]() {
|
|
// This failed, contextual spacing in 4th paragraph was lost.
|
|
CPPUNIT_ASSERT(getProperty<bool>(getParagraph(4), u"ParaContextMargin"_ustr));
|
|
};
|
|
createSwDoc("tdf113202.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf156030)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextFieldsSupplier> xTextFieldsSupplier(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<container::XEnumerationAccess> xFieldsAccess(
|
|
xTextFieldsSupplier->getTextFields());
|
|
uno::Reference<container::XEnumeration> xFields(xFieldsAccess->createEnumeration());
|
|
|
|
// As usual, fields given by FieldsAccess are not in same order as in the document
|
|
// (mostly in reverse order, thanks to SwModify::Add)
|
|
std::vector<std::vector<OUString>> aExpectedValues = {
|
|
{ u"1 FORMULA 2"_ustr, u"true value 1"_ustr,
|
|
u"false value 1"_ustr }, // #1, condition should be 1 = 2
|
|
{ u""_ustr, u""_ustr, u""_ustr }, // #9, not enough field params
|
|
{ u"1 1 FORMULA 1 2 1 true value 8 fal"_ustr, u"se"_ustr,
|
|
u"value 8"_ustr }, // #8, nonsense in field params
|
|
{ u"1 1 FORMULA 1 2 1 true value 7 false"_ustr, u"value"_ustr,
|
|
u"7"_ustr }, // #7, another parse error
|
|
{ u"1 < 2"_ustr, u"true value 6"_ustr, u"false value 6"_ustr }, // #6
|
|
{ u"1 > 2"_ustr, u"true value 5"_ustr, u"false value 5"_ustr }, // #5
|
|
{ u"1 <> 2"_ustr, u"true value 4"_ustr, u"false value 4"_ustr }, // #4
|
|
{ u"1 != 2"_ustr, u"true value 3"_ustr, u"false value 3"_ustr }, // #3
|
|
{ u"1 FORMULA FORMULA 2"_ustr, u"true value 2"_ustr,
|
|
u"false value 2"_ustr }, // #2, condition expected 1 == 2
|
|
};
|
|
uno::Reference<beans::XPropertySet> xPropertySet;
|
|
OUString sValue;
|
|
|
|
for (const auto& aValues : aExpectedValues)
|
|
{
|
|
xPropertySet.set(xFields->nextElement(), uno::UNO_QUERY_THROW);
|
|
CPPUNIT_ASSERT(xPropertySet.is());
|
|
CPPUNIT_ASSERT(xPropertySet->getPropertyValue(u"Condition"_ustr) >>= sValue);
|
|
CPPUNIT_ASSERT_EQUAL(aValues[0], sValue);
|
|
CPPUNIT_ASSERT(xPropertySet->getPropertyValue(u"TrueContent"_ustr) >>= sValue);
|
|
CPPUNIT_ASSERT_EQUAL(aValues[1], sValue);
|
|
CPPUNIT_ASSERT(xPropertySet->getPropertyValue(u"FalseContent"_ustr) >>= sValue);
|
|
CPPUNIT_ASSERT_EQUAL(aValues[2], sValue);
|
|
}
|
|
|
|
// No more fields
|
|
CPPUNIT_ASSERT(!xFields->hasMoreElements());
|
|
};
|
|
createSwDoc("tdf156030.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf153195)
|
|
{
|
|
auto verify = [this]() {
|
|
uno::Reference<text::XTextTablesSupplier> xTextTablesSupplier(mxComponent, uno::UNO_QUERY);
|
|
uno::Reference<container::XIndexAccess> xTables(xTextTablesSupplier->getTextTables(),
|
|
uno::UNO_QUERY);
|
|
|
|
// Table margin test (cannot be set to exact value, it jumps between -1991 and -1983)
|
|
CPPUNIT_ASSERT_DOUBLES_EQUAL(
|
|
sal_Int32(-2182), getProperty<sal_Int32>(xTables->getByIndex(0), u"LeftMargin"_ustr),
|
|
10);
|
|
CPPUNIT_ASSERT_DOUBLES_EQUAL(
|
|
sal_Int32(-2182), getProperty<sal_Int32>(xTables->getByIndex(1), u"LeftMargin"_ustr),
|
|
10);
|
|
};
|
|
createSwDoc("tdf153195.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(Test, testTdf158762)
|
|
{
|
|
auto verify = [this]() {
|
|
for (int paragraph = 3; paragraph < 6; ++paragraph)
|
|
{
|
|
uno::Reference<text::XTextRange> xPara(getParagraph(paragraph));
|
|
uno::Reference<beans::XPropertySet> properties(xPara, uno::UNO_QUERY);
|
|
uno::Reference<container::XIndexAccess> xLevels(
|
|
properties->getPropertyValue(u"NumberingRules"_ustr), uno::UNO_QUERY);
|
|
CPPUNIT_ASSERT(xLevels.is());
|
|
}
|
|
};
|
|
createSwDoc("tdf158762.rtf");
|
|
verify();
|
|
saveAndReload(mpFilter);
|
|
verify();
|
|
}
|
|
|
|
} // end of anonymous namespace
|
|
CPPUNIT_PLUGIN_IMPLEMENT();
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|