diff options
author | Oliver Bolte <obo@openoffice.org> | 2007-07-17 14:21:30 +0000 |
---|---|---|
committer | Oliver Bolte <obo@openoffice.org> | 2007-07-17 14:21:30 +0000 |
commit | c5e7b26f638d965f943ef0a636941a5fdc58cb33 (patch) | |
tree | d573949ca9d51f7730c07e1ec63e99dff14af6fe /slideshow/test | |
parent | e015abd6d279e260c1f69a984fdf3b35f11b01ed (diff) |
INTEGRATION: CWS presfixes12 (1.1.2); FILE ADDED
2007/05/10 20:32:41 thb 1.1.2.6: #i37778# Reworked LayerManager::updateShapeLayers - now much better aligned with general shape update, and avoids superfluous rendering; made unit tests work again; passing down slide background repaint status to LayerManager; relaxed preconditions for Shape::getUpdateArea() - no longer requires views to work; now catching singular view matrix and using sensible default at API border
2007/03/06 21:54:19 thb 1.1.2.5: #i37778# Added bool property to disable z order correct animations
2007/03/05 13:47:13 thb 1.1.2.4: #i37778# Removed Activity::needsScreenUpdate() method - this is now handled by notifying ScreenUpdater explicitely; reorg of SlideShowImpl members, to align lifetime with mutual references; fixed (hopefully) last repaint issues with new LayerManager; added more tests
2007/02/25 01:10:28 thb 1.1.2.3: #i37778# Cleared up error handling a lot: no longer quenching RuntimeExceptions; reporting assertions in the debug case; ViewLayer now reports resized sprite (which needs re-render from all shapes); fixed missing subset area reduction for glyph-level animations; added return of resize state from Layer::commitLayerBounds(); adapted unit tests to corrected behaviour
2007/02/12 02:14:52 thb 1.1.2.2: #i37778# Added workaround to have ViewLayer always return valid canvas (even if no size has been set); fixed silly reference-instead-of-byvalue bug in SlideAnimations for slide size; fixed member initialization order problem in SlideImpl (also affecting slide size); adapted shape import for new LayerManager (which no longer gracefully ignores addition of NULL shapes); extended unit tests to catch fixed bugs
2007/02/10 23:23:53 thb 1.1.2.1: #i37778# Renamed setMouseCursor() to setCursorShape() at View interface (name clash with API method otherwise); added LayerManager/Layer unit tests; fixed a bunch of bugs/glitches found during unit testing
Diffstat (limited to 'slideshow/test')
-rw-r--r-- | slideshow/test/slidetest.cxx | 378 |
1 files changed, 378 insertions, 0 deletions
diff --git a/slideshow/test/slidetest.cxx b/slideshow/test/slidetest.cxx new file mode 100644 index 000000000000..3ef7eadf70f4 --- /dev/null +++ b/slideshow/test/slidetest.cxx @@ -0,0 +1,378 @@ +/************************************************************************* + * + * OpenOffice.org - a multi-platform office productivity suite + * + * $RCSfile: slidetest.cxx,v $ + * + * $Revision: 1.2 $ + * + * last change: $Author: obo $ $Date: 2007-07-17 15:21:30 $ + * + * The Contents of this file are made available subject to + * the terms of GNU Lesser General Public License Version 2.1. + * + * + * GNU Lesser General Public License Version 2.1 + * ============================================= + * Copyright 2005 by Sun Microsystems, Inc. + * 901 San Antonio Road, Palo Alto, CA 94303, USA + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License version 2.1, as published by the Free Software Foundation. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + * + ************************************************************************/ + +#include <cppunit/simpleheader.hxx> +#include <cppuhelper/compbase1.hxx> +#include <comphelper/broadcasthelper.hxx> + +#include <basegfx/matrix/b2dhommatrix.hxx> +#include <basegfx/range/b2drectangle.hxx> +#include <cppcanvas/spritecanvas.hxx> + +#include "view.hxx" +#include "unoview.hxx" +#include "unoviewcontainer.hxx" +#include "shape.hxx" +#include "tests.hxx" +#include "../engine/slide/layermanager.hxx" +#include "../engine/slide/layer.hxx" +#include "com/sun/star/presentation/XSlideShowView.hpp" + +namespace target = slideshow::internal; +using namespace ::com::sun::star; + +namespace +{ + +class LayerManagerTest : public CppUnit::TestFixture +{ + target::UnoViewContainer maViews; + target::LayerManagerSharedPtr mpLayerManager; + TestViewSharedPtr mpTestView; + TestShapeSharedPtr mpTestShape; + +public: + void setUp() + { + mpTestShape = createTestShape( + basegfx::B2DRange(0.0,0.0,10.0,10.0), + 1.0); + mpTestView = createTestView(); + maViews.addView( mpTestView ); + + mpLayerManager.reset( + new target::LayerManager( + maViews, + basegfx::B2DRange(0.0,0.0,100.0,100.0), + false )); + } + + void tearDown() + { + mpLayerManager.reset(); + maViews.dispose(); + } + + void testLayer() + { + target::LayerSharedPtr pBgLayer( + target::Layer::createBackgroundLayer( basegfx::B2DRange(0,0,100,100) ) ); + pBgLayer->addView( mpTestView ); + + target::LayerSharedPtr pFgLayer( + target::Layer::createLayer( basegfx::B2DRange(0,0,100,100) ) ); + pFgLayer->addView( mpTestView ); + + CPPUNIT_ASSERT_MESSAGE( "BG layer must confess that!", + pBgLayer->isBackgroundLayer() ); + CPPUNIT_ASSERT_MESSAGE( "FG layer lies!", + !pFgLayer->isBackgroundLayer() ); + + CPPUNIT_ASSERT_MESSAGE( "BG layer must not have pending updates!", + !pBgLayer->isUpdatePending() ); + pBgLayer->addUpdateRange( basegfx::B2DRange(0,0,10,10) ); + CPPUNIT_ASSERT_MESSAGE( "BG layer must have pending updates!", + pBgLayer->isUpdatePending() ); + + TestShapeSharedPtr pTestShape = createTestShape( + basegfx::B2DRange(0.0,0.0,1000.0,1000.0), + 1.0); + pBgLayer->updateBounds( pTestShape ); + CPPUNIT_ASSERT_MESSAGE( "BG layer must not resize!", + !pBgLayer->commitBounds() ); + + TestShapeSharedPtr pTestShape2 = createTestShape( + basegfx::B2DRange(0.0,0.0,1.0,1.0), + 1.0); + pFgLayer->updateBounds( pTestShape2 ); + CPPUNIT_ASSERT_MESSAGE( "FG layer must resize!", + pFgLayer->commitBounds() ); + } + + void testBasics() + { + mpLayerManager->activate( false ); + + CPPUNIT_ASSERT_MESSAGE( "Un-added shape must have zero view layers", + mpTestShape->getViewLayers().empty() ); + mpLayerManager->addShape(mpTestShape); + CPPUNIT_ASSERT_MESSAGE( "Adding a shape requires a LayerManager update", + mpLayerManager->isUpdatePending() ); + + // update does the delayed viewAdded call to the shape + CPPUNIT_ASSERT_MESSAGE( "Update failed on LayerManager", + mpLayerManager->update() ); + CPPUNIT_ASSERT_MESSAGE( "Added shape must have one view layer", + mpTestShape->getViewLayers().size() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Shape must been rendered", + mpTestShape->getNumRenders() ); + CPPUNIT_ASSERT_MESSAGE( "Shape must not been updated", + !mpTestShape->getNumUpdates() ); + + // test second view, check whether shape gets additional view + TestViewSharedPtr pTestView( createTestView() ); + CPPUNIT_ASSERT_MESSAGE( "Adding second View failed", + maViews.addView( pTestView ) ); + CPPUNIT_ASSERT_MESSAGE( "View container must have two views", + maViews.end() - maViews.begin() == 2 ); + mpLayerManager->viewAdded(pTestView); + CPPUNIT_ASSERT_MESSAGE( "Added shape must have two view layers", + mpTestShape->getViewLayers().size() == 2 ); + + CPPUNIT_ASSERT_MESSAGE( "Removing second View failed", + maViews.removeView( pTestView ) ); + mpLayerManager->viewRemoved(pTestView); + CPPUNIT_ASSERT_MESSAGE( "Added shape must have one view layer", + mpTestShape->getViewLayers().size() == 1 ); + + mpLayerManager->deactivate(); + } + + void testShapeOrdering() + { + TestShapeSharedPtr pShape2( createTestShape( + basegfx::B2DRange(0.0,0.0,10.0,10.0), + 2.0)); + TestShapeSharedPtr pShape3( createTestShape( + basegfx::B2DRange(0.0,0.0,10.0,10.0), + 3.0)); + TestShapeSharedPtr pShape4( createTestShape( + basegfx::B2DRange(0.0,0.0,10.0,10.0), + 4.0)); + + mpLayerManager->addShape(mpTestShape); + mpLayerManager->addShape(pShape2); + mpLayerManager->addShape(pShape3); + mpLayerManager->addShape(pShape4); + + mpLayerManager->activate( false ); + + // update does the delayed viewAdded call to the shape + CPPUNIT_ASSERT_MESSAGE( "Update failed on LayerManager", + mpLayerManager->update() ); + CPPUNIT_ASSERT_MESSAGE( "View must have background layer only", + mpTestView->getViewLayers().empty() ); + + // LayerManager must now generate one extra view layer + mpLayerManager->enterAnimationMode(pShape2); + CPPUNIT_ASSERT_MESSAGE( "No update pending on LayerManager", + mpLayerManager->isUpdatePending() ); + CPPUNIT_ASSERT_MESSAGE( "Update failed on LayerManager", + mpLayerManager->update() ); + CPPUNIT_ASSERT_MESSAGE( "View must have one extra layer only", + mpTestView->getViewLayers().size() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "View layer must have 10x10 size", + mpTestView->getViewLayers().at(0)->getBounds() == + basegfx::B2DRange(0.0,0.0,10.0,10.0) ); + + // LayerManager must now remove the extra view layer + mpLayerManager->leaveAnimationMode(pShape2); + CPPUNIT_ASSERT_MESSAGE( "No update pending on LayerManager", + mpLayerManager->isUpdatePending() ); + CPPUNIT_ASSERT_MESSAGE( "Update failed on LayerManager #2", + mpLayerManager->update() ); + CPPUNIT_ASSERT_MESSAGE( "Shape 1 must be on background layer", + mpTestShape->getViewLayers().at(0).first == mpTestView ); + CPPUNIT_ASSERT_MESSAGE( "Shape 2 must be on background layer", + pShape2->getViewLayers().at(0).first == mpTestView ); + CPPUNIT_ASSERT_MESSAGE( "Shape 3 must have one layer", + pShape3->getViewLayers().size() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Shape 3 must be on background layer", + pShape3->getViewLayers().at(0).first == mpTestView ); + CPPUNIT_ASSERT_MESSAGE( "Shape 4 must be on background layer", + pShape4->getViewLayers().at(0).first == mpTestView ); + + // checking deactivation (all layers except background layer + // must vanish) + mpLayerManager->enterAnimationMode(pShape3); + CPPUNIT_ASSERT_MESSAGE( "No update pending on LayerManager", + mpLayerManager->isUpdatePending() ); + CPPUNIT_ASSERT_MESSAGE( "Update failed on LayerManager", + mpLayerManager->update() ); + CPPUNIT_ASSERT_MESSAGE( "Shape 4 must not be on background layer", + pShape4->getViewLayers().at(0).first != mpTestView ); + mpLayerManager->leaveAnimationMode(pShape3); + CPPUNIT_ASSERT_MESSAGE( "Update failed on LayerManager", + mpLayerManager->update() ); + CPPUNIT_ASSERT_MESSAGE( "Shape 4 must be on background layer", + pShape4->getViewLayers().at(0).first == mpTestView ); + + mpLayerManager->deactivate(); + CPPUNIT_ASSERT_MESSAGE( "Update pending on deactivated LayerManager", + !mpLayerManager->isUpdatePending() ); + } + + void testShapeRepaint() + { + TestShapeSharedPtr pShape2( createTestShape( + basegfx::B2DRange(0.0,0.0,10.0,10.0), + 2.0)); + TestShapeSharedPtr pShape3( createTestShape( + basegfx::B2DRange(0.0,0.0,10.0,10.0), + 3.0)); + TestShapeSharedPtr pShape4( createTestShape( + basegfx::B2DRange(0.0,0.0,10.0,10.0), + 4.0)); + TestShapeSharedPtr pShape5( createTestShape( + basegfx::B2DRange(20.0,20.0,30.0,30.0), + 4.0)); + + mpLayerManager->addShape(mpTestShape); + mpLayerManager->addShape(pShape2); + mpLayerManager->enterAnimationMode(pShape2); + mpLayerManager->addShape(pShape3); + mpLayerManager->addShape(pShape4); + mpLayerManager->addShape(pShape5); + + mpLayerManager->activate( false ); + mpLayerManager->update(); + + CPPUNIT_ASSERT_MESSAGE( "First shape not rendered", + mpTestShape->getNumRenders() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Second shape not rendered", + pShape2->getNumRenders() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Third shape not rendered", + pShape3->getNumRenders() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Fourth shape not rendered", + pShape4->getNumRenders() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Fifth shape not rendered", + pShape5->getNumRenders() == 1 ); + + mpLayerManager->enterAnimationMode(pShape4); + mpLayerManager->update(); + + CPPUNIT_ASSERT_MESSAGE( "First shape not rendered", + mpTestShape->getNumRenders() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Second shape not rendered", + pShape2->getNumRenders() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Third shape not rendered", + pShape3->getNumRenders() == 2 ); + CPPUNIT_ASSERT_MESSAGE( "Fourth shape not rendered", + pShape4->getNumRenders() == 2 ); + CPPUNIT_ASSERT_MESSAGE( "Fifth shape not rendered", + pShape5->getNumRenders() == 2 ); + + mpLayerManager->leaveAnimationMode(pShape2); + mpLayerManager->leaveAnimationMode(pShape4); + mpLayerManager->update(); + + CPPUNIT_ASSERT_MESSAGE( "First shape not rendered #2", + mpTestShape->getNumRenders() == 2 ); + CPPUNIT_ASSERT_MESSAGE( "Second shape not rendered #2", + pShape2->getNumRenders() == 2 ); + CPPUNIT_ASSERT_MESSAGE( "Third shape not rendered #2", + pShape3->getNumRenders() == 3 ); + CPPUNIT_ASSERT_MESSAGE( "Fourth shape not rendered #2", + pShape4->getNumRenders() == 3 ); + CPPUNIT_ASSERT_MESSAGE( "Fifth shape not rendered #2", + pShape5->getNumRenders() == 3 ); + } + + void testRefCounting() + { + TestShapeSharedPtr pShape2( createTestShape( + basegfx::B2DRange(0.0,0.0,10.0,10.0), + 2.0)); + TestShapeSharedPtr pShape3( createTestShape( + basegfx::B2DRange(0.0,0.0,10.0,10.0), + 3.0)); + TestShapeSharedPtr pShape4( createTestShape( + basegfx::B2DRange(0.0,0.0,10.0,10.0), + 4.0)); + + mpLayerManager->addShape(mpTestShape); + mpLayerManager->addShape(pShape2); + mpLayerManager->addShape(pShape3); + mpLayerManager->addShape(pShape4); + + mpLayerManager->removeShape(mpTestShape); + mpLayerManager->removeShape(pShape2); + mpLayerManager->removeShape(pShape3); + mpLayerManager->removeShape(pShape4); + + CPPUNIT_ASSERT_MESSAGE( "Shape 1 must have refcount of 1", + mpTestShape.use_count() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Shape 2 must have refcount of ", + pShape2.use_count() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Shape 3 must have refcount of 1", + pShape3.use_count() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Shape 4 must have refcount of", + pShape4.use_count() == 1 ); + + + mpLayerManager->addShape(mpTestShape); + mpLayerManager->addShape(pShape2); + mpLayerManager->addShape(pShape3); + mpLayerManager->addShape(pShape4); + + mpLayerManager->activate( false ); + mpLayerManager->update(); + + mpLayerManager->removeShape(mpTestShape); + mpLayerManager->removeShape(pShape2); + mpLayerManager->removeShape(pShape3); + mpLayerManager->removeShape(pShape4); + + CPPUNIT_ASSERT_MESSAGE( "Shape 1 must have refcount of 1", + mpTestShape.use_count() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Shape 2 must have refcount of ", + pShape2.use_count() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Shape 3 must have refcount of 1", + pShape3.use_count() == 1 ); + CPPUNIT_ASSERT_MESSAGE( "Shape 4 must have refcount of 1", + pShape4.use_count() == 1 ); + + maViews.removeView(mpTestView); + mpLayerManager->viewRemoved(mpTestView); + CPPUNIT_ASSERT_MESSAGE( "View must have refcount of 1", + mpTestView.use_count() == 1 ); + } + + // hook up the test + CPPUNIT_TEST_SUITE(LayerManagerTest); + CPPUNIT_TEST(testBasics); + CPPUNIT_TEST(testLayer); + CPPUNIT_TEST(testShapeOrdering); + CPPUNIT_TEST(testShapeRepaint); + CPPUNIT_TEST(testRefCounting); + CPPUNIT_TEST_SUITE_END(); + +}; // class LayerManagerTest + +// ----------------------------------------------------------------------------- +CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(LayerManagerTest, "LayerManagerTest"); +} // namespace + + |