summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Stahl <mstahl@redhat.com>2015-02-13 22:56:17 +0100
committerMichael Stahl <mstahl@redhat.com>2015-02-16 22:32:26 +0100
commit5a1fe97d70ca7c89ef74c05fd52783c9f54caf08 (patch)
treec2bb7aa419d7f05351b4f318b2143f16cb31e472
parent6c92e54a3abcaa1d8f5d83d74dfb0b77415be1d3 (diff)
sw: test case for search-and-replace bug fixed by commit ...
... b60ce8465c8f01242354abccebe00742d164af60 Change-Id: Iba1a059b3aeb5b2266398d80e6995f98fd580f14
-rw-r--r--sw/CppunitTest_sw_macros_test.mk1
-rw-r--r--sw/qa/core/macros-test.cxx64
2 files changed, 65 insertions, 0 deletions
diff --git a/sw/CppunitTest_sw_macros_test.mk b/sw/CppunitTest_sw_macros_test.mk
index c96084d1aa57..251597d0dd32 100644
--- a/sw/CppunitTest_sw_macros_test.mk
+++ b/sw/CppunitTest_sw_macros_test.mk
@@ -77,6 +77,7 @@ $(eval $(call gb_CppunitTest_use_components,sw_macros_test,\
forms/util/frm \
framework/util/fwk \
i18npool/util/i18npool \
+ i18npool/source/search/i18nsearch \
oox/util/oox \
package/source/xstor/xstor \
package/util/package2 \
diff --git a/sw/qa/core/macros-test.cxx b/sw/qa/core/macros-test.cxx
index 5267c34d3e55..d0c9e6dc0e67 100644
--- a/sw/qa/core/macros-test.cxx
+++ b/sw/qa/core/macros-test.cxx
@@ -18,6 +18,7 @@
#include <com/sun/star/lang/XComponent.hpp>
#include <com/sun/star/lang/XMultiServiceFactory.hpp>
#include <com/sun/star/beans/XPropertySet.hpp>
+#include <com/sun/star/util/SearchOptions.hpp>
#include <com/sun/star/frame/Desktop.hpp>
#include <com/sun/star/frame/XComponentLoader.hpp>
#include <com/sun/star/frame/XStorable.hpp>
@@ -47,11 +48,14 @@
#include <basic/sbxdef.hxx>
#include <unotools/tempfile.hxx>
+#include <unocrsr.hxx>
+#include <ndtxt.hxx>
#include <doc.hxx>
#include <IDocumentLayoutAccess.hxx>
#include <IDocumentUndoRedo.hxx>
#include <IDocumentContentOperations.hxx>
#include "docsh.hxx"
+#include <unotxdoc.hxx>
typedef tools::SvRef<SwDocShell> SwDocShellRef;
@@ -80,6 +84,7 @@ public:
#endif
void testFdo55289();
void testFdo68983();
+ void testFindReplace();
CPPUNIT_TEST_SUITE(SwMacrosTest);
#if !defined(MACOSX) && !defined(WNT)
//enable this test if you want to play with star basic macros in unit tests
@@ -93,6 +98,7 @@ public:
#endif
CPPUNIT_TEST(testFdo55289);
CPPUNIT_TEST(testFdo68983);
+ CPPUNIT_TEST(testFindReplace);
CPPUNIT_TEST_SUITE_END();
@@ -393,6 +399,64 @@ void SwMacrosTest::testFdo68983()
xDocCloseable->close(false);
}
+void SwMacrosTest::testFindReplace()
+{
+ // we need a full document with view and layout etc. because ::GetNode()
+ Reference<lang::XComponent> const xComponent =
+ loadFromDesktop("private:factory/swriter", "com.sun.star.text.TextDocument");
+ SwXTextDocument *const pTxtDoc = dynamic_cast<SwXTextDocument *>(xComponent.get());
+ SwDoc *const pDoc = pTxtDoc->GetDocShell()->GetDoc();
+ SwNodeIndex aIdx(pDoc->GetNodes().GetEndOfContent(), -1);
+ // use a UnoCrsr so it will be corrected when deleting nodes
+ SwUnoCrsr *const pPaM(pDoc->CreateUnoCrsr(SwPosition(aIdx), false));
+
+ IDocumentContentOperations & rIDCO(pDoc->getIDocumentContentOperations());
+ rIDCO.InsertString(*pPaM, OUString("foo"));
+ rIDCO.AppendTxtNode(*pPaM->GetPoint());
+ rIDCO.InsertString(*pPaM, OUString("bar"));
+ rIDCO.AppendTxtNode(*pPaM->GetPoint());
+ rIDCO.InsertString(*pPaM, OUString("baz"));
+ pPaM->Move(fnMoveBackward, fnGoDoc);
+
+ bool bCancel(false);
+ util::SearchOptions opts(
+ util::SearchAlgorithms_REGEXP,
+ 65536,
+ "$",
+ "",
+ lang::Locale("en", "US", ""),
+ 2,
+ 2,
+ 2,
+ 1073745152);
+
+ // find newline on 1st paragraph
+ bool bFound = pPaM->Find(
+ opts, false, DOCPOS_CURR, DOCPOS_END, bCancel, FND_IN_BODY, false);
+ CPPUNIT_ASSERT(bFound);
+ CPPUNIT_ASSERT(pPaM->HasMark());
+ CPPUNIT_ASSERT_EQUAL(OUString(""), pPaM->GetTxt());
+
+ // now do another Find, inside the selection from the first Find
+// opts.searchFlags = 71680;
+ bFound = pPaM->Find(
+ opts, false, DOCPOS_CURR, DOCPOS_END, bCancel, FND_IN_SEL, false);
+ CPPUNIT_ASSERT(bFound);
+ CPPUNIT_ASSERT(pPaM->HasMark());
+ CPPUNIT_ASSERT_EQUAL(OUString(""), pPaM->GetTxt());
+
+ rIDCO.ReplaceRange(*pPaM, " ", true);
+
+ pPaM->DeleteMark();
+ pPaM->Move(fnMoveBackward, fnGoDoc);
+
+ // problem was that after the 2nd Find, the wrong newline was selected
+ CPPUNIT_ASSERT_EQUAL(OUString("foo bar"),
+ pPaM->Start()->nNode.GetNode().GetTxtNode()->GetTxt());
+ pPaM->Move(fnMoveForward, fnGoNode);
+ CPPUNIT_ASSERT_EQUAL(OUString("baz"),
+ pPaM->End()->nNode.GetNode().GetTxtNode()->GetTxt());
+}
SwMacrosTest::SwMacrosTest()
: m_aBaseString("/sw/qa/core/data")