170f497fbSAndrew Rist /**************************************************************
2cdf0e10cSrcweir *
370f497fbSAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one
470f497fbSAndrew Rist * or more contributor license agreements. See the NOTICE file
570f497fbSAndrew Rist * distributed with this work for additional information
670f497fbSAndrew Rist * regarding copyright ownership. The ASF licenses this file
770f497fbSAndrew Rist * to you under the Apache License, Version 2.0 (the
870f497fbSAndrew Rist * "License"); you may not use this file except in compliance
970f497fbSAndrew Rist * with the License. You may obtain a copy of the License at
10cdf0e10cSrcweir *
1170f497fbSAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir *
1370f497fbSAndrew Rist * Unless required by applicable law or agreed to in writing,
1470f497fbSAndrew Rist * software distributed under the License is distributed on an
1570f497fbSAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
1670f497fbSAndrew Rist * KIND, either express or implied. See the License for the
1770f497fbSAndrew Rist * specific language governing permissions and limitations
1870f497fbSAndrew Rist * under the License.
19cdf0e10cSrcweir *
2070f497fbSAndrew Rist *************************************************************/
2170f497fbSAndrew Rist
22cdf0e10cSrcweir #include <cppuhelper/compbase1.hxx>
23cdf0e10cSrcweir #include <comphelper/broadcasthelper.hxx>
24cdf0e10cSrcweir
25cdf0e10cSrcweir #include <basegfx/matrix/b2dhommatrix.hxx>
26cdf0e10cSrcweir #include <basegfx/range/b2drectangle.hxx>
27cdf0e10cSrcweir #include <cppcanvas/spritecanvas.hxx>
28cdf0e10cSrcweir
29cdf0e10cSrcweir #include "view.hxx"
30cdf0e10cSrcweir #include "unoview.hxx"
31cdf0e10cSrcweir #include "unoviewcontainer.hxx"
32cdf0e10cSrcweir #include "shape.hxx"
33cdf0e10cSrcweir #include "tests.hxx"
34cdf0e10cSrcweir #include "../engine/slide/layermanager.hxx"
35cdf0e10cSrcweir #include "../engine/slide/layer.hxx"
36*d9ee14b8SDamjan Jovanovic #include "gtest/gtest.h"
37cdf0e10cSrcweir #include "com/sun/star/presentation/XSlideShowView.hpp"
38cdf0e10cSrcweir
39cdf0e10cSrcweir namespace target = slideshow::internal;
40cdf0e10cSrcweir using namespace ::com::sun::star;
41cdf0e10cSrcweir
42*d9ee14b8SDamjan Jovanovic // FIXME:
43*d9ee14b8SDamjan Jovanovic #define RUN_OLD_FAILING_TESTS 0
44*d9ee14b8SDamjan Jovanovic
45cdf0e10cSrcweir namespace
46cdf0e10cSrcweir {
47cdf0e10cSrcweir
48*d9ee14b8SDamjan Jovanovic class LayerManagerTest : public ::testing::Test
49cdf0e10cSrcweir {
50*d9ee14b8SDamjan Jovanovic protected:
51cdf0e10cSrcweir target::UnoViewContainer maViews;
52cdf0e10cSrcweir target::LayerManagerSharedPtr mpLayerManager;
53cdf0e10cSrcweir TestViewSharedPtr mpTestView;
54cdf0e10cSrcweir TestShapeSharedPtr mpTestShape;
55cdf0e10cSrcweir
56cdf0e10cSrcweir public:
SetUp()57*d9ee14b8SDamjan Jovanovic virtual void SetUp()
58cdf0e10cSrcweir {
59cdf0e10cSrcweir mpTestShape = createTestShape(
60cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,10.0,10.0),
61cdf0e10cSrcweir 1.0);
62cdf0e10cSrcweir mpTestView = createTestView();
63cdf0e10cSrcweir maViews.addView( mpTestView );
64cdf0e10cSrcweir
65cdf0e10cSrcweir mpLayerManager.reset(
66cdf0e10cSrcweir new target::LayerManager(
67cdf0e10cSrcweir maViews,
68cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,100.0,100.0),
69cdf0e10cSrcweir false ));
70cdf0e10cSrcweir }
71cdf0e10cSrcweir
TearDown()72*d9ee14b8SDamjan Jovanovic virtual void TearDown()
73cdf0e10cSrcweir {
74cdf0e10cSrcweir mpLayerManager.reset();
75cdf0e10cSrcweir maViews.dispose();
76cdf0e10cSrcweir }
77*d9ee14b8SDamjan Jovanovic }; // class LayerManagerTest
78cdf0e10cSrcweir
79*d9ee14b8SDamjan Jovanovic
TEST_F(LayerManagerTest,testLayer)80*d9ee14b8SDamjan Jovanovic TEST_F(LayerManagerTest, testLayer)
81cdf0e10cSrcweir {
82cdf0e10cSrcweir target::LayerSharedPtr pBgLayer(
83cdf0e10cSrcweir target::Layer::createBackgroundLayer( basegfx::B2DRange(0,0,100,100) ) );
84cdf0e10cSrcweir pBgLayer->addView( mpTestView );
85cdf0e10cSrcweir
86cdf0e10cSrcweir target::LayerSharedPtr pFgLayer(
87cdf0e10cSrcweir target::Layer::createLayer( basegfx::B2DRange(0,0,100,100) ) );
88cdf0e10cSrcweir pFgLayer->addView( mpTestView );
89cdf0e10cSrcweir
90*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pBgLayer->isBackgroundLayer() ) << "BG layer must confess that!";
91*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( !pFgLayer->isBackgroundLayer() ) << "FG layer lies!";
92cdf0e10cSrcweir
93*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( !pBgLayer->isUpdatePending() ) << "BG layer must not have pending updates!";
94cdf0e10cSrcweir pBgLayer->addUpdateRange( basegfx::B2DRange(0,0,10,10) );
95*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pBgLayer->isUpdatePending() ) << "BG layer must have pending updates!";
96cdf0e10cSrcweir
97cdf0e10cSrcweir TestShapeSharedPtr pTestShape = createTestShape(
98cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,1000.0,1000.0),
99cdf0e10cSrcweir 1.0);
100cdf0e10cSrcweir pBgLayer->updateBounds( pTestShape );
101*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( !pBgLayer->commitBounds() ) << "BG layer must not resize!";
102cdf0e10cSrcweir
103cdf0e10cSrcweir TestShapeSharedPtr pTestShape2 = createTestShape(
104cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,1.0,1.0),
105cdf0e10cSrcweir 1.0);
106cdf0e10cSrcweir pFgLayer->updateBounds( pTestShape2 );
107*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pFgLayer->commitBounds() ) << "FG layer must resize!";
108cdf0e10cSrcweir }
109cdf0e10cSrcweir
TEST_F(LayerManagerTest,testBasics)110*d9ee14b8SDamjan Jovanovic TEST_F(LayerManagerTest, testBasics)
111cdf0e10cSrcweir {
112cdf0e10cSrcweir mpLayerManager->activate( false );
113cdf0e10cSrcweir
114*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestShape->getViewLayers().empty() ) << "Un-added shape must have zero view layers";
115cdf0e10cSrcweir mpLayerManager->addShape(mpTestShape);
116*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpLayerManager->isUpdatePending() ) << "Adding a shape requires a LayerManager update";
117cdf0e10cSrcweir
118cdf0e10cSrcweir // update does the delayed viewAdded call to the shape
119*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpLayerManager->update() ) << "Update failed on LayerManager";
120*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestShape->getViewLayers().size() == 1 ) << "Added shape must have one view layer";
121*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestShape->getNumRenders() ) << "Shape must been rendered";
122*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( !mpTestShape->getNumUpdates() ) << "Shape must not been updated";
123cdf0e10cSrcweir
124cdf0e10cSrcweir // test second view, check whether shape gets additional view
125cdf0e10cSrcweir TestViewSharedPtr pTestView( createTestView() );
126*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( maViews.addView( pTestView ) ) << "Adding second View failed";
127*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( maViews.end() - maViews.begin() == 2 ) << "View container must have two views";
128cdf0e10cSrcweir mpLayerManager->viewAdded(pTestView);
129*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestShape->getViewLayers().size() == 2 ) << "Added shape must have two view layers";
130cdf0e10cSrcweir
131*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( maViews.removeView( pTestView ) ) << "Removing second View failed";
132cdf0e10cSrcweir mpLayerManager->viewRemoved(pTestView);
133*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestShape->getViewLayers().size() == 1 ) << "Added shape must have one view layer";
134cdf0e10cSrcweir
135cdf0e10cSrcweir mpLayerManager->deactivate();
136cdf0e10cSrcweir }
137cdf0e10cSrcweir
TEST_F(LayerManagerTest,testShapeOrdering)138*d9ee14b8SDamjan Jovanovic TEST_F(LayerManagerTest, testShapeOrdering)
139cdf0e10cSrcweir {
140cdf0e10cSrcweir TestShapeSharedPtr pShape2( createTestShape(
141cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,10.0,10.0),
142cdf0e10cSrcweir 2.0));
143cdf0e10cSrcweir TestShapeSharedPtr pShape3( createTestShape(
144cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,10.0,10.0),
145cdf0e10cSrcweir 3.0));
146cdf0e10cSrcweir TestShapeSharedPtr pShape4( createTestShape(
147cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,10.0,10.0),
148cdf0e10cSrcweir 4.0));
149cdf0e10cSrcweir
150cdf0e10cSrcweir mpLayerManager->addShape(mpTestShape);
151cdf0e10cSrcweir mpLayerManager->addShape(pShape2);
152cdf0e10cSrcweir mpLayerManager->addShape(pShape3);
153cdf0e10cSrcweir mpLayerManager->addShape(pShape4);
154cdf0e10cSrcweir
155cdf0e10cSrcweir mpLayerManager->activate( false );
156cdf0e10cSrcweir
157cdf0e10cSrcweir // update does the delayed viewAdded call to the shape
158*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpLayerManager->update() ) << "Update failed on LayerManager";
159*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestView->getViewLayers().empty() ) << "View must have background layer only";
160cdf0e10cSrcweir
161cdf0e10cSrcweir // LayerManager must now generate one extra view layer
162cdf0e10cSrcweir mpLayerManager->enterAnimationMode(pShape2);
163*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpLayerManager->isUpdatePending() ) << "No update pending on LayerManager";
164*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpLayerManager->update() ) << "Update failed on LayerManager";
165*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestView->getViewLayers().size() == 1 ) << "View must have one extra layer only";
166*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestView->getViewLayers().at(0)->getBounds() ==
167*d9ee14b8SDamjan Jovanovic basegfx::B2DRange(0.0,0.0,10.0,10.0) ) << "View layer must have 10x10 size";
168cdf0e10cSrcweir
169cdf0e10cSrcweir // LayerManager must now remove the extra view layer
170cdf0e10cSrcweir mpLayerManager->leaveAnimationMode(pShape2);
171*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpLayerManager->isUpdatePending() ) << "No update pending on LayerManager";
172*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpLayerManager->update() ) << "Update failed on LayerManager #2";
173*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestShape->getViewLayers().at(0).first == mpTestView ) << "Shape 1 must be on background layer";
174*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape2->getViewLayers().at(0).first == mpTestView ) << "Shape 2 must be on background layer";
175*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape3->getViewLayers().size() == 1 ) << "Shape 3 must have one layer";
176*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape3->getViewLayers().at(0).first == mpTestView ) << "Shape 3 must be on background layer";
177*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape4->getViewLayers().at(0).first == mpTestView ) << "Shape 4 must be on background layer";
178cdf0e10cSrcweir
179cdf0e10cSrcweir // checking deactivation (all layers except background layer
180cdf0e10cSrcweir // must vanish)
181cdf0e10cSrcweir mpLayerManager->enterAnimationMode(pShape3);
182*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpLayerManager->isUpdatePending() ) << "No update pending on LayerManager";
183*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpLayerManager->update() ) << "Update failed on LayerManager";
184*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape4->getViewLayers().at(0).first != mpTestView ) << "Shape 4 must not be on background layer";
185cdf0e10cSrcweir mpLayerManager->leaveAnimationMode(pShape3);
186*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpLayerManager->update() ) << "Update failed on LayerManager";
187*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape4->getViewLayers().at(0).first == mpTestView ) << "Shape 4 must be on background layer";
188cdf0e10cSrcweir
189cdf0e10cSrcweir mpLayerManager->deactivate();
190*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( !mpLayerManager->isUpdatePending() ) << "Update pending on deactivated LayerManager";
191cdf0e10cSrcweir }
192cdf0e10cSrcweir
TEST_F(LayerManagerTest,testShapeRepaint)193*d9ee14b8SDamjan Jovanovic TEST_F(LayerManagerTest, testShapeRepaint)
194cdf0e10cSrcweir {
195cdf0e10cSrcweir TestShapeSharedPtr pShape2( createTestShape(
196cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,10.0,10.0),
197cdf0e10cSrcweir 2.0));
198cdf0e10cSrcweir TestShapeSharedPtr pShape3( createTestShape(
199cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,10.0,10.0),
200cdf0e10cSrcweir 3.0));
201cdf0e10cSrcweir TestShapeSharedPtr pShape4( createTestShape(
202cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,10.0,10.0),
203cdf0e10cSrcweir 4.0));
204cdf0e10cSrcweir TestShapeSharedPtr pShape5( createTestShape(
205cdf0e10cSrcweir basegfx::B2DRange(20.0,20.0,30.0,30.0),
206cdf0e10cSrcweir 4.0));
207cdf0e10cSrcweir
208cdf0e10cSrcweir mpLayerManager->addShape(mpTestShape);
209cdf0e10cSrcweir mpLayerManager->addShape(pShape2);
210cdf0e10cSrcweir mpLayerManager->enterAnimationMode(pShape2);
211cdf0e10cSrcweir mpLayerManager->addShape(pShape3);
212cdf0e10cSrcweir mpLayerManager->addShape(pShape4);
213cdf0e10cSrcweir mpLayerManager->addShape(pShape5);
214cdf0e10cSrcweir
215cdf0e10cSrcweir mpLayerManager->activate( false );
216cdf0e10cSrcweir mpLayerManager->update();
217cdf0e10cSrcweir
218*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestShape->getNumRenders() == 1 ) << "First shape not rendered";
219*d9ee14b8SDamjan Jovanovic #if RUN_OLD_FAILING_TESTS
220*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape2->getNumRenders() == 1 ) << "Second shape not rendered";
221*d9ee14b8SDamjan Jovanovic #endif
222*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape3->getNumRenders() == 1 ) << "Third shape not rendered";
223*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape4->getNumRenders() == 1 ) << "Fourth shape not rendered";
224*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape5->getNumRenders() == 1 ) << "Fifth shape not rendered";
225cdf0e10cSrcweir
226cdf0e10cSrcweir mpLayerManager->enterAnimationMode(pShape4);
227cdf0e10cSrcweir mpLayerManager->update();
228cdf0e10cSrcweir
229*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestShape->getNumRenders() == 1 ) << "First shape not rendered";
230*d9ee14b8SDamjan Jovanovic #if RUN_OLD_FAILING_TESTS
231*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape2->getNumRenders() == 1 ) << "Second shape not rendered";
232*d9ee14b8SDamjan Jovanovic #endif
233*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape3->getNumRenders() == 2 ) << "Third shape not rendered";
234*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape4->getNumRenders() == 2 ) << "Fourth shape not rendered";
235*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape5->getNumRenders() == 2 ) << "Fifth shape not rendered";
236cdf0e10cSrcweir
237cdf0e10cSrcweir mpLayerManager->leaveAnimationMode(pShape2);
238cdf0e10cSrcweir mpLayerManager->leaveAnimationMode(pShape4);
239cdf0e10cSrcweir mpLayerManager->update();
240cdf0e10cSrcweir
241*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestShape->getNumRenders() == 2 ) << "First shape not rendered #2";
242*d9ee14b8SDamjan Jovanovic #if RUN_OLD_FAILING_TESTS
243*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape2->getNumRenders() == 2 ) << "Second shape not rendered #2"
244*d9ee14b8SDamjan Jovanovic #endif
245*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape3->getNumRenders() == 3 ) << "Third shape not rendered #2";
246*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape4->getNumRenders() == 3 ) << "Fourth shape not rendered #2";
247*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape5->getNumRenders() == 3 ) << "Fifth shape not rendered #2";
248cdf0e10cSrcweir }
249cdf0e10cSrcweir
TEST_F(LayerManagerTest,testRefCounting)250*d9ee14b8SDamjan Jovanovic TEST_F(LayerManagerTest, testRefCounting)
251cdf0e10cSrcweir {
252cdf0e10cSrcweir TestShapeSharedPtr pShape2( createTestShape(
253cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,10.0,10.0),
254cdf0e10cSrcweir 2.0));
255cdf0e10cSrcweir TestShapeSharedPtr pShape3( createTestShape(
256cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,10.0,10.0),
257cdf0e10cSrcweir 3.0));
258cdf0e10cSrcweir TestShapeSharedPtr pShape4( createTestShape(
259cdf0e10cSrcweir basegfx::B2DRange(0.0,0.0,10.0,10.0),
260cdf0e10cSrcweir 4.0));
261cdf0e10cSrcweir
262cdf0e10cSrcweir mpLayerManager->addShape(mpTestShape);
263cdf0e10cSrcweir mpLayerManager->addShape(pShape2);
264cdf0e10cSrcweir mpLayerManager->addShape(pShape3);
265cdf0e10cSrcweir mpLayerManager->addShape(pShape4);
266cdf0e10cSrcweir
267cdf0e10cSrcweir mpLayerManager->removeShape(mpTestShape);
268cdf0e10cSrcweir mpLayerManager->removeShape(pShape2);
269cdf0e10cSrcweir mpLayerManager->removeShape(pShape3);
270cdf0e10cSrcweir mpLayerManager->removeShape(pShape4);
271cdf0e10cSrcweir
272*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestShape.use_count() == 1 ) << "Shape 1 must have refcount of 1";
273*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape2.use_count() == 1 ) << "Shape 2 must have refcount of 1";
274*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape3.use_count() == 1 ) << "Shape 3 must have refcount of 1";
275*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape4.use_count() == 1 ) << "Shape 4 must have refcount of 1";
276cdf0e10cSrcweir
277cdf0e10cSrcweir
278cdf0e10cSrcweir mpLayerManager->addShape(mpTestShape);
279cdf0e10cSrcweir mpLayerManager->addShape(pShape2);
280cdf0e10cSrcweir mpLayerManager->addShape(pShape3);
281cdf0e10cSrcweir mpLayerManager->addShape(pShape4);
282cdf0e10cSrcweir
283cdf0e10cSrcweir mpLayerManager->activate( false );
284cdf0e10cSrcweir mpLayerManager->update();
285cdf0e10cSrcweir
286cdf0e10cSrcweir mpLayerManager->removeShape(mpTestShape);
287cdf0e10cSrcweir mpLayerManager->removeShape(pShape2);
288cdf0e10cSrcweir mpLayerManager->removeShape(pShape3);
289cdf0e10cSrcweir mpLayerManager->removeShape(pShape4);
290cdf0e10cSrcweir
291*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestShape.use_count() == 1 ) << "Shape 1 must have refcount of 1";
292*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape2.use_count() == 1 ) << "Shape 2 must have refcount of 1";
293*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape3.use_count() == 1 ) << "Shape 3 must have refcount of 1";
294*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( pShape4.use_count() == 1 ) << "Shape 4 must have refcount of 1";
295cdf0e10cSrcweir
296cdf0e10cSrcweir maViews.removeView(mpTestView);
297cdf0e10cSrcweir mpLayerManager->viewRemoved(mpTestView);
298*d9ee14b8SDamjan Jovanovic ASSERT_TRUE( mpTestView.use_count() == 1 ) << "View must have refcount of 1";
299cdf0e10cSrcweir }
300cdf0e10cSrcweir
301cdf0e10cSrcweir
302cdf0e10cSrcweir } // namespace
303