diff options
Diffstat (limited to 'sc')
-rw-r--r-- | sc/qa/unit/scshapetest.cxx | 422 |
1 files changed, 114 insertions, 308 deletions
diff --git a/sc/qa/unit/scshapetest.cxx b/sc/qa/unit/scshapetest.cxx index bc5df4d4854c..1c54c0e5ac5c 100644 --- a/sc/qa/unit/scshapetest.cxx +++ b/sc/qa/unit/scshapetest.cxx @@ -148,29 +148,61 @@ static void lcl_AssertPointEqualWithTolerance(std::string_view sInfo, const Poin CPPUNIT_ASSERT_MESSAGE(sMsg.getStr(), std::abs(rExpected.Y() - rActual.Y()) <= nTolerance); } -void ScShapeTest::testTdf139583_Rotate180deg() +static ScDocShell* +lcl_getScDocShellWithAssert(css::uno::Reference<css::lang::XComponent>& xComponent) { - // Load an empty document. - OUString aFileURL; - createFileURL(u"ManualColWidthRowHeight.ods", aFileURL); - uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); - CPPUNIT_ASSERT(xComponent.is()); - - // Get ScDocShell SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); CPPUNIT_ASSERT(pDocSh); + return pDocSh; +} - // Get SdrPage - ScDocument& rDoc = pDocSh->GetDocument(); +static ScTabViewShell* lcl_getScTabViewShellWithAssert(ScDocShell* pDocSh) +{ + ScTabViewShell* pTabViewShell = pDocSh->GetBestViewShell(false); + CPPUNIT_ASSERT_MESSAGE("No ScTabViewShell", pTabViewShell); + return pTabViewShell; +} + +static SdrPage* lcl_getSdrPageWithAssert(ScDocument& rDoc) +{ ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); SdrPage* pPage = pDrawLayer->GetPage(0); CPPUNIT_ASSERT_MESSAGE("No draw page", pPage); + return pPage; +} + +static SdrObject* lcl_getSdrObjectWithAssert(ScDocument& rDoc, sal_uInt16 nObjNumber) +{ + ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); + CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); + const SdrPage* pPage = pDrawLayer->GetPage(0); + CPPUNIT_ASSERT_MESSAGE("No draw page", pPage); + SdrObject* pObj = pPage->GetObj(nObjNumber); + OString sMsg = "no Object " + OString::number(nObjNumber); + CPPUNIT_ASSERT_MESSAGE(sMsg.getStr(), pObj); + return pObj; +} + +void ScShapeTest::testTdf139583_Rotate180deg() +{ + // Load an empty document. + OUString aFileURL; + createFileURL(u"ManualColWidthRowHeight.ods", aFileURL); + uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); + CPPUNIT_ASSERT(xComponent.is()); + + // Get document and draw page + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); + ScDocument& rDoc = pDocSh->GetDocument(); + SdrPage* pPage = lcl_getSdrPageWithAssert(rDoc); // Insert Shape const tools::Rectangle aRect(Point(3000, 4000), Size(5000, 2000)); + ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); + CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); SdrRectObj* pObj = new SdrRectObj(*pDrawLayer, aRect); CPPUNIT_ASSERT_MESSAGE("Could not create rectangle", pObj); pPage->InsertObject(pObj); @@ -184,20 +216,10 @@ void ScShapeTest::testTdf139583_Rotate180deg() saveAndReload(xComponent, "calc8"); CPPUNIT_ASSERT(xComponent); - // Get ScDocShell - pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Reload: Failed to access document shell", pFoundShell); - pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - // Get document and object + pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc2 = pDocSh->GetDocument(); - pDrawLayer = rDoc2.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("Reload: No ScDrawLayer", pDrawLayer); - pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("Reload: No draw page", pPage); - pObj = dynamic_cast<SdrRectObj*>(pPage->GetObj(0)); - CPPUNIT_ASSERT_MESSAGE("Reload: Shape no longer exists", pObj); + pObj = static_cast<SdrRectObj*>(lcl_getSdrObjectWithAssert(rDoc2, 0)); // Without the fix in place, the shape would have nearly zero size. lcl_AssertRectEqualWithTolerance("Show: Object geometry should not change", aRect, @@ -213,20 +235,10 @@ void ScShapeTest::testTdf137033_FlipHori_Resize() uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); CPPUNIT_ASSERT(xComponent.is()); - // Get document - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - ScDocShell* pDocSh = static_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); + // Get document and shape + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); - - // Get shape - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("No draw page", pPage); - SdrObjCustomShape* pObj = static_cast<SdrObjCustomShape*>(pPage->GetObj(0)); - CPPUNIT_ASSERT_MESSAGE("Load: custom shape not found", pObj); + SdrObjCustomShape* pObj = static_cast<SdrObjCustomShape*>(lcl_getSdrObjectWithAssert(rDoc, 0)); // Verify shape is correctly loaded. Then set shape to "resize with cell". tools::Rectangle aSnapRect(pObj->GetSnapRect()); @@ -238,20 +250,10 @@ void ScShapeTest::testTdf137033_FlipHori_Resize() saveAndReload(xComponent, "calc8"); CPPUNIT_ASSERT(xComponent); - // Get document - pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - pDocSh = static_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); + // Get document and shape + pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc2 = pDocSh->GetDocument(); - - // Get shape - pDrawLayer = rDoc2.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); - pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("No draw page", pPage); - pObj = static_cast<SdrObjCustomShape*>(pPage->GetObj(0)); - CPPUNIT_ASSERT_MESSAGE("Reload: custom shape not found", pObj); + pObj = static_cast<SdrObjCustomShape*>(lcl_getSdrObjectWithAssert(rDoc2, 0)); // Check shape has the original geometry, besides rounding and unit conversion errors aSnapRect = pObj->GetSnapRect(); @@ -273,10 +275,7 @@ void ScShapeTest::testTdf137033_RotShear_ResizeHide() CPPUNIT_ASSERT(xComponent.is()); // Get document - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); // Hide rows 4 and 5 (UI number), which are inside the shape and thus change shape geometry @@ -284,12 +283,7 @@ void ScShapeTest::testTdf137033_RotShear_ResizeHide() rDoc.SetDrawPageSize(0); // trigger recalcpos, otherwise shapes are not changed // Get shape - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("No draw page", pPage); - SdrObject* pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("No object found", pObj); + SdrObject* pObj = lcl_getSdrObjectWithAssert(rDoc, 0); // Verify hiding has changed shape geometry as expected tools::Rectangle aSnapRect(pObj->GetSnapRect()); @@ -310,20 +304,10 @@ void ScShapeTest::testTdf137033_RotShear_ResizeHide() saveAndReload(xComponent, "calc8"); CPPUNIT_ASSERT(xComponent); - // Get document - pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); + // Get document and shape + pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc2 = pDocSh->GetDocument(); - - // Get shape - pDrawLayer = rDoc2.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); - pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("No draw page", pPage); - pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("No object found", pObj); + pObj = lcl_getSdrObjectWithAssert(rDoc2, 0); // Check shape has the original geometry, besides heavy rounding and unit conversion errors aSnapRect = pObj->GetSnapRect(); @@ -351,10 +335,7 @@ void ScShapeTest::testTdf137033_RotShear_Hide() CPPUNIT_ASSERT(xComponent.is()); // Get document - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); // Hide column C, which is left from logic rect, but right from left edge of snap rect @@ -365,20 +346,10 @@ void ScShapeTest::testTdf137033_RotShear_Hide() saveAndReload(xComponent, "calc8"); CPPUNIT_ASSERT(xComponent); - // Get document - pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); + // Get document and shape + pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc2 = pDocSh->GetDocument(); - - // Get shape - ScDrawLayer* pDrawLayer = rDoc2.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("No draw page", pPage); - SdrObject* pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("No object found", pObj); + SdrObject* pObj = lcl_getSdrObjectWithAssert(rDoc2, 0); // Check shape is visible. With the old version, the shape was moved to column C and // thus hidden on reload. @@ -409,26 +380,17 @@ void ScShapeTest::testTdf137576_LogicRectInDefaultMeasureline() CPPUNIT_ASSERT(xComponent.is()); // Get ScDocShell - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT_MESSAGE("No ScDocShell", pDocSh); + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); // Create default measureline by SfxRequest that corresponds to Ctrl+Click - ScTabViewShell* pTabViewShell = pDocSh->GetBestViewShell(false); - CPPUNIT_ASSERT_MESSAGE("No ScTabViewShell", pTabViewShell); + ScTabViewShell* pTabViewShell = lcl_getScTabViewShellWithAssert(pDocSh); SfxRequest aReq(pTabViewShell->GetViewFrame(), SID_DRAW_MEASURELINE); aReq.SetModifier(KEY_MOD1); // Ctrl pTabViewShell->ExecDraw(aReq); // Get document and newly created measure line. ScDocument& rDoc = pDocSh->GetDocument(); - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("No draw page", pPage); - SdrObject* pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("No object found", pObj); + SdrObject* pObj = lcl_getSdrObjectWithAssert(rDoc, 0); // Anchor "to Cell (resize with cell)" ScDrawLayer::SetCellAnchoredFromPosition(*pObj, rDoc, 0 /*SCTAB*/, true /*bResizeWithCell*/); @@ -449,19 +411,11 @@ void ScShapeTest::testTdf137576_LogicRectInDefaultMeasureline() // Save and reload, get ScDocShell saveAndReload(xComponent, "calc8"); CPPUNIT_ASSERT(xComponent); - pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Reload: Failed to access document shell", pFoundShell); - pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); + pDocSh = lcl_getScDocShellWithAssert(xComponent); // Get document and object ScDocument& rDoc2 = pDocSh->GetDocument(); - pDrawLayer = rDoc2.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("Reload: No ScDrawLayer", pDrawLayer); - pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("Reload: No draw page", pPage); - pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("Measure line lost", pObj); + pObj = lcl_getSdrObjectWithAssert(rDoc2, 0); // Assert object position is unchanged, besides Twips<->Hmm inaccuracy. Point aNewPos = pObj->GetRelativePos(); @@ -482,22 +436,16 @@ void ScShapeTest::testTdf137576_LogicRectInNewMeasureline() uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); CPPUNIT_ASSERT(xComponent.is()); - // Get ScDocShell - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - - // Get SdrPage + // Get document and draw page + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); - SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("No draw page", pPage); + SdrPage* pPage = lcl_getSdrPageWithAssert(rDoc); // Create a new measure line and insert it Point aStartPoint(5000, 5500); Point aEndPoint(13000, 8000); + ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); + CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); SdrMeasureObj* pObj = new SdrMeasureObj(*pDrawLayer, aStartPoint, aEndPoint); CPPUNIT_ASSERT_MESSAGE("Could not create measure line", pObj); pPage->InsertObject(pObj); @@ -523,20 +471,10 @@ void ScShapeTest::testMeasurelineHideColSave() uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); CPPUNIT_ASSERT(xComponent.is()); - // Get the document model - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - // Get document and shape + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("No draw page", pPage); - SdrObject* pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("No object found", pObj); + SdrObject* pObj = lcl_getSdrObjectWithAssert(rDoc, 0); // Make sure loading is correct Point aStartPoint(7500, 15000); // according UI @@ -557,20 +495,10 @@ void ScShapeTest::testMeasurelineHideColSave() saveAndReload(xComponent, "calc8"); CPPUNIT_ASSERT(xComponent); - // Get ScDocShell - pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Reload: Failed to access document shell", pFoundShell); - pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - - // Get document and object + // Get document and shape + pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc2 = pDocSh->GetDocument(); - pDrawLayer = rDoc2.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("Reload: No ScDrawLayer", pDrawLayer); - pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("Reload: No draw page", pPage); - pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("Reload: custom shape no longer exists", pObj); + pObj = lcl_getSdrObjectWithAssert(rDoc2, 0); // Check that start and end point are unchanged besides rounding and unit conversion errors lcl_AssertPointEqualWithTolerance("Reload start: ", aStartPoint, pObj->GetPoint(0), 2); @@ -590,20 +518,11 @@ void ScShapeTest::testHideColsShow() uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); CPPUNIT_ASSERT(xComponent.is()); - // Get the document model - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - // Get document and shape + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("No draw page", pPage); - SdrObject* pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("No object found", pObj); + SdrObjCustomShape* pObj = static_cast<SdrObjCustomShape*>(lcl_getSdrObjectWithAssert(rDoc, 0)); + CPPUNIT_ASSERT_MESSAGE("Load: Object should be visible", pObj->IsVisible()); tools::Rectangle aSnapRectOrig(pObj->GetSnapRect()); @@ -613,8 +532,7 @@ void ScShapeTest::testHideColsShow() }; dispatchCommand(xComponent, ".uno:GoToCell", aPropertyValues); - ScTabViewShell* pViewShell = pDocSh->GetBestViewShell(false); - CPPUNIT_ASSERT_MESSAGE("No ScTabViewShell", pViewShell); + ScTabViewShell* pViewShell = lcl_getScTabViewShellWithAssert(pDocSh); pViewShell->GetViewData().GetDispatcher().Execute(FID_COL_HIDE); // Check object is invisible @@ -645,20 +563,10 @@ void ScShapeTest::testTdf138138_MoveCellWithRotatedShape() uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); CPPUNIT_ASSERT(xComponent.is()); - // Get ScDocShell - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - - // Get document and object + // Get document and shape + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("Load: No ScDrawLayer", pDrawLayer); - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("Load: No draw page", pPage); - SdrObject* pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("Load: custom shape not found", pObj); + SdrObject* pObj = lcl_getSdrObjectWithAssert(rDoc, 0); // Check anchor and position of shape. The expected values are taken from UI. tools::Rectangle aSnapRect = pObj->GetSnapRect(); @@ -670,8 +578,8 @@ void ScShapeTest::testTdf138138_MoveCellWithRotatedShape() comphelper::makePropertyValue("ToPoint", OUString("$A$1:$B$1")), }; dispatchCommand(xComponent, ".uno:GoToCell", aPropertyValues); - ScTabViewShell* pViewShell = pDocSh->GetBestViewShell(false); - CPPUNIT_ASSERT_MESSAGE("No ScTabViewShell", pViewShell); + + ScTabViewShell* pViewShell = lcl_getScTabViewShellWithAssert(pDocSh); pViewShell->GetViewData().GetDispatcher().Execute(FID_INS_COLUMNS_AFTER); aExpectedRect = tools::Rectangle(Point(16000, 3000), Size(1000, 7500)); // col width 3000 aSnapRect = pObj->GetSnapRect(); @@ -682,20 +590,10 @@ void ScShapeTest::testTdf138138_MoveCellWithRotatedShape() saveAndReload(xComponent, "calc8"); CPPUNIT_ASSERT(xComponent); - // Get ScDocShell - pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Reload: Failed to access document shell", pFoundShell); - pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - - // Get document and object + // Get document and shape + pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc2 = pDocSh->GetDocument(); - pDrawLayer = rDoc2.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("Reload: No ScDrawLayer", pDrawLayer); - pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("Reload: No draw page", pPage); - pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("Reload: custom shape no longer exists", pObj); + pObj = lcl_getSdrObjectWithAssert(rDoc2, 0); // Assert objects size is unchanged, position is shifted. aSnapRect = pObj->GetSnapRect(); @@ -714,20 +612,12 @@ void ScShapeTest::testLoadVerticalFlip() uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); CPPUNIT_ASSERT(xComponent.is()); - // Get the document model - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - - // Get the shape and check that it is flipped + // Get document and shape + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT(pDrawLayer); - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT(pPage); - SdrObjCustomShape* pObj = dynamic_cast<SdrObjCustomShape*>(pPage->GetObj(0)); - CPPUNIT_ASSERT(pObj); + SdrObjCustomShape* pObj = static_cast<SdrObjCustomShape*>(lcl_getSdrObjectWithAssert(rDoc, 0)); + + // Check that shape is flipped CPPUNIT_ASSERT_MESSAGE("Load: Object should be vertically flipped", pObj->IsMirroredY()); pDocSh->DoClose(); @@ -743,26 +633,14 @@ void ScShapeTest::testTdf117948_CollapseBeforeShape() uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); CPPUNIT_ASSERT(xComponent.is()); - // Get ScDocShell - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - // Get document and objects + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("Load: No ScDrawLayer", pDrawLayer); - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("Load: No draw page", pPage); - SdrObject* pObj0 = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("Load: custom shape not found", pObj0); - SdrObject* pObj1 = pPage->GetObj(1); - CPPUNIT_ASSERT_MESSAGE("Load: Vertical line not found", pObj1); + SdrObject* pObj0 = lcl_getSdrObjectWithAssert(rDoc, 0); + SdrObject* pObj1 = lcl_getSdrObjectWithAssert(rDoc, 1); // Collapse the group - ScTabViewShell* pViewShell = pDocSh->GetBestViewShell(false); - CPPUNIT_ASSERT_MESSAGE("Load: No ScTabViewShell", pViewShell); + ScTabViewShell* pViewShell = lcl_getScTabViewShellWithAssert(pDocSh); pViewShell->GetViewData().SetCurX(1); pViewShell->GetViewData().SetCurY(0); pViewShell->GetViewData().GetDispatcher().Execute(SID_OUTLINE_HIDE); @@ -780,22 +658,11 @@ void ScShapeTest::testTdf117948_CollapseBeforeShape() saveAndReload(xComponent, "calc8"); CPPUNIT_ASSERT(xComponent); - // Get ScDocShell - pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Reload: Failed to access document shell", pFoundShell); - pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - // Get document and objects + pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc2 = pDocSh->GetDocument(); - pDrawLayer = rDoc2.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("Reload: No ScDrawLayer", pDrawLayer); - pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("Reload: No draw page", pPage); - pObj0 = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("Reload: custom shape no longer exists", pObj0); - pObj1 = pPage->GetObj(1); - CPPUNIT_ASSERT_MESSAGE("Reload: custom shape no longer exists", pObj1); + pObj0 = lcl_getSdrObjectWithAssert(rDoc2, 0); + pObj1 = lcl_getSdrObjectWithAssert(rDoc2, 1); // Assert objects size and position are not changed. Actual values differ a little bit // because of cumulated Twips-Hmm conversion errors. @@ -820,20 +687,11 @@ void ScShapeTest::testTdf137355_UndoHideRows() uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); CPPUNIT_ASSERT(xComponent.is()); - // Get the document model - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - // Get document and shape + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("No ScDrawLayer", pDrawLayer); - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("No draw page", pPage); - SdrObject* pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("No object found", pObj); + SdrObject* pObj = lcl_getSdrObjectWithAssert(rDoc, 0); + CPPUNIT_ASSERT_MESSAGE("Load: Object should be visible", pObj->IsVisible()); tools::Rectangle aSnapRectOrig(pObj->GetSnapRect()); @@ -843,9 +701,7 @@ void ScShapeTest::testTdf137355_UndoHideRows() comphelper::makePropertyValue("ToPoint", OUString("$A$3:$A$6")), }; dispatchCommand(xComponent, ".uno:GoToCell", aPropertyValues); - - ScTabViewShell* pViewShell = pDocSh->GetBestViewShell(false); - CPPUNIT_ASSERT_MESSAGE("No ScTabViewShell", pViewShell); + ScTabViewShell* pViewShell = lcl_getScTabViewShellWithAssert(pDocSh); pViewShell->GetViewData().GetDispatcher().Execute(FID_ROW_HIDE); // Check object is invisible @@ -875,27 +731,16 @@ void ScShapeTest::testTdf115655_HideDetail() uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); CPPUNIT_ASSERT(xComponent.is()); - // Get ScDocShell - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - // Get document and image + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("Load: No ScDrawLayer", pDrawLayer); - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("Load: No draw page", pPage); - SdrObject* pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("Load: No object found", pObj); + SdrObject* pObj = lcl_getSdrObjectWithAssert(rDoc, 0); // Get image size tools::Rectangle aSnapRectOrig = pObj->GetSnapRect(); // Collapse the group - ScTabViewShell* pViewShell = pDocSh->GetBestViewShell(false); - CPPUNIT_ASSERT_MESSAGE("Load: No ScTabViewShell", pViewShell); + ScTabViewShell* pViewShell = lcl_getScTabViewShellWithAssert(pDocSh); pViewShell->GetViewData().SetCurX(0); pViewShell->GetViewData().SetCurY(1); pViewShell->GetViewData().GetDispatcher().Execute(SID_OUTLINE_HIDE); @@ -905,20 +750,10 @@ void ScShapeTest::testTdf115655_HideDetail() saveAndReload(xComponent, "calc8"); CPPUNIT_ASSERT(xComponent); - // Get ScDocShell - pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Reload: Failed to access document shell", pFoundShell); - pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - // Get document and image + pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc2 = pDocSh->GetDocument(); - pDrawLayer = rDoc2.GetDrawLayer(); - CPPUNIT_ASSERT_MESSAGE("Reload: No ScDrawLayer", pDrawLayer); - pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT_MESSAGE("Reload: No draw page", pPage); - pObj = pPage->GetObj(0); - CPPUNIT_ASSERT_MESSAGE("Reload: Image no longer exists", pObj); + pObj = lcl_getSdrObjectWithAssert(rDoc2, 0); // Expand the group pViewShell = pDocSh->GetBestViewShell(false); @@ -946,29 +781,13 @@ void ScShapeTest::testFitToCellSize() uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); CPPUNIT_ASSERT(xComponent.is()); - // Get the document model - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - - // Get the shape + // Get document and shape + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT(pDrawLayer); - - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT(pPage); - - SdrObjCustomShape* pObj = dynamic_cast<SdrObjCustomShape*>(pPage->GetObj(0)); - CPPUNIT_ASSERT(pObj); - - // Get the document controller - ScTabViewShell* pViewShell = pDocSh->GetBestViewShell(false); - CPPUNIT_ASSERT(pViewShell); + SdrObjCustomShape* pObj = dynamic_cast<SdrObjCustomShape*>(lcl_getSdrObjectWithAssert(rDoc, 0)); // Get the draw view of the document + ScTabViewShell* pViewShell = lcl_getScTabViewShellWithAssert(pDocSh); ScDrawView* pDrawView = pViewShell->GetViewData().GetScDrawView(); CPPUNIT_ASSERT(pDrawView); @@ -996,23 +815,10 @@ void ScShapeTest::testCustomShapeCellAnchoredRotatedShape() uno::Reference<css::lang::XComponent> xComponent = loadFromDesktop(aFileURL); CPPUNIT_ASSERT(xComponent.is()); - // Get the document model - SfxObjectShell* pFoundShell = SfxObjectShell::GetShellFromComponent(xComponent); - CPPUNIT_ASSERT_MESSAGE("Failed to access document shell", pFoundShell); - - ScDocShell* pDocSh = dynamic_cast<ScDocShell*>(pFoundShell); - CPPUNIT_ASSERT(pDocSh); - - // Get the shape + // Get document and shape + ScDocShell* pDocSh = lcl_getScDocShellWithAssert(xComponent); ScDocument& rDoc = pDocSh->GetDocument(); - ScDrawLayer* pDrawLayer = rDoc.GetDrawLayer(); - CPPUNIT_ASSERT(pDrawLayer); - - const SdrPage* pPage = pDrawLayer->GetPage(0); - CPPUNIT_ASSERT(pPage); - - SdrObjCustomShape* pObj = dynamic_cast<SdrObjCustomShape*>(pPage->GetObj(0)); - CPPUNIT_ASSERT(pObj); + SdrObjCustomShape* pObj = dynamic_cast<SdrObjCustomShape*>(lcl_getSdrObjectWithAssert(rDoc, 0)); // Check Position and Size rDoc.SetDrawPageSize(0); // trigger recalcpos |