1
0
Fork 0
libreoffice/sw/qa/core/layout/layact.cxx
Daniel Baumann 8e63e14cf6
Adding upstream version 4:25.2.3.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
2025-06-22 16:20:04 +02:00

135 lines
4.6 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 <vcl/scheduler.hxx>
#include <IDocumentLayoutAccess.hxx>
#include <anchoredobject.hxx>
#include <docsh.hxx>
#include <flyfrm.hxx>
#include <pagefrm.hxx>
#include <rootfrm.hxx>
#include <rowfrm.hxx>
#include <sortedobjs.hxx>
#include <tabfrm.hxx>
#include <wrtsh.hxx>
#include <sectfrm.hxx>
namespace
{
/// Covers sw/source/core/layout/layact.cxx fixes.
class Test : public SwModelTestBase
{
public:
Test()
: SwModelTestBase(u"/sw/qa/core/layout/data/"_ustr)
{
}
};
CPPUNIT_TEST_FIXTURE(Test, testSplitFlyNextRowInvalidatePos)
{
// Given a multi-page floating table, row1 is split, i.e. is both on page 1 and page 2:
createSwDoc("floattable-next-row-invalidate-pos.docx");
// Make sure the follow anchor's IsCompletePaint() reaches its false state, as it happens in the
// interactive case.
Scheduler::ProcessEventsToIdle();
SwDoc* pDoc = getSwDoc();
SwRootFrame* pLayout = pDoc->getIDocumentLayoutAccess().GetCurrentLayout();
auto pPage1 = pLayout->Lower()->DynCastPageFrame();
CPPUNIT_ASSERT(pPage1);
auto pPage2 = pPage1->GetNext()->DynCastPageFrame();
CPPUNIT_ASSERT(pPage2);
CPPUNIT_ASSERT(pPage2->GetSortedObjs());
SwSortedObjs& rPage2Objs = *pPage2->GetSortedObjs();
auto pFly2 = rPage2Objs[0]->DynCastFlyFrame();
auto pTable2 = pFly2->GetLower()->DynCastTabFrame();
auto pRow2 = pTable2->GetLastLower()->DynCastRowFrame();
SwTwips nOldRow2Top = pRow2->getFrameArea().Top();
// When adding a new paragraph at the end of B1:
// Go to the table: A1 cell.
SwWrtShell* pWrtShell = getSwDocShell()->GetWrtShell();
pWrtShell->GotoTable(u"Table1"_ustr);
// Go to the column: B1 cell.
pWrtShell->GoNextCell();
// Go to the end of the B1 cell, on page 2.
pWrtShell->EndOfSection();
// Add a new paragraph at the cell end.
pWrtShell->SplitNode();
// Then make sure row 2 is shifted down:
SwTwips nNewRow2Top = pRow2->getFrameArea().Top();
// Without the accompanying fix in place, this test would have failed with:
// - Expected greater than: 7121
// - Actual : 7121
// i.e. row 2 has to be shifted down to 7390, but this didn't happen.
CPPUNIT_ASSERT_GREATER(nOldRow2Top, nNewRow2Top);
}
CPPUNIT_TEST_FIXTURE(Test, testTdf157096)
{
createSwDoc("tdf157096.docx");
CPPUNIT_ASSERT_EQUAL(2, getPages());
dispatchCommand(mxComponent, u".uno:SelectAll"_ustr, {});
// Without the fix in place, it would have crashed here
dispatchCommand(mxComponent, u".uno:Delete"_ustr, {});
CPPUNIT_ASSERT_EQUAL(1, getPages());
}
CPPUNIT_TEST_FIXTURE(Test, testSplitFlyInSection)
{
// Given a document with multiple sections, the 2nd section on page 1 has a one-page floating
// table:
createSwDoc("floattable-in-section.docx");
// When laying out that document:
SwDoc* pDoc = getSwDoc();
SwRootFrame* pLayout = pDoc->getIDocumentLayoutAccess().GetCurrentLayout();
// Then make sure the table is on page 1, not on page 2:
auto pPage1 = pLayout->Lower()->DynCastPageFrame();
CPPUNIT_ASSERT(pPage1);
// Without the fix in place, it would have failed, the table was on page 2, not on page 1.
CPPUNIT_ASSERT(pPage1->GetSortedObjs());
SwSortedObjs& rPage1Objs = *pPage1->GetSortedObjs();
CPPUNIT_ASSERT_EQUAL(static_cast<size_t>(1), rPage1Objs.size());
auto pPage2 = pPage1->GetNext()->DynCastPageFrame();
CPPUNIT_ASSERT(pPage2);
CPPUNIT_ASSERT(!pPage2->GetSortedObjs());
}
CPPUNIT_TEST_FIXTURE(Test, testBadSplitSection)
{
// Given a document with a section, containing 5 paragraphs:
createSwDoc("bad-split-section.odt");
// When laying out that document:
SwDoc* pDoc = getSwDoc();
SwRootFrame* pLayout = pDoc->getIDocumentLayoutAccess().GetCurrentLayout();
// Then make sure the entire section is on page 1:
auto pPage = pLayout->Lower()->DynCastPageFrame();
CPPUNIT_ASSERT(pPage);
auto pBody = pPage->FindBodyCont();
CPPUNIT_ASSERT(pBody);
auto pSection = dynamic_cast<SwSectionFrame*>(pBody->GetLastLower());
CPPUNIT_ASSERT(pSection);
// Without the fix in place, it would have failed, the section was split between page 1 and page
// 2.
CPPUNIT_ASSERT(!pSection->GetFollow());
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */