office-gobmx/sw/qa/uibase/uno/uno.cxx
Xisco Fauli 42ca17dd19 SwModelTestBase: add getSwTextDoc and use it everywhere
Change-Id: I09f132a9c79f0aa4c3f4d3ca5f2fed233d0dcb06
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/175641
Tested-by: Jenkins
Reviewed-by: Xisco Fauli <xiscofauli@libreoffice.org>
2024-10-30 00:30:44 +01:00

576 lines
27 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 <boost/property_tree/json_parser.hpp>
#include <com/sun/star/frame/XModel2.hpp>
#include <com/sun/star/text/XTextViewTextRangeSupplier.hpp>
#include <com/sun/star/util/XCloseable.hpp>
#include <com/sun/star/text/XTextDocument.hpp>
#include <com/sun/star/beans/PropertyAttribute.hpp>
#include <vcl/scheduler.hxx>
#include <tools/json_writer.hxx>
#include <comphelper/propertyvalue.hxx>
#include <xmloff/odffields.hxx>
#include <docsh.hxx>
#include <edtwin.hxx>
#include <unotextrange.hxx>
#include <view.hxx>
#include <wrtsh.hxx>
#include <rootfrm.hxx>
#include <sortedobjs.hxx>
#include <anchoredobject.hxx>
#include <frameformats.hxx>
#include <fmtanchr.hxx>
#include <unotxdoc.hxx>
/// Covers sw/source/uibase/uno/ fixes.
class SwUibaseUnoTest : public SwModelTestBase
{
public:
SwUibaseUnoTest()
: SwModelTestBase(u"/sw/qa/uibase/uno/data/"_ustr)
{
}
};
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testLockControllers)
{
createSwDoc();
{
uno::Reference<frame::XModel> xModel(mxComponent, uno::UNO_QUERY_THROW);
xModel->lockControllers();
}
{
uno::Reference<util::XCloseable> xCloseable(mxComponent, uno::UNO_QUERY_THROW);
xCloseable->close(false);
}
// Without the accompanying fix in place, this test would have crashed.
mxComponent.clear();
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testCondFieldCachedValue)
{
createSwDoc("cond-field-cached-value.docx");
Scheduler::ProcessEventsToIdle();
// Without the accompanying fix in place, this test would have failed with:
// - Expected: 1
// - Actual :
// i.e. the conditional field lost its cached content.
getParagraph(2, u"1"_ustr);
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testCreateTextRangeByPixelPosition)
{
// Given a document with 2 characters, and the pixel position of the point between them:
createSwDoc();
SwDoc* pDoc = getSwDoc();
SwDocShell* pDocShell = getSwDocShell();
SwWrtShell* pWrtShell = pDocShell->GetWrtShell();
pWrtShell->Insert2(u"AZ"_ustr);
pWrtShell->Left(SwCursorSkipMode::Chars, /*bSelect=*/false, 1, /*bBasicCall=*/false);
Point aLogic = pWrtShell->GetCharRect().Center();
SwView* pView = pDocShell->GetView();
SwEditWin& rEditWin = pView->GetEditWin();
Point aPixel = rEditWin.LogicToPixel(aLogic);
// When converting that pixel position to a document model position (text range):
uno::Reference<frame::XModel2> xModel(mxComponent, uno::UNO_QUERY);
uno::Reference<container::XEnumeration> xControllers = xModel->getControllers();
uno::Reference<text::XTextViewTextRangeSupplier> xController(xControllers->nextElement(),
uno::UNO_QUERY);
awt::Point aPoint(aPixel.getX(), aPixel.getY());
uno::Reference<text::XTextRange> xTextRange
= xController->createTextRangeByPixelPosition(aPoint);
// Then make sure that text range points after the first character:
auto pTextRange = dynamic_cast<SwXTextRange*>(xTextRange.get());
SwPaM aPaM(pDoc->GetNodes());
pTextRange->GetPositions(aPaM);
sal_Int32 nActual = aPaM.GetPoint()->GetContentIndex();
// Without the needed PixelToLogic() call in place, this test would have failed with:
// - Expected: 1
// - Actual : 0
// i.e. the returned text range pointed before the first character, not between the first and
// the second character.
CPPUNIT_ASSERT_EQUAL(static_cast<sal_Int32>(1), nActual);
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testCreateTextRangeByPixelPositionGraphic)
{
// Given a document with an as-char image and the center of that image in pixels:
createSwDoc();
uno::Reference<lang::XMultiServiceFactory> xFactory(mxComponent, uno::UNO_QUERY);
uno::Reference<beans::XPropertySet> xTextGraphic(
xFactory->createInstance(u"com.sun.star.text.TextGraphicObject"_ustr), uno::UNO_QUERY);
xTextGraphic->setPropertyValue(u"AnchorType"_ustr,
uno::Any(text::TextContentAnchorType_AS_CHARACTER));
xTextGraphic->setPropertyValue(u"Width"_ustr, uno::Any(static_cast<sal_Int32>(10000)));
xTextGraphic->setPropertyValue(u"Height"_ustr, uno::Any(static_cast<sal_Int32>(10000)));
uno::Reference<text::XTextDocument> xTextDocument(mxComponent, uno::UNO_QUERY);
uno::Reference<text::XText> xBodyText = xTextDocument->getText();
uno::Reference<text::XTextCursor> xCursor(xBodyText->createTextCursor());
uno::Reference<text::XTextContent> xTextContent(xTextGraphic, uno::UNO_QUERY);
xBodyText->insertTextContent(xCursor, xTextContent, false);
SwDoc* pDoc = getSwDoc();
SwDocShell* pDocShell = getSwDocShell();
SwWrtShell* pWrtShell = pDocShell->GetWrtShell();
SwRootFrame* pLayout = pWrtShell->GetLayout();
SwFrame* pPage = pLayout->GetLower();
SwFrame* pBody = pPage->GetLower();
SwFrame* pText = pBody->GetLower();
SwSortedObjs& rDrawObjs = *pText->GetDrawObjs();
SwAnchoredObject* pAnchored = rDrawObjs[0];
Point aLogic = pAnchored->GetObjRect().Center();
SwView* pView = pDocShell->GetView();
SwEditWin& rEditWin = pView->GetEditWin();
Point aPixel = rEditWin.LogicToPixel(aLogic);
// When converting that pixel position to a document model position (text range):
uno::Reference<frame::XModel2> xModel(mxComponent, uno::UNO_QUERY);
uno::Reference<container::XEnumeration> xControllers = xModel->getControllers();
uno::Reference<text::XTextViewTextRangeSupplier> xController(xControllers->nextElement(),
uno::UNO_QUERY);
awt::Point aPoint(aPixel.getX(), aPixel.getY());
// Without the accompanying fix in place, this test would have crashed, because an XTextRange
// can't point to a graphic node.
uno::Reference<text::XTextRange> xTextRange
= xController->createTextRangeByPixelPosition(aPoint);
// Then make sure that the anchor of the image is returned:
const auto& rFormats = *pDoc->GetSpzFrameFormats();
const auto pFormat = rFormats[0];
SwPosition aAnchorPos(*pFormat->GetAnchor().GetContentAnchor());
auto pTextRange = dynamic_cast<SwXTextRange*>(xTextRange.get());
SwPaM aPaM(pDoc->GetNodes());
pTextRange->GetPositions(aPaM);
CPPUNIT_ASSERT_EQUAL(aAnchorPos, *aPaM.GetPoint());
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testCreateTextRangeByPixelPositionAtPageGraphic)
{
// Given a document with an at-page anchored image:
createSwDoc();
uno::Reference<lang::XMultiServiceFactory> xFactory(mxComponent, uno::UNO_QUERY);
uno::Reference<beans::XPropertySet> xTextGraphic(
xFactory->createInstance(u"com.sun.star.text.TextGraphicObject"_ustr), uno::UNO_QUERY);
xTextGraphic->setPropertyValue(u"AnchorType"_ustr,
uno::Any(text::TextContentAnchorType_AT_PAGE));
xTextGraphic->setPropertyValue(u"AnchorPageNo"_ustr, uno::Any(static_cast<sal_Int16>(1)));
xTextGraphic->setPropertyValue(u"Width"_ustr, uno::Any(static_cast<sal_Int32>(10000)));
xTextGraphic->setPropertyValue(u"Height"_ustr, uno::Any(static_cast<sal_Int32>(10000)));
uno::Reference<text::XTextDocument> xTextDocument(mxComponent, uno::UNO_QUERY);
uno::Reference<text::XText> xBodyText = xTextDocument->getText();
uno::Reference<text::XTextCursor> xCursor(xBodyText->createTextCursor());
uno::Reference<text::XTextContent> xTextContent(xTextGraphic, uno::UNO_QUERY);
xBodyText->insertTextContent(xCursor, xTextContent, false);
SwDocShell* pDocShell = getSwDocShell();
SwWrtShell* pWrtShell = pDocShell->GetWrtShell();
SwRootFrame* pLayout = pWrtShell->GetLayout();
SwFrame* pPage = pLayout->GetLower();
SwSortedObjs& rDrawObjs = *pPage->GetDrawObjs();
SwAnchoredObject* pAnchored = rDrawObjs[0];
Point aLogic = pAnchored->GetObjRect().Center();
SwView* pView = pDocShell->GetView();
SwEditWin& rEditWin = pView->GetEditWin();
Point aPixel = rEditWin.LogicToPixel(aLogic);
// When asking for the doc model pos of the image's anchor by pixel position:
uno::Reference<frame::XModel2> xModel(mxComponent, uno::UNO_QUERY);
uno::Reference<container::XEnumeration> xControllers = xModel->getControllers();
uno::Reference<text::XTextViewTextRangeSupplier> xController(xControllers->nextElement(),
uno::UNO_QUERY);
awt::Point aPoint(aPixel.getX(), aPixel.getY());
// Without the accompanying fix in place, this test would have crashed.
uno::Reference<text::XTextRange> xTextRange
= xController->createTextRangeByPixelPosition(aPoint);
// Then make sure that the result is empty, since the image is at-page anchored:
CPPUNIT_ASSERT(!xTextRange.is());
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testGetTextFormFields)
{
// Given a document with 3 fieldmarks: 2 zotero items and a zotero
// bibliography:
createSwDoc();
for (int i = 0; i < 2; ++i)
{
uno::Sequence<css::beans::PropertyValue> aArgs = {
comphelper::makePropertyValue(u"FieldType"_ustr, uno::Any(ODF_UNHANDLED)),
comphelper::makePropertyValue(u"FieldCommand"_ustr,
uno::Any(u"ADDIN ZOTERO_ITEM foo bar"_ustr)),
comphelper::makePropertyValue(u"FieldResult"_ustr, uno::Any(u"result"_ustr)),
};
dispatchCommand(mxComponent, u".uno:TextFormField"_ustr, aArgs);
}
{
uno::Sequence<css::beans::PropertyValue> aArgs = {
comphelper::makePropertyValue(u"FieldType"_ustr, uno::Any(ODF_UNHANDLED)),
comphelper::makePropertyValue(u"FieldCommand"_ustr,
uno::Any(u"ADDIN ZOTERO_BIBL foo bar"_ustr)),
comphelper::makePropertyValue(u"FieldResult"_ustr,
uno::Any(u"<p>aaa</p><p>bbb</p>"_ustr)),
};
dispatchCommand(mxComponent, u".uno:TextFormField"_ustr, aArgs);
}
// When getting the zotero items:
tools::JsonWriter aJsonWriter;
std::string_view aCommand(".uno:TextFormFields?type=vnd.oasis.opendocument.field.UNHANDLED&"
"commandPrefix=ADDIN%20ZOTERO_ITEM");
getSwTextDoc()->getCommandValues(aJsonWriter, aCommand);
// Then make sure we find the 2 items and ignore the bibliography:
OString pJSON(aJsonWriter.finishAndGetAsOString());
std::stringstream aStream((std::string(pJSON)));
boost::property_tree::ptree aTree;
boost::property_tree::read_json(aStream, aTree);
// Without the accompanying fix in place, this test would have failed with:
// - No such node (fields)
// i.e. the returned JSON was just empty.
CPPUNIT_ASSERT_EQUAL(static_cast<size_t>(2), aTree.get_child("fields").count(""));
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testGetDocumentProperties)
{
// Given a document with 3 custom properties: 2 Zotero ones and one other:
createSwDoc();
SwDocShell* pDocShell = getSwDocShell();
uno::Reference<document::XDocumentPropertiesSupplier> xDPS(pDocShell->GetModel(),
uno::UNO_QUERY);
uno::Reference<document::XDocumentProperties> xDP = xDPS->getDocumentProperties();
uno::Reference<beans::XPropertyContainer> xUDP = xDP->getUserDefinedProperties();
xUDP->addProperty(u"ZOTERO_PREF_1"_ustr, beans::PropertyAttribute::REMOVABLE,
uno::Any(u"foo"_ustr));
xUDP->addProperty(u"ZOTERO_PREF_2"_ustr, beans::PropertyAttribute::REMOVABLE,
uno::Any(u"bar"_ustr));
xUDP->addProperty(u"OTHER"_ustr, beans::PropertyAttribute::REMOVABLE, uno::Any(u"baz"_ustr));
// When getting the zotero properties:
tools::JsonWriter aJsonWriter;
std::string_view aCommand(".uno:SetDocumentProperties?namePrefix=ZOTERO_PREF_");
getSwTextDoc()->getCommandValues(aJsonWriter, aCommand);
// Then make sure we find the 2 properties and ignore the other one:
OString pJSON(aJsonWriter.finishAndGetAsOString());
std::stringstream aStream((std::string(pJSON)));
boost::property_tree::ptree aTree;
boost::property_tree::read_json(aStream, aTree);
// Without the accompanying fix in place, this test would have failed with:
// - No such node (userDefinedProperties)
// i.e. the returned JSON was just empty.
CPPUNIT_ASSERT_EQUAL(static_cast<size_t>(2),
aTree.get_child("userDefinedProperties").count(""));
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testGetBookmarks)
{
// Given a document with 3 bookmarks: 2 zotero references and a zotero bibliography:
createSwDoc();
{
uno::Sequence<css::beans::PropertyValue> aArgs = {
comphelper::makePropertyValue(u"Bookmark"_ustr, uno::Any(u"ZOTERO_BREF_1"_ustr)),
};
dispatchCommand(mxComponent, u".uno:InsertBookmark"_ustr, aArgs);
}
{
uno::Sequence<css::beans::PropertyValue> aArgs = {
comphelper::makePropertyValue(u"Bookmark"_ustr, uno::Any(u"ZOTERO_BREF_2"_ustr)),
};
dispatchCommand(mxComponent, u".uno:InsertBookmark"_ustr, aArgs);
}
{
uno::Sequence<css::beans::PropertyValue> aArgs = {
comphelper::makePropertyValue(u"Bookmark"_ustr, uno::Any(u"ZOTERO_BIBL"_ustr)),
};
dispatchCommand(mxComponent, u".uno:InsertBookmark"_ustr, aArgs);
}
// When getting the reference bookmarks:
tools::JsonWriter aJsonWriter;
std::string_view aCommand(".uno:Bookmarks?namePrefix=ZOTERO_BREF_");
getSwTextDoc()->getCommandValues(aJsonWriter, aCommand);
// Then make sure we get the 2 references but not the bibliography:
OString pJSON(aJsonWriter.finishAndGetAsOString());
std::stringstream aStream((std::string(pJSON)));
boost::property_tree::ptree aTree;
boost::property_tree::read_json(aStream, aTree);
// Without the accompanying fix in place, this test would have failed with:
// - No such node (bookmarks)
// i.e. the returned JSON was just empty.
CPPUNIT_ASSERT_EQUAL(static_cast<size_t>(2), aTree.get_child("bookmarks").count(""));
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testGetFields)
{
// Given a document with a refmark:
createSwDoc();
SwWrtShell* pWrtShell = getSwDocShell()->GetWrtShell();
OUString aName(u"ZOTERO_ITEM CSL_CITATION {} "_ustr);
for (int i = 0; i < 5; ++i)
{
uno::Sequence<css::beans::PropertyValue> aArgs = {
comphelper::makePropertyValue(u"TypeName"_ustr, uno::Any(u"SetRef"_ustr)),
comphelper::makePropertyValue(u"Name"_ustr, uno::Any(aName + OUString::number(i + 1))),
comphelper::makePropertyValue(u"Content"_ustr, uno::Any(u"mycontent"_ustr)),
};
dispatchCommand(mxComponent, u".uno:InsertField"_ustr, aArgs);
pWrtShell->SttEndDoc(/*bStt=*/false);
pWrtShell->SplitNode();
pWrtShell->SttEndDoc(/*bStt=*/false);
}
// When getting the refmarks:
tools::JsonWriter aJsonWriter;
std::string_view aCommand(".uno:Fields?typeName=SetRef&namePrefix=ZOTERO_ITEM%20CSL_CITATION");
getSwTextDoc()->getCommandValues(aJsonWriter, aCommand);
// Then make sure we get the 1 refmark:
OString pJSON(aJsonWriter.finishAndGetAsOString());
std::stringstream aStream((std::string(pJSON)));
boost::property_tree::ptree aTree;
boost::property_tree::read_json(aStream, aTree);
// Without the accompanying fix in place, this test would have failed with:
// - No such node (setRefs)
// i.e. the returned JSON was just empty.
CPPUNIT_ASSERT_EQUAL(static_cast<size_t>(5), aTree.get_child("setRefs").count(""));
auto it = aTree.get_child("setRefs").begin();
boost::property_tree::ptree aRef = (it++)->second;
CPPUNIT_ASSERT_EQUAL(std::string("ZOTERO_ITEM CSL_CITATION {} 1"),
aRef.get<std::string>("name"));
aRef = (it++)->second;
CPPUNIT_ASSERT_EQUAL(std::string("ZOTERO_ITEM CSL_CITATION {} 2"),
aRef.get<std::string>("name"));
aRef = (it++)->second;
// Without the accompanying fix in place, this test would have failed with:
// - Expected: ZOTERO_ITEM CSL_CITATION {} 3
// - Actual : ZOTERO_ITEM CSL_CITATION {} 4
// i.e. the output was unsorted.
CPPUNIT_ASSERT_EQUAL(std::string("ZOTERO_ITEM CSL_CITATION {} 3"),
aRef.get<std::string>("name"));
aRef = (it++)->second;
CPPUNIT_ASSERT_EQUAL(std::string("ZOTERO_ITEM CSL_CITATION {} 4"),
aRef.get<std::string>("name"));
aRef = (it++)->second;
CPPUNIT_ASSERT_EQUAL(std::string("ZOTERO_ITEM CSL_CITATION {} 5"),
aRef.get<std::string>("name"));
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testGetTextFormField)
{
// Given a document with a fieldmark:
createSwDoc();
uno::Sequence<css::beans::PropertyValue> aArgs = {
comphelper::makePropertyValue(u"FieldType"_ustr, uno::Any(ODF_UNHANDLED)),
comphelper::makePropertyValue(u"FieldCommand"_ustr,
uno::Any(u"ADDIN ZOTERO_ITEM foo bar"_ustr)),
comphelper::makePropertyValue(u"FieldResult"_ustr, uno::Any(u"result"_ustr)),
};
dispatchCommand(mxComponent, u".uno:TextFormField"_ustr, aArgs);
// When stepping into the fieldmark with the cursor and getting the command value for
// uno:TextFormField:
SwWrtShell* pWrtShell = getSwDocShell()->GetWrtShell();
pWrtShell->SttEndDoc(/*bStt=*/false);
pWrtShell->Left(SwCursorSkipMode::Chars, /*bSelect=*/false, 1, /*bBasicCall=*/false);
tools::JsonWriter aJsonWriter;
std::string_view aCommand(".uno:TextFormField?type=vnd.oasis.opendocument.field.UNHANDLED&"
"commandPrefix=ADDIN%20ZOTERO_ITEM");
getSwTextDoc()->getCommandValues(aJsonWriter, aCommand);
// Then make sure we find the inserted fieldmark:
OString pJSON(aJsonWriter.finishAndGetAsOString());
std::stringstream aStream((std::string(pJSON)));
boost::property_tree::ptree aTree;
boost::property_tree::read_json(aStream, aTree);
// Without the accompanying fix in place, this test would have failed with:
// - No such node (type)
// i.e. the returned JSON was just an empty object.
auto field = aTree.get_child("field");
CPPUNIT_ASSERT_EQUAL(std::string("vnd.oasis.opendocument.field.UNHANDLED"),
field.get<std::string>("type"));
CPPUNIT_ASSERT_EQUAL(std::string("ADDIN ZOTERO_ITEM foo bar"),
field.get<std::string>("command"));
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testGetSections)
{
// Given a document with a section:
createSwDoc();
uno::Sequence<css::beans::PropertyValue> aArgs = {
comphelper::makePropertyValue(
u"RegionName"_ustr, uno::Any(u"ZOTERO_BIBL {} CSL_BIBLIOGRAPHY RNDRfiit6mXBc"_ustr)),
comphelper::makePropertyValue(u"Content"_ustr, uno::Any(u"<p>aaa</p><p>bbb</p>"_ustr)),
};
dispatchCommand(mxComponent, u".uno:InsertSection"_ustr, aArgs);
// When asking for a list of section names:
tools::JsonWriter aJsonWriter;
std::string_view aCommand(".uno:Sections?namePrefix=ZOTERO_BIBL");
getSwTextDoc()->getCommandValues(aJsonWriter, aCommand);
// Make sure we find our just inserted section:
OString pJSON(aJsonWriter.finishAndGetAsOString());
std::stringstream aStream((std::string(pJSON)));
boost::property_tree::ptree aTree;
boost::property_tree::read_json(aStream, aTree);
// Without the accompanying fix in place, this test would have failed with:
// - No such node (sections)
// i.e. the returned JSON was an empty object.
CPPUNIT_ASSERT_EQUAL(static_cast<size_t>(1), aTree.get_child("sections").count(""));
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testGetBookmark)
{
// Given a document with a bookmark:
createSwDoc();
uno::Sequence<css::beans::PropertyValue> aArgs = {
comphelper::makePropertyValue(u"Bookmark"_ustr, uno::Any(u"ZOTERO_BREF_1"_ustr)),
comphelper::makePropertyValue(u"BookmarkText"_ustr, uno::Any(u"<p>aaa</p><p>bbb</p>"_ustr)),
};
dispatchCommand(mxComponent, u".uno:InsertBookmark"_ustr, aArgs);
// When stepping into the bookmark with the cursor and getting the command value for
// .uno:Bookmark:
SwWrtShell* pWrtShell = getSwDocShell()->GetWrtShell();
pWrtShell->SttEndDoc(/*bStt=*/false);
pWrtShell->Left(SwCursorSkipMode::Chars, /*bSelect=*/false, 1, /*bBasicCall=*/false);
tools::JsonWriter aJsonWriter;
std::string_view aCommand(".uno:Bookmark?namePrefix=ZOTERO_BREF_");
getSwTextDoc()->getCommandValues(aJsonWriter, aCommand);
// Then make sure we find the inserted bookmark:
OString pJSON(aJsonWriter.finishAndGetAsOString());
std::stringstream aStream((std::string(pJSON)));
boost::property_tree::ptree aTree;
boost::property_tree::read_json(aStream, aTree);
boost::property_tree::ptree aBookmark = aTree.get_child("bookmark");
// Without the accompanying fix in place, this test would have failed with:
// - No such node (bookmark)
// i.e. the returned JSON was an empty object.
CPPUNIT_ASSERT_EQUAL(std::string("ZOTERO_BREF_1"), aBookmark.get<std::string>("name"));
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testGetField)
{
// Given a document with a refmark:
createSwDoc();
uno::Sequence<css::beans::PropertyValue> aArgs = {
comphelper::makePropertyValue(u"TypeName"_ustr, uno::Any(u"SetRef"_ustr)),
comphelper::makePropertyValue(u"Name"_ustr,
uno::Any(u"ZOTERO_ITEM CSL_CITATION {} refmark"_ustr)),
comphelper::makePropertyValue(u"Content"_ustr, uno::Any(u"content"_ustr)),
};
dispatchCommand(mxComponent, u".uno:InsertField"_ustr, aArgs);
// When in the refmark with the cursor and getting the command value for .uno:Field:
SwWrtShell* pWrtShell = getSwDocShell()->GetWrtShell();
pWrtShell->SttEndDoc(/*bStt=*/false);
pWrtShell->Left(SwCursorSkipMode::Chars, /*bSelect=*/false, 1, /*bBasicCall=*/false);
tools::JsonWriter aJsonWriter;
std::string_view aCommand(".uno:Field?typeName=SetRef&namePrefix=ZOTERO_ITEM%20CSL_CITATION");
getSwTextDoc()->getCommandValues(aJsonWriter, aCommand);
// Then make sure we find the inserted refmark:
OString pJSON(aJsonWriter.finishAndGetAsOString());
std::stringstream aStream((std::string(pJSON)));
boost::property_tree::ptree aTree;
boost::property_tree::read_json(aStream, aTree);
boost::property_tree::ptree aBookmark = aTree.get_child("setRef");
// Without the accompanying fix in place, this test would have failed with:
// - No such node (setRef)
// i.e. the returned JSON was an empty object.
CPPUNIT_ASSERT_EQUAL(std::string("ZOTERO_ITEM CSL_CITATION {} refmark"),
aBookmark.get<std::string>("name"));
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testDoNotBreakWrappedTables)
{
// Given an empty document:
createSwDoc();
// When checking the state of the DoNotBreakWrappedTables compat flag:
uno::Reference<lang::XMultiServiceFactory> xDocument(mxComponent, uno::UNO_QUERY);
uno::Reference<beans::XPropertySet> xSettings(
xDocument->createInstance(u"com.sun.star.document.Settings"_ustr), uno::UNO_QUERY);
bool bDoNotBreakWrappedTables{};
// Without the accompanying fix in place, this test would have failed with:
// An uncaught exception of type com.sun.star.beans.UnknownPropertyException
// i.e. the compat flag was not recognized.
xSettings->getPropertyValue(u"DoNotBreakWrappedTables"_ustr) >>= bDoNotBreakWrappedTables;
// Then make sure it's false by default:
CPPUNIT_ASSERT(!bDoNotBreakWrappedTables);
// And when setting DoNotBreakWrappedTables=true:
xSettings->setPropertyValue(u"DoNotBreakWrappedTables"_ustr, uno::Any(true));
// Then make sure it gets enabled:
xSettings->getPropertyValue(u"DoNotBreakWrappedTables"_ustr) >>= bDoNotBreakWrappedTables;
CPPUNIT_ASSERT(bDoNotBreakWrappedTables);
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testAllowTextAfterFloatingTableBreak)
{
// Given an empty document:
createSwDoc();
// When checking the state of the AllowTextAfterFloatingTableBreak compat flag:
uno::Reference<lang::XMultiServiceFactory> xDocument(mxComponent, uno::UNO_QUERY);
uno::Reference<beans::XPropertySet> xSettings(
xDocument->createInstance(u"com.sun.star.document.Settings"_ustr), uno::UNO_QUERY);
bool bAllowTextAfterFloatingTableBreak{};
// Without the accompanying fix in place, this test would have failed with:
// An uncaught exception of type com.sun.star.beans.UnknownPropertyException
// i.e. the compat flag was not recognized.
xSettings->getPropertyValue(u"AllowTextAfterFloatingTableBreak"_ustr)
>>= bAllowTextAfterFloatingTableBreak;
// Then make sure it's false by default:
CPPUNIT_ASSERT(!bAllowTextAfterFloatingTableBreak);
// And when setting AllowTextAfterFloatingTableBreak=true:
xSettings->setPropertyValue(u"AllowTextAfterFloatingTableBreak"_ustr, uno::Any(true));
// Then make sure it gets enabled:
xSettings->getPropertyValue(u"AllowTextAfterFloatingTableBreak"_ustr)
>>= bAllowTextAfterFloatingTableBreak;
CPPUNIT_ASSERT(bAllowTextAfterFloatingTableBreak);
}
CPPUNIT_TEST_FIXTURE(SwUibaseUnoTest, testDoNotMirrorRtlDrawObjs)
{
// Given an empty document:
createSwDoc();
// When checking the state of the DoNotMirrorRtlDrawObjs compat flag:
uno::Reference<lang::XMultiServiceFactory> xDocument(mxComponent, uno::UNO_QUERY);
uno::Reference<beans::XPropertySet> xSettings(
xDocument->createInstance(u"com.sun.star.document.Settings"_ustr), uno::UNO_QUERY);
bool bDoNotMirrorRtlDrawObjs{};
// Without the accompanying fix in place, this test would have failed with:
// An uncaught exception of type com.sun.star.beans.UnknownPropertyException
// i.e. the compat flag was not recognized.
xSettings->getPropertyValue(u"DoNotMirrorRtlDrawObjs"_ustr) >>= bDoNotMirrorRtlDrawObjs;
// Then make sure it's false by default:
CPPUNIT_ASSERT(!bDoNotMirrorRtlDrawObjs);
// And when setting DoNotMirrorRtlDrawObjs=true:
xSettings->setPropertyValue(u"DoNotMirrorRtlDrawObjs"_ustr, uno::Any(true));
// Then make sure it gets enabled:
xSettings->getPropertyValue(u"DoNotMirrorRtlDrawObjs"_ustr) >>= bDoNotMirrorRtlDrawObjs;
CPPUNIT_ASSERT(bDoNotMirrorRtlDrawObjs);
}
CPPUNIT_PLUGIN_IMPLEMENT();
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */