xref: /aoo4110/main/framework/test/test.cxx (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_framework.hxx"
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
28*b1cdbd2cSJim Jagielski //	my own includes
29*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
30*b1cdbd2cSJim Jagielski #include <classes/servicemanager.hxx>
31*b1cdbd2cSJim Jagielski #include <classes/filtercache.hxx>
32*b1cdbd2cSJim Jagielski #include <macros/generic.hxx>
33*b1cdbd2cSJim Jagielski #include <macros/debug.hxx>
34*b1cdbd2cSJim Jagielski #include <services.h>
35*b1cdbd2cSJim Jagielski 
36*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
37*b1cdbd2cSJim Jagielski //	interface includes
38*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
39*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XDesktop.hpp>
40*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XFrame.hpp>
41*b1cdbd2cSJim Jagielski #include <com/sun/star/awt/XWindow.hpp>
42*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XFrameLoader.hpp>
43*b1cdbd2cSJim Jagielski #include <com/sun/star/beans/PropertyValue.hpp>
44*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XLoadEventListener.hpp>
45*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XDispatchProvider.hpp>
46*b1cdbd2cSJim Jagielski #include <com/sun/star/util/URL.hpp>
47*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/FrameSearchFlag.hpp>
48*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XFrames.hpp>
49*b1cdbd2cSJim Jagielski #include <com/sun/star/lang/XServiceInfo.hpp>
50*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XComponentLoader.hpp>
51*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XTasksSupplier.hpp>
52*b1cdbd2cSJim Jagielski #include <com/sun/star/task/XStatusIndicatorFactory.hpp>
53*b1cdbd2cSJim Jagielski #include <com/sun/star/beans/XMultiPropertySet.hpp>
54*b1cdbd2cSJim Jagielski #include <com/sun/star/lang/XSingleServiceFactory.hpp>
55*b1cdbd2cSJim Jagielski #include <com/sun/star/mozilla/XPluginInstancePeer.hpp>
56*b1cdbd2cSJim Jagielski #include <com/sun/star/bridge/XInstanceProvider.hpp>
57*b1cdbd2cSJim Jagielski #include <com/sun/star/document/XTypeDetection.hpp>
58*b1cdbd2cSJim Jagielski #include <com/sun/star/container/XNameAccess.hpp>
59*b1cdbd2cSJim Jagielski #include <com/sun/star/container/XNameContainer.hpp>
60*b1cdbd2cSJim Jagielski #include <com/sun/star/container/XElementAccess.hpp>
61*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XConfigManager.hpp>
62*b1cdbd2cSJim Jagielski 
63*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
64*b1cdbd2cSJim Jagielski //	other includes
65*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
66*b1cdbd2cSJim Jagielski #include <comphelper/processfactory.hxx>
67*b1cdbd2cSJim Jagielski #include <com/sun/star/uno/Reference.h>
68*b1cdbd2cSJim Jagielski #include <rtl/ustring.hxx>
69*b1cdbd2cSJim Jagielski #include <rtl/ustrbuf.hxx>
70*b1cdbd2cSJim Jagielski #include <toolkit/helper/vclunohelper.hxx>
71*b1cdbd2cSJim Jagielski #include <svtools/unoiface.hxx>
72*b1cdbd2cSJim Jagielski #include <tools/urlobj.hxx>
73*b1cdbd2cSJim Jagielski 
74*b1cdbd2cSJim Jagielski #include <vcl/event.hxx>
75*b1cdbd2cSJim Jagielski #include <vcl/svapp.hxx>
76*b1cdbd2cSJim Jagielski #include <vcl/wrkwin.hxx>
77*b1cdbd2cSJim Jagielski #include <vcl/msgbox.hxx>
78*b1cdbd2cSJim Jagielski #include <stdio.h>
79*b1cdbd2cSJim Jagielski 
80*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
81*b1cdbd2cSJim Jagielski //	const
82*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
83*b1cdbd2cSJim Jagielski 
84*b1cdbd2cSJim Jagielski #define	APPLICATIONNAME							"FrameWork - Testapplication"
85*b1cdbd2cSJim Jagielski 
86*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
87*b1cdbd2cSJim Jagielski //	namespace
88*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
89*b1cdbd2cSJim Jagielski 
90*b1cdbd2cSJim Jagielski using namespace ::rtl						;
91*b1cdbd2cSJim Jagielski using namespace ::comphelper				;
92*b1cdbd2cSJim Jagielski using namespace ::framework					;
93*b1cdbd2cSJim Jagielski using namespace ::cppu						;
94*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::uno		;
95*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::lang		;
96*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::frame		;
97*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::awt		;
98*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::beans		;
99*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::util		;
100*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::task		;
101*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::mozilla	;
102*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::bridge	;
103*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::document	;
104*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::container	;
105*b1cdbd2cSJim Jagielski 
106*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
107*b1cdbd2cSJim Jagielski //	defines
108*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
109*b1cdbd2cSJim Jagielski 
110*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
111*b1cdbd2cSJim Jagielski //	declarations
112*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
113*b1cdbd2cSJim Jagielski 
114*b1cdbd2cSJim Jagielski /*-***************************************************************************************************************/
115*b1cdbd2cSJim Jagielski class TestApplication : public Application
116*b1cdbd2cSJim Jagielski {
117*b1cdbd2cSJim Jagielski 	//*************************************************************************************************************
118*b1cdbd2cSJim Jagielski 	public:
119*b1cdbd2cSJim Jagielski 
120*b1cdbd2cSJim Jagielski 		void Main();
121*b1cdbd2cSJim Jagielski 
122*b1cdbd2cSJim Jagielski 	//*************************************************************************************************************
123*b1cdbd2cSJim Jagielski 	private:
124*b1cdbd2cSJim Jagielski 
125*b1cdbd2cSJim Jagielski 		#ifdef TEST_DESKTOP
126*b1cdbd2cSJim Jagielski 		void impl_testDesktop	( const Reference< XDesktop >& xDesktop );
127*b1cdbd2cSJim Jagielski 		void impl_buildTree		( const Reference< XDesktop >& xDesktop );
128*b1cdbd2cSJim Jagielski 		void impl_logTree		( const Reference< XDesktop >& xDesktop );
129*b1cdbd2cSJim Jagielski 
130*b1cdbd2cSJim Jagielski 		#endif
131*b1cdbd2cSJim Jagielski 
132*b1cdbd2cSJim Jagielski 		#ifdef TEST_PLUGIN
133*b1cdbd2cSJim Jagielski 		void impl_testPlugIn	( const Reference< XDesktop >& xDesktop, const Reference< XMultiServiceFactory >& xFactory	);
134*b1cdbd2cSJim Jagielski 		#endif
135*b1cdbd2cSJim Jagielski 
136*b1cdbd2cSJim Jagielski 		#ifdef TEST_LOGINDIALOG
137*b1cdbd2cSJim Jagielski 		void impl_testLoginDialog();
138*b1cdbd2cSJim Jagielski 		#endif
139*b1cdbd2cSJim Jagielski 
140*b1cdbd2cSJim Jagielski 		#ifdef TEST_FILTERCACHE
141*b1cdbd2cSJim Jagielski 		void impl_testFilterCache();
142*b1cdbd2cSJim Jagielski 		#endif
143*b1cdbd2cSJim Jagielski 
144*b1cdbd2cSJim Jagielski 		#ifdef TEST_TYPEDETECTION
145*b1cdbd2cSJim Jagielski 		void impl_testTypeDetection();
146*b1cdbd2cSJim Jagielski 		#endif
147*b1cdbd2cSJim Jagielski 
148*b1cdbd2cSJim Jagielski 		#ifdef TEST_FILTERREGISTRATION
149*b1cdbd2cSJim Jagielski 		void impl_testFilterRegistration();
150*b1cdbd2cSJim Jagielski 		#endif
151*b1cdbd2cSJim Jagielski 
152*b1cdbd2cSJim Jagielski 		#ifdef TEST_TREESEARCH
153*b1cdbd2cSJim Jagielski 		sal_Bool impl_testTreeSearch();
154*b1cdbd2cSJim Jagielski 		#endif
155*b1cdbd2cSJim Jagielski 
156*b1cdbd2cSJim Jagielski 	//*************************************************************************************************************
157*b1cdbd2cSJim Jagielski 	private:
158*b1cdbd2cSJim Jagielski 
159*b1cdbd2cSJim Jagielski 	//*************************************************************************************************************
160*b1cdbd2cSJim Jagielski 	private:
161*b1cdbd2cSJim Jagielski 
162*b1cdbd2cSJim Jagielski 		Reference< XMultiServiceFactory >	m_xFactory;
163*b1cdbd2cSJim Jagielski 
164*b1cdbd2cSJim Jagielski };	//	class TestApplication
165*b1cdbd2cSJim Jagielski 
166*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
167*b1cdbd2cSJim Jagielski //	global variables
168*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
169*b1cdbd2cSJim Jagielski 
170*b1cdbd2cSJim Jagielski TestApplication	aTestApplication ;
171*b1cdbd2cSJim Jagielski 
172*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
173*b1cdbd2cSJim Jagielski //	main
174*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
175*b1cdbd2cSJim Jagielski 
Main()176*b1cdbd2cSJim Jagielski void TestApplication::Main()
177*b1cdbd2cSJim Jagielski {
178*b1cdbd2cSJim Jagielski //	RegistryCache aCache;
179*b1cdbd2cSJim Jagielski 
180*b1cdbd2cSJim Jagielski 	/**-***********************************************************************************************************
181*b1cdbd2cSJim Jagielski 		initialize program
182*b1cdbd2cSJim Jagielski 	**************************************************************************************************************/
183*b1cdbd2cSJim Jagielski 
184*b1cdbd2cSJim Jagielski 	// Init global servicemanager and set it.
185*b1cdbd2cSJim Jagielski 	ServiceManager aManager;
186*b1cdbd2cSJim Jagielski 	m_xFactory = aManager.getGlobalUNOServiceManager();
187*b1cdbd2cSJim Jagielski 	setProcessServiceFactory( m_xFactory );
188*b1cdbd2cSJim Jagielski 
189*b1cdbd2cSJim Jagielski 	// Control sucess of operation.
190*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(m_xFactory.is()			==sal_False	), "TestApplication::Main()\nCan't create global service manager.\n\n"			)
191*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(getProcessServiceFactory()!=m_xFactory), "TestApplication::Main()\nGlobal servicemanager not set in UNOTOOLS.\n\n"	)
192*b1cdbd2cSJim Jagielski 
193*b1cdbd2cSJim Jagielski 	/**-***********************************************************************************************************
194*b1cdbd2cSJim Jagielski 		test area
195*b1cdbd2cSJim Jagielski 	**************************************************************************************************************/
196*b1cdbd2cSJim Jagielski 
197*b1cdbd2cSJim Jagielski 	sal_Bool bState = sal_True;
198*b1cdbd2cSJim Jagielski 
199*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
200*b1cdbd2cSJim Jagielski 	#ifdef TEST_FILTERCACHE
201*b1cdbd2cSJim Jagielski 	impl_testFilterCache();
202*b1cdbd2cSJim Jagielski 	#endif
203*b1cdbd2cSJim Jagielski 
204*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
205*b1cdbd2cSJim Jagielski 	#ifdef TEST_TYPEDETECTION
206*b1cdbd2cSJim Jagielski 	impl_testTypeDetection();
207*b1cdbd2cSJim Jagielski 	#endif
208*b1cdbd2cSJim Jagielski 
209*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
210*b1cdbd2cSJim Jagielski 	#ifdef TEST_LOGINDIALOG
211*b1cdbd2cSJim Jagielski 	ResMgr* pRessourceManager = CREATEVERSIONRESMGR( lgd );
212*b1cdbd2cSJim Jagielski 	Resource::SetResManager( pRessourceManager );
213*b1cdbd2cSJim Jagielski 	impl_testLoginDialog();
214*b1cdbd2cSJim Jagielski 	#endif
215*b1cdbd2cSJim Jagielski 
216*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
217*b1cdbd2cSJim Jagielski 	#ifdef TEST_DESKTOP
218*b1cdbd2cSJim Jagielski 	Reference< XDesktop > xDesktop( xGlobalServiceManager->createInstance( SERVICENAME_DESKTOP ), UNO_QUERY );
219*b1cdbd2cSJim Jagielski 	impl_testDesktop( xDesktop );
220*b1cdbd2cSJim Jagielski 	#endif
221*b1cdbd2cSJim Jagielski 
222*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
223*b1cdbd2cSJim Jagielski 	#ifdef TEST_PLUGIN
224*b1cdbd2cSJim Jagielski 	impl_testPlugIn( xDesktop, xGlobalServiceManager );
225*b1cdbd2cSJim Jagielski 	#endif
226*b1cdbd2cSJim Jagielski 
227*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
228*b1cdbd2cSJim Jagielski 	#ifdef TEST_FILTERREGISTRATION
229*b1cdbd2cSJim Jagielski 	impl_testFilterRegistration();
230*b1cdbd2cSJim Jagielski 	#endif
231*b1cdbd2cSJim Jagielski 
232*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
233*b1cdbd2cSJim Jagielski 	#ifdef TEST_TREESEARCH
234*b1cdbd2cSJim Jagielski 	bState = impl_testTreeSearch();
235*b1cdbd2cSJim Jagielski 	#endif
236*b1cdbd2cSJim Jagielski 
237*b1cdbd2cSJim Jagielski //	Execute();
238*b1cdbd2cSJim Jagielski //    xFrame->dispose();
239*b1cdbd2cSJim Jagielski //    delete pMainWindow;
240*b1cdbd2cSJim Jagielski 	if( bState = sal_True )
241*b1cdbd2cSJim Jagielski 	{
242*b1cdbd2cSJim Jagielski 		LOG_ERROR( "TestApplication::Main()", "Test successful ..." )
243*b1cdbd2cSJim Jagielski 	}
244*b1cdbd2cSJim Jagielski 	else
245*b1cdbd2cSJim Jagielski 	{
246*b1cdbd2cSJim Jagielski 		LOG_ERROR( "TestApplication::Main()", "Test failed ..." )
247*b1cdbd2cSJim Jagielski 	}
248*b1cdbd2cSJim Jagielski }
249*b1cdbd2cSJim Jagielski 
250*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
251*b1cdbd2cSJim Jagielski //	test method
252*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
253*b1cdbd2cSJim Jagielski #ifdef TEST_TYPEDETECTION
impl_testTypeDetection()254*b1cdbd2cSJim Jagielski void TestApplication::impl_testTypeDetection()
255*b1cdbd2cSJim Jagielski {
256*b1cdbd2cSJim Jagielski 	// We use a string buffer to log important informations and search results.
257*b1cdbd2cSJim Jagielski 	// Errors are shown directly by an assert!
258*b1cdbd2cSJim Jagielski 	OUStringBuffer sBuffer( 100000 );
259*b1cdbd2cSJim Jagielski 
260*b1cdbd2cSJim Jagielski 	// Create a new type detection service.
261*b1cdbd2cSJim Jagielski 	Reference< XTypeDetection > xTypeDetection( getProcessServiceFactory()->createInstance( SERVICENAME_TYPEDETECTION ), UNO_QUERY );
262*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xTypeDetection.is()==sal_False), "TestApplication::impl_testTypeDetection()\nCouldn't create the type detection service.\n" );
263*b1cdbd2cSJim Jagielski 
264*b1cdbd2cSJim Jagielski 	if( xTypeDetection.is() == sal_True )
265*b1cdbd2cSJim Jagielski 	{
266*b1cdbd2cSJim Jagielski 		// a) Check his implementation and his supported interfaces first.
267*b1cdbd2cSJim Jagielski 		Reference< XInterface >		xInterface		( xTypeDetection, UNO_QUERY );
268*b1cdbd2cSJim Jagielski 		Reference< XTypeProvider >	xTypeProvider	( xTypeDetection, UNO_QUERY );
269*b1cdbd2cSJim Jagielski 		Reference< XServiceInfo >	xServiceInfo	( xTypeDetection, UNO_QUERY );
270*b1cdbd2cSJim Jagielski 		Reference< XNameAccess >	xNameAccess		( xTypeDetection, UNO_QUERY );
271*b1cdbd2cSJim Jagielski 		Reference< XElementAccess >	xElementAccess	( xTypeDetection, UNO_QUERY );
272*b1cdbd2cSJim Jagielski 
273*b1cdbd2cSJim Jagielski 		LOG_ASSERT( !(	xInterface.is()		==	sal_False	||
274*b1cdbd2cSJim Jagielski 						xTypeProvider.is()	==	sal_False	||
275*b1cdbd2cSJim Jagielski 						xServiceInfo.is()	==	sal_False	||
276*b1cdbd2cSJim Jagielski 						xNameAccess.is()	==	sal_False	||
277*b1cdbd2cSJim Jagielski 						xElementAccess.is()	==	sal_False	), "TestApplication::impl_testTypeDetection()\nMiss supported for searched interface!\n" )
278*b1cdbd2cSJim Jagielski 
279*b1cdbd2cSJim Jagielski 		// b) Check OneInstance mode of service.
280*b1cdbd2cSJim Jagielski 		Reference< XTypeDetection > xTypeDetection2( getProcessServiceFactory()->createInstance( SERVICENAME_TYPEDETECTION ), UNO_QUERY );
281*b1cdbd2cSJim Jagielski 		LOG_ASSERT( !(xTypeDetection!=xTypeDetection2), "TestApplication::impl_testTypeDetection()\nService isn't \"OneInstance\" ...!\n" )
282*b1cdbd2cSJim Jagielski 		xTypeDetection2 = Reference< XTypeDetection >();
283*b1cdbd2cSJim Jagielski 
284*b1cdbd2cSJim Jagielski 		// c) Check "XTypeDetection" ... flat by URL
285*b1cdbd2cSJim Jagielski 		// Define list of URLs for checking.
286*b1cdbd2cSJim Jagielski 		OUString pURLs[] =
287*b1cdbd2cSJim Jagielski 		{
288*b1cdbd2cSJim Jagielski 			DECLARE_ASCII("file://c|/temp/test.sdw"	),
289*b1cdbd2cSJim Jagielski 			DECLARE_ASCII("private:factory/scalc"	),
290*b1cdbd2cSJim Jagielski 			DECLARE_ASCII("file://c|/temp/test.txt"	),
291*b1cdbd2cSJim Jagielski 			DECLARE_ASCII("slot:5000"				),
292*b1cdbd2cSJim Jagielski 		};
293*b1cdbd2cSJim Jagielski 		sal_uInt32 nCount = 4;
294*b1cdbd2cSJim Jagielski 		Sequence< OUString > seqURLs( pURLs, nCount );
295*b1cdbd2cSJim Jagielski 
296*b1cdbd2cSJim Jagielski 		Reference< XMultiServiceFactory > xFilterFactory( getProcessServiceFactory()->createInstance( SERVICENAME_FILTERFACTORY		), UNO_QUERY );
297*b1cdbd2cSJim Jagielski 		Reference< XMultiServiceFactory > xLoaderFactory( getProcessServiceFactory()->createInstance( SERVICENAME_FRAMELOADERFACTORY), UNO_QUERY );
298*b1cdbd2cSJim Jagielski 		LOG_ASSERT( !(xFilterFactory.is()==sal_False), "TestApplication::impl_testTypeDetection()\nCouldn't create filter factory!\n" )
299*b1cdbd2cSJim Jagielski 		LOG_ASSERT( !(xLoaderFactory.is()==sal_False), "TestApplication::impl_testTypeDetection()\nCouldn't create loader factory!\n" )
300*b1cdbd2cSJim Jagielski 
301*b1cdbd2cSJim Jagielski 		// Step over these list.
302*b1cdbd2cSJim Jagielski 		for( sal_uInt32 nURL=0; nURL<nCount; ++nURL )
303*b1cdbd2cSJim Jagielski 		{
304*b1cdbd2cSJim Jagielski 			// Try to get a type name for every URL from list and log search result.
305*b1cdbd2cSJim Jagielski 			OUString sTypeName = xTypeDetection->queryTypeByURL( seqURLs[nURL] );
306*b1cdbd2cSJim Jagielski 			sBuffer.appendAscii	( "queryTypeByURL( \""		);
307*b1cdbd2cSJim Jagielski 			sBuffer.append		( seqURLs[nURL]				);
308*b1cdbd2cSJim Jagielski 			sBuffer.appendAscii	( "\" ) returns type \""	);
309*b1cdbd2cSJim Jagielski 			sBuffer.append		( sTypeName					);
310*b1cdbd2cSJim Jagielski 			sBuffer.appendAscii	( "\"\n"					);
311*b1cdbd2cSJim Jagielski 			// If a type was found - try to get a filter and a frame loader for it.
312*b1cdbd2cSJim Jagielski 			if( sTypeName.getLength() > 0 )
313*b1cdbd2cSJim Jagielski 			{
314*b1cdbd2cSJim Jagielski 				Reference< XInterface > xFilter = xFilterFactory->createInstance( sTypeName );
315*b1cdbd2cSJim Jagielski 				Reference< XInterface > xLoader = xLoaderFactory->createInstance( sTypeName );
316*b1cdbd2cSJim Jagielski 				if( xFilter.is() == sal_False )
317*b1cdbd2cSJim Jagielski 				{
318*b1cdbd2cSJim Jagielski 					sBuffer.appendAscii( "Couldn't find an filter.\n" );
319*b1cdbd2cSJim Jagielski 				}
320*b1cdbd2cSJim Jagielski 				else
321*b1cdbd2cSJim Jagielski 				{
322*b1cdbd2cSJim Jagielski 					Reference< XPropertySet > xFilterProperties( xFilter, UNO_QUERY );
323*b1cdbd2cSJim Jagielski 					LOG_ASSERT( !(xFilterProperties.is()==sal_False), "TestApplication::impl_testTypeDetection()\nFilter don't support XPropertySet!\n" )
324*b1cdbd2cSJim Jagielski 					if( xFilterProperties.is() == sal_True )
325*b1cdbd2cSJim Jagielski 					{
326*b1cdbd2cSJim Jagielski 						OUString sUIName;
327*b1cdbd2cSJim Jagielski 						xFilterProperties->getPropertyValue( DECLARE_ASCII("UIName") ) >>= sUIName;
328*b1cdbd2cSJim Jagielski 						sBuffer.appendAscii	( "Found filter \""	);
329*b1cdbd2cSJim Jagielski 						sBuffer.append		( sUIName			);
330*b1cdbd2cSJim Jagielski 						sBuffer.appendAscii	( "\"\n"			);
331*b1cdbd2cSJim Jagielski 					}
332*b1cdbd2cSJim Jagielski 
333*b1cdbd2cSJim Jagielski 					Reference< XPropertySet > xLoaderProperties( xLoader, UNO_QUERY );
334*b1cdbd2cSJim Jagielski 					LOG_ASSERT( !(xLoaderProperties.is()==sal_False), "TestApplication::impl_testTypeDetection()\nLoader don't support XPropertySet!\n" )
335*b1cdbd2cSJim Jagielski 					if( xLoaderProperties.is() == sal_True )
336*b1cdbd2cSJim Jagielski 					{
337*b1cdbd2cSJim Jagielski 						OUString sUIName;
338*b1cdbd2cSJim Jagielski 						xLoaderProperties->getPropertyValue( DECLARE_ASCII("UIName") ) >>= sUIName;
339*b1cdbd2cSJim Jagielski 						sBuffer.appendAscii	( "Found loader \""	);
340*b1cdbd2cSJim Jagielski 						sBuffer.append		( sUIName			);
341*b1cdbd2cSJim Jagielski 						sBuffer.appendAscii	( "\"\n"			);
342*b1cdbd2cSJim Jagielski 					}
343*b1cdbd2cSJim Jagielski 				}
344*b1cdbd2cSJim Jagielski 			}
345*b1cdbd2cSJim Jagielski 		}
346*b1cdbd2cSJim Jagielski 	}
347*b1cdbd2cSJim Jagielski 
348*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( "testTypeDetection.log", U2B(sBuffer.makeStringAndClear()) )
349*b1cdbd2cSJim Jagielski }
350*b1cdbd2cSJim Jagielski #endif
351*b1cdbd2cSJim Jagielski 
352*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
353*b1cdbd2cSJim Jagielski //	test method
354*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
355*b1cdbd2cSJim Jagielski #ifdef TEST_FILTERCACHE
impl_testFilterCache()356*b1cdbd2cSJim Jagielski void TestApplication::impl_testFilterCache()
357*b1cdbd2cSJim Jagielski {
358*b1cdbd2cSJim Jagielski 	FilterCache aCache;
359*b1cdbd2cSJim Jagielski 
360*b1cdbd2cSJim Jagielski 	OUStringBuffer sBuffer( 100000 );
361*b1cdbd2cSJim Jagielski 	if( aCache.isValid() == sal_False )
362*b1cdbd2cSJim Jagielski 	{
363*b1cdbd2cSJim Jagielski 		sBuffer.appendAscii( "Cache isn't valid!\n" );
364*b1cdbd2cSJim Jagielski 	}
365*b1cdbd2cSJim Jagielski 	else
366*b1cdbd2cSJim Jagielski 	{
367*b1cdbd2cSJim Jagielski /*
368*b1cdbd2cSJim Jagielski 		// Step over all types and log his values.
369*b1cdbd2cSJim Jagielski 		// These simulate a XNameAccess!
370*b1cdbd2cSJim Jagielski 		const Sequence< OUString > seqAllTypeNames = aCache.getAllTypeNames();
371*b1cdbd2cSJim Jagielski 		sal_uInt32 nCount = seqAllTypeNames.getLength();
372*b1cdbd2cSJim Jagielski 		for( sal_uInt32 nPosition=0; nPosition<nCount; ++nPosition )
373*b1cdbd2cSJim Jagielski 		{
374*b1cdbd2cSJim Jagielski 			sBuffer.appendAscii( "--------------------------------------------------------------------------------\n" );
375*b1cdbd2cSJim Jagielski 			const TType* pType = aCache.getTypeByName( seqAllTypeNames[nPosition] );
376*b1cdbd2cSJim Jagielski 			if( pType == NULL )
377*b1cdbd2cSJim Jagielski 			{
378*b1cdbd2cSJim Jagielski 				sBuffer.appendAscii	( "Type ["					);
379*b1cdbd2cSJim Jagielski 				sBuffer.append		( (sal_Int32)nPosition		);
380*b1cdbd2cSJim Jagielski 				sBuffer.appendAscii	( "] \""					);
381*b1cdbd2cSJim Jagielski 				sBuffer.append		( seqAllTypeNames[nPosition]);
382*b1cdbd2cSJim Jagielski 				sBuffer.appendAscii	( "\" isn't valid!"			);
383*b1cdbd2cSJim Jagielski 			}
384*b1cdbd2cSJim Jagielski 			else
385*b1cdbd2cSJim Jagielski 			{
386*b1cdbd2cSJim Jagielski 				sBuffer.appendAscii	( "Type ["						);
387*b1cdbd2cSJim Jagielski 				sBuffer.append		( (sal_Int32)nPosition			);
388*b1cdbd2cSJim Jagielski 				sBuffer.appendAscii	( "] \""						);
389*b1cdbd2cSJim Jagielski 				sBuffer.append		( seqAllTypeNames[nPosition]	);
390*b1cdbd2cSJim Jagielski 				sBuffer.appendAscii	( "\"\n\t\tUIName\t=\t"			);
391*b1cdbd2cSJim Jagielski 				sBuffer.append		( pType->sUIName				);
392*b1cdbd2cSJim Jagielski 				sBuffer.appendAscii	( "\n\t\tMediaType\t=\t"		);
393*b1cdbd2cSJim Jagielski 				sBuffer.append		( pType->sMediaType				);
394*b1cdbd2cSJim Jagielski 				sBuffer.appendAscii	( "\n\t\tClipboardFormat\t=\t"	);
395*b1cdbd2cSJim Jagielski 				sBuffer.append		( pType->sClipboardFormat		);
396*b1cdbd2cSJim Jagielski 				sBuffer.appendAscii	( "\n\t\tURLPattern\t=\t{"		);
397*b1cdbd2cSJim Jagielski 				for( TConstStringIterator aIterator=pType->lURLPattern.begin(); aIterator!=pType->lURLPattern.end(); ++aIterator )
398*b1cdbd2cSJim Jagielski 				{
399*b1cdbd2cSJim Jagielski 					sBuffer.append		( *aIterator	);
400*b1cdbd2cSJim Jagielski 					sBuffer.appendAscii	( ";\n\t\t"		);
401*b1cdbd2cSJim Jagielski 				}
402*b1cdbd2cSJim Jagielski 				sBuffer.appendAscii( "}\nExtensions\t=\t" );
403*b1cdbd2cSJim Jagielski 				for( aIterator=pType->lExtensions.begin(); aIterator!=pType->lExtensions.end(); ++aIterator )
404*b1cdbd2cSJim Jagielski 				{
405*b1cdbd2cSJim Jagielski 					sBuffer.append		( *aIterator	);
406*b1cdbd2cSJim Jagielski 					sBuffer.appendAscii	( ";\n\t\t"		);
407*b1cdbd2cSJim Jagielski 				}
408*b1cdbd2cSJim Jagielski 				sBuffer.appendAscii	( "}\nDocumentIconID\t=\t" 			);
409*b1cdbd2cSJim Jagielski 				sBuffer.append		( (sal_Int32)pType->nDocumentIconID	);
410*b1cdbd2cSJim Jagielski 			}
411*b1cdbd2cSJim Jagielski 		}
412*b1cdbd2cSJim Jagielski */
413*b1cdbd2cSJim Jagielski 		// searchFirstType( URL, MediaType, ClipboardFormat, startEntry )
414*b1cdbd2cSJim Jagielski 		TCheckedTypeIterator aIterator;
415*b1cdbd2cSJim Jagielski 		sBuffer.appendAscii( "search type for \"file://c|/temp/test.sdw\"; no media type; no clipboard format\n" );
416*b1cdbd2cSJim Jagielski 		OUString sURL = DECLARE_ASCII("file://c|/temp/test.sdw");
417*b1cdbd2cSJim Jagielski 		const OUString* pType = aCache.searchFirstType( &sURL, NULL, NULL, aIterator );
418*b1cdbd2cSJim Jagielski 		while( pType != NULL )
419*b1cdbd2cSJim Jagielski 		{
420*b1cdbd2cSJim Jagielski 			sBuffer.appendAscii	( "\tfound \""	);
421*b1cdbd2cSJim Jagielski 			sBuffer.append		( *pType		);
422*b1cdbd2cSJim Jagielski 			sBuffer.appendAscii	( "\"\n"		);
423*b1cdbd2cSJim Jagielski 			pType = aCache.searchType( &sURL, NULL, NULL, aIterator );
424*b1cdbd2cSJim Jagielski 		}
425*b1cdbd2cSJim Jagielski 	}
426*b1cdbd2cSJim Jagielski 
427*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( "test_FilterCache.log", U2B(sBuffer.makeStringAndClear()) )
428*b1cdbd2cSJim Jagielski }
429*b1cdbd2cSJim Jagielski #endif
430*b1cdbd2cSJim Jagielski 
431*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
432*b1cdbd2cSJim Jagielski //	test method
433*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
434*b1cdbd2cSJim Jagielski #ifdef TEST_LOGINDIALOG
impl_testLoginDialog()435*b1cdbd2cSJim Jagielski void TestApplication::impl_testLoginDialog()
436*b1cdbd2cSJim Jagielski {
437*b1cdbd2cSJim Jagielski 	// Get global servicemanager to create service "LoginDialog".
438*b1cdbd2cSJim Jagielski 	Reference< XMultiServiceFactory > xFactory = getProcessServiceFactory();
439*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xFactory.is()==sal_False), "TestApplication::impl_testLoginDialog()\nServicemanager not valid.\n" )
440*b1cdbd2cSJim Jagielski 	// Create LoginDialog.
441*b1cdbd2cSJim Jagielski 	Reference< XDialog > xDialog( xFactory->createInstance( DECLARE_ASCII("com.sun.star.framework.LoginDialog") ), UNO_QUERY );
442*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDialog.is()==sal_False), "TestApplication::impl_testLoginDialog()\nCould not create login dialog.\n" )
443*b1cdbd2cSJim Jagielski 	// Check set/getTitle()
444*b1cdbd2cSJim Jagielski 	/* not implemented yet! */
445*b1cdbd2cSJim Jagielski //	OUString sTitle = DECLARE_ASCII("Login Dialog Test");
446*b1cdbd2cSJim Jagielski //	xDialog->setTitle( sTitle );
447*b1cdbd2cSJim Jagielski //	LOG_ASSERT( !(xDialog->getTitle()!=sTitle), "TestApplication::impl_testLoginDialog()\nset/getTitle don't work correct.\n" )
448*b1cdbd2cSJim Jagielski 
449*b1cdbd2cSJim Jagielski 	UniString sInternalURL = DECLARE_ASCII("private:factory/scalc");
450*b1cdbd2cSJim Jagielski 	UniString sExternalURL = OUString();
451*b1cdbd2cSJim Jagielski 
452*b1cdbd2cSJim Jagielski 	OString sOut = "internal: ";
453*b1cdbd2cSJim Jagielski 	sOut += OUStringToOString( sInternalURL, RTL_TEXTENCODING_UTF8 );
454*b1cdbd2cSJim Jagielski 	sOut += "\nexternal: ";
455*b1cdbd2cSJim Jagielski 	sOut += OUStringToOString( sExternalURL, RTL_TEXTENCODING_UTF8 );
456*b1cdbd2cSJim Jagielski 	sOut += "\n";
457*b1cdbd2cSJim Jagielski 	LOG_ASSERT( sal_False, sOut )
458*b1cdbd2cSJim Jagielski 
459*b1cdbd2cSJim Jagielski 	INetURLObject::translateToExternal( sInternalURL, sExternalURL );
460*b1cdbd2cSJim Jagielski 	sOut = "internal: ";
461*b1cdbd2cSJim Jagielski 	sOut += OUStringToOString( sInternalURL, RTL_TEXTENCODING_UTF8 );
462*b1cdbd2cSJim Jagielski 	sOut += "\nexternal: ";
463*b1cdbd2cSJim Jagielski 	sOut += OUStringToOString( sExternalURL, RTL_TEXTENCODING_UTF8 );
464*b1cdbd2cSJim Jagielski 	sOut += "\n";
465*b1cdbd2cSJim Jagielski 	LOG_ASSERT( sal_False, sOut )
466*b1cdbd2cSJim Jagielski 
467*b1cdbd2cSJim Jagielski 	INetURLObject::translateToInternal( sExternalURL, sInternalURL );
468*b1cdbd2cSJim Jagielski 	sOut = "internal: ";
469*b1cdbd2cSJim Jagielski 	sOut += OUStringToOString( sInternalURL, RTL_TEXTENCODING_UTF8 );
470*b1cdbd2cSJim Jagielski 	sOut += "\nexternal: ";
471*b1cdbd2cSJim Jagielski 	sOut += OUStringToOString( sExternalURL, RTL_TEXTENCODING_UTF8 );
472*b1cdbd2cSJim Jagielski 	sOut += "\n";
473*b1cdbd2cSJim Jagielski 	LOG_ASSERT( sal_False, sOut )
474*b1cdbd2cSJim Jagielski 
475*b1cdbd2cSJim Jagielski 	// Work with properties of dialog.
476*b1cdbd2cSJim Jagielski 	Reference< XPropertySet > xPropertySet( xDialog, UNO_QUERY );
477*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xPropertySet.is()==sal_False), "TestApplication::impl_testLoginDialog()\nCan't cast dialog to XPropertySet interface.\n" )
478*b1cdbd2cSJim Jagielski 	Any aUserName 		;
479*b1cdbd2cSJim Jagielski 	Any aPassword 		;
480*b1cdbd2cSJim Jagielski 	Any aServer   		;
481*b1cdbd2cSJim Jagielski 	Any aConnectionType	;
482*b1cdbd2cSJim Jagielski 	Any aPort			;
483*b1cdbd2cSJim Jagielski 	aUserName 		<<= DECLARE_ASCII("Andreas");
484*b1cdbd2cSJim Jagielski 	aPassword 		<<= DECLARE_ASCII("Test");
485*b1cdbd2cSJim Jagielski 	aServer   		<<= DECLARE_ASCII("www.yahoo.de:7777");
486*b1cdbd2cSJim Jagielski 	aConnectionType	<<= DECLARE_ASCII("Bla");
487*b1cdbd2cSJim Jagielski 	sal_Int32 nPort = 8081;
488*b1cdbd2cSJim Jagielski 	aPort			<<= nPort;
489*b1cdbd2cSJim Jagielski 	try
490*b1cdbd2cSJim Jagielski 	{
491*b1cdbd2cSJim Jagielski 	xPropertySet->setPropertyValue( DECLARE_ASCII("UserName"			), aUserName 		);
492*b1cdbd2cSJim Jagielski 	xPropertySet->setPropertyValue( DECLARE_ASCII("Password"			), aPassword 		);
493*b1cdbd2cSJim Jagielski 	xPropertySet->setPropertyValue( DECLARE_ASCII("Server"  			), aServer   		);
494*b1cdbd2cSJim Jagielski 	xPropertySet->setPropertyValue( DECLARE_ASCII("ConnectionType"	), aConnectionType	);
495*b1cdbd2cSJim Jagielski 	xPropertySet->setPropertyValue( DECLARE_ASCII("Compressed"		), aPort			);
496*b1cdbd2cSJim Jagielski 	}
497*b1cdbd2cSJim Jagielski 	catch( ::com::sun::star::beans::UnknownPropertyException& )
498*b1cdbd2cSJim Jagielski 	{
499*b1cdbd2cSJim Jagielski 		LOG_ASSERT( sal_False, "UnkownPropertyException detected!\n" )
500*b1cdbd2cSJim Jagielski 	}
501*b1cdbd2cSJim Jagielski 	catch( ::com::sun::star::beans::PropertyVetoException& )
502*b1cdbd2cSJim Jagielski 	{
503*b1cdbd2cSJim Jagielski 		LOG_ASSERT( sal_False, "PropertyVetoException detected!\n" )
504*b1cdbd2cSJim Jagielski 	}
505*b1cdbd2cSJim Jagielski 	catch( ::com::sun::star::lang::IllegalArgumentException& )
506*b1cdbd2cSJim Jagielski 	{
507*b1cdbd2cSJim Jagielski 		LOG_ASSERT( sal_False, "IllegalArgumentException detected!\n" )
508*b1cdbd2cSJim Jagielski 	}
509*b1cdbd2cSJim Jagielski 	catch( ::com::sun::star::lang::WrappedTargetException& )
510*b1cdbd2cSJim Jagielski 	{
511*b1cdbd2cSJim Jagielski 		LOG_ASSERT( sal_False, "WrappedTargetException detected!\n" )
512*b1cdbd2cSJim Jagielski 	}
513*b1cdbd2cSJim Jagielski 	catch( ::com::sun::star::uno::RuntimeException& )
514*b1cdbd2cSJim Jagielski 	{
515*b1cdbd2cSJim Jagielski 		LOG_ASSERT( sal_False, "RuntimeException detected!\n" )
516*b1cdbd2cSJim Jagielski 	}
517*b1cdbd2cSJim Jagielski 
518*b1cdbd2cSJim Jagielski 	xDialog->execute();
519*b1cdbd2cSJim Jagielski 
520*b1cdbd2cSJim Jagielski 	OUString sUserName			;
521*b1cdbd2cSJim Jagielski 	OUString sPassword			;
522*b1cdbd2cSJim Jagielski 	OUString sServer  			;
523*b1cdbd2cSJim Jagielski 	OUString sConnectionType	;
524*b1cdbd2cSJim Jagielski 	xPropertySet->getPropertyValue( DECLARE_ASCII("UserName"			) ) >>= sUserName 		;
525*b1cdbd2cSJim Jagielski 	xPropertySet->getPropertyValue( DECLARE_ASCII("Password"			) ) >>= sPassword 		;
526*b1cdbd2cSJim Jagielski 	xPropertySet->getPropertyValue( DECLARE_ASCII("Server"  			) ) >>= sServer   		;
527*b1cdbd2cSJim Jagielski 	xPropertySet->getPropertyValue( DECLARE_ASCII("ConnectionType"	) ) >>= sConnectionType	;
528*b1cdbd2cSJim Jagielski 	xPropertySet->getPropertyValue( sConnectionType ) >>= nPort	;
529*b1cdbd2cSJim Jagielski 
530*b1cdbd2cSJim Jagielski 	LOG_ASSERT( sal_False, OUStringToOString( sUserName, RTL_TEXTENCODING_UTF8 ) )
531*b1cdbd2cSJim Jagielski 	LOG_ASSERT( sal_False, OUStringToOString( sPassword, RTL_TEXTENCODING_UTF8 ) )
532*b1cdbd2cSJim Jagielski 	LOG_ASSERT( sal_False, OUStringToOString( sServer  , RTL_TEXTENCODING_UTF8 ) )
533*b1cdbd2cSJim Jagielski 	LOG_ASSERT( sal_False, OUStringToOString( sConnectionType  , RTL_TEXTENCODING_UTF8 ) )
534*b1cdbd2cSJim Jagielski 	LOG_ASSERT( sal_False, OString::valueOf( (sal_Int32)nPort ) )
535*b1cdbd2cSJim Jagielski }
536*b1cdbd2cSJim Jagielski #endif
537*b1cdbd2cSJim Jagielski 
538*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
539*b1cdbd2cSJim Jagielski //	test method
540*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
541*b1cdbd2cSJim Jagielski #ifdef TEST_PLUGIN
impl_testPlugIn(const Reference<XDesktop> & xDesktop,const Reference<XMultiServiceFactory> & xFactory)542*b1cdbd2cSJim Jagielski void TestApplication::impl_testPlugIn( const Reference< XDesktop >& xDesktop, const Reference< XMultiServiceFactory >& xFactory )
543*b1cdbd2cSJim Jagielski {
544*b1cdbd2cSJim Jagielski 	// create instance provider for creation of factories.
545*b1cdbd2cSJim Jagielski 	Reference< XInstanceProvider > xInstanceProvider( (OWeakObject*)(new OInstanceProvider( xFactory )), UNO_QUERY );
546*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xInstanceProvider.is()==sal_False), "TestApplication::impl_testPlugIn()\nCan't create new instance provider!\n" )
547*b1cdbd2cSJim Jagielski 
548*b1cdbd2cSJim Jagielski 	// try to get factory for create a plugin
549*b1cdbd2cSJim Jagielski 	Reference< XSingleServiceFactory > xPlugInFactory( xInstanceProvider->getInstance( INSTANCENAME_PLUGINFACTORY ), UNO_QUERY );
550*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xPlugInFactory.is()==sal_False), "TestApplication::impl_testPlugIn()\nCan't get PlugInFactory from instance provider!\n" )
551*b1cdbd2cSJim Jagielski 
552*b1cdbd2cSJim Jagielski 	// initialize parameter for creation of plugin
553*b1cdbd2cSJim Jagielski 	Reference< XPluginInstancePeer > xPlugInDLL =Reference< XPluginInstancePeer >();
554*b1cdbd2cSJim Jagielski 	Sequence< Any > seqArguments(1);
555*b1cdbd2cSJim Jagielski 	seqArguments[0] <<= xPlugInDLL;
556*b1cdbd2cSJim Jagielski 
557*b1cdbd2cSJim Jagielski 	// create plugin
558*b1cdbd2cSJim Jagielski 	Reference< XFrame > xPlugIn( xPlugInFactory->createInstanceWithArguments( seqArguments ), UNO_QUERY );
559*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xPlugIn.is()==sal_False), "TestApplication::impl_testPlugIn()\nFactory has created no valid plugin!\n" )
560*b1cdbd2cSJim Jagielski 
561*b1cdbd2cSJim Jagielski 	xPlugIn->setName( OUString(RTL_CONSTASCII_USTRINGPARAM("PlugIn")) );
562*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSupplier( xDesktop, UNO_QUERY );
563*b1cdbd2cSJim Jagielski 	xPlugIn->setCreator( xSupplier );
564*b1cdbd2cSJim Jagielski }
565*b1cdbd2cSJim Jagielski #endif
566*b1cdbd2cSJim Jagielski 
567*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
568*b1cdbd2cSJim Jagielski //	test method
569*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
570*b1cdbd2cSJim Jagielski #ifdef TEST_DESKTOP
571*b1cdbd2cSJim Jagielski #define LOGFILE_TARGETING "targeting.log"
impl_testDesktop(const Reference<XDesktop> & xDesktop)572*b1cdbd2cSJim Jagielski void TestApplication::impl_testDesktop( const Reference< XDesktop >& xDesktop )
573*b1cdbd2cSJim Jagielski {
574*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
575*b1cdbd2cSJim Jagielski 	//	1) Test cast to all supported interfaces of Desktop.
576*b1cdbd2cSJim Jagielski 
577*b1cdbd2cSJim Jagielski 	Reference< XInterface >					xDesktopInterface				( xDesktop, UNO_QUERY );
578*b1cdbd2cSJim Jagielski 	Reference< XTypeProvider >				xDesktopTypeProvider			( xDesktop, UNO_QUERY );
579*b1cdbd2cSJim Jagielski 	Reference< XServiceInfo >				xDesktopServiceInfo				( xDesktop, UNO_QUERY );
580*b1cdbd2cSJim Jagielski 	Reference< XComponentLoader >			xDesktopComponentLoader			( xDesktop, UNO_QUERY );
581*b1cdbd2cSJim Jagielski 	Reference< XTasksSupplier >				xDesktopTasksSupplier			( xDesktop, UNO_QUERY );
582*b1cdbd2cSJim Jagielski 	Reference< XDispatchProvider >			xDesktopDispatchProvider		( xDesktop, UNO_QUERY );
583*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier >			xDesktopFramesSupplier			( xDesktop, UNO_QUERY );
584*b1cdbd2cSJim Jagielski 	Reference< XFrame >						xDesktopFrame					( xDesktop, UNO_QUERY );
585*b1cdbd2cSJim Jagielski 	Reference< XComponent >					xDesktopComponent				( xDesktop, UNO_QUERY );
586*b1cdbd2cSJim Jagielski 	Reference< XStatusIndicatorFactory >	xDesktopStatusIndicatorFactory	( xDesktop, UNO_QUERY );
587*b1cdbd2cSJim Jagielski 	Reference< XPropertySet >				xDesktopPropertySet				( xDesktop, UNO_QUERY );
588*b1cdbd2cSJim Jagielski 	Reference< XFastPropertySet >			xDesktopFastPropertySet			( xDesktop, UNO_QUERY );
589*b1cdbd2cSJim Jagielski 	Reference< XMultiPropertySet >			xDesktopMultiPropertySet		( xDesktop, UNO_QUERY );
590*b1cdbd2cSJim Jagielski 
591*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopInterface.is()				==sal_False), "TestApplication::impl_testDesktop()\nXInterface not supported by Desktop.\n\n"				)
592*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopTypeProvider.is()				==sal_False), "TestApplication::impl_testDesktop()\nXTypeProvider not supported by Desktop.\n\n"			)
593*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopServiceInfo.is()				==sal_False), "TestApplication::impl_testDesktop()\nXServiceInfo not supported by Desktop.\n\n"				)
594*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktop.is()							==sal_False), "TestApplication::impl_testDesktop()\nXDesktop not supported by Desktop.\n\n"					)
595*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopComponentLoader.is()			==sal_False), "TestApplication::impl_testDesktop()\nXComponentLoader not supported by Desktop.\n\n"			)
596*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopTasksSupplier.is()			==sal_False), "TestApplication::impl_testDesktop()\nXTasksSupplier not supported by Desktop.\n\n"			)
597*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopDispatchProvider.is()			==sal_False), "TestApplication::impl_testDesktop()\nXDispatchProvider not supported by Desktop.\n\n"		)
598*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopFramesSupplier.is()			==sal_False), "TestApplication::impl_testDesktop()\nXFramesSupplier not supported by Desktop.\n\n"			)
599*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopFrame.is()					==sal_False), "TestApplication::impl_testDesktop()\nXFrame not supported by Desktop.\n\n"					)
600*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopComponent.is()				==sal_False), "TestApplication::impl_testDesktop()\nXComponent not supported by Desktop.\n\n"				)
601*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopStatusIndicatorFactory.is()	==sal_False), "TestApplication::impl_testDesktop()\nXStatusIndicatorFactory not supported by Desktop.\n\n"	)
602*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopPropertySet.is()				==sal_False), "TestApplication::impl_testDesktop()\nXPropertySet not supported by Desktop.\n\n"				)
603*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopFastPropertySet.is()			==sal_False), "TestApplication::impl_testDesktop()\nXFastPropertySet not supported by Desktop.\n\n"			)
604*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopMultiPropertySet.is()			==sal_False), "TestApplication::impl_testDesktop()\nXMultiPropertySet not supported by Desktop.\n\n"		)
605*b1cdbd2cSJim Jagielski 
606*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
607*b1cdbd2cSJim Jagielski 	//	2) Test set-/getName().
608*b1cdbd2cSJim Jagielski 
609*b1cdbd2cSJim Jagielski 	//	2a) Test default value "Desktop".
610*b1cdbd2cSJim Jagielski 	OUString sName( RTL_CONSTASCII_USTRINGPARAM("Desktop") );
611*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopFrame->getName()!=sName), "TestApplication::impl_testDesktop()\nDefault value of desktop name is invalid.\n\n" )
612*b1cdbd2cSJim Jagielski 
613*b1cdbd2cSJim Jagielski 	//	2b) Set name and try to get the same name.
614*b1cdbd2cSJim Jagielski 	sName = OUString( RTL_CONSTASCII_USTRINGPARAM("New Desktop") );
615*b1cdbd2cSJim Jagielski 	xDesktopFrame->setName( sName );
616*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xDesktopFrame->getName()!=sName), "TestApplication::impl_testDesktop()\nSetting of name works not correct on desktop.\n\n" )
617*b1cdbd2cSJim Jagielski 
618*b1cdbd2cSJim Jagielski 	//	Reset name do default!
619*b1cdbd2cSJim Jagielski 	//	Its neccessary for follow operations.
620*b1cdbd2cSJim Jagielski 	sName = OUString( RTL_CONSTASCII_USTRINGPARAM("Desktop") );
621*b1cdbd2cSJim Jagielski 	xDesktopFrame->setName( sName );
622*b1cdbd2cSJim Jagielski 
623*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
624*b1cdbd2cSJim Jagielski 	//	3) Test findFrame().
625*b1cdbd2cSJim Jagielski 
626*b1cdbd2cSJim Jagielski 	//	Build new example tree and log initial structure in file.
627*b1cdbd2cSJim Jagielski 	impl_buildTree	( xDesktop );
628*b1cdbd2cSJim Jagielski 	impl_logTree	( xDesktop );
629*b1cdbd2cSJim Jagielski 
630*b1cdbd2cSJim Jagielski 	OUString			sTargetFrameName;
631*b1cdbd2cSJim Jagielski 	sal_uInt32			nSearchFlags	;
632*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xSearchFrame	;
633*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xTask_4			;
634*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_41		;
635*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_411		;
636*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_112		;
637*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_1123		;
638*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_11231	;
639*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_11221	;
640*b1cdbd2cSJim Jagielski 
641*b1cdbd2cSJim Jagielski 	//	3a) Search for Desktop
642*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
643*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with SELF for \"Desktop\" on Desktop\n" )
644*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
645*b1cdbd2cSJim Jagielski 	sTargetFrameName	= OUString(RTL_CONSTASCII_USTRINGPARAM("Desktop"));
646*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::SELF;
647*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
648*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_False), "TestApplication::impl_testDesktop()\nSearch 3a)-1 invalid\n" );
649*b1cdbd2cSJim Jagielski 
650*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
651*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with ALL for \"Desktop\" on Desktop\n" )
652*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
653*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::ALL;
654*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
655*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_False), "TestApplication::impl_testDesktop()\nSearch 3a)-2 invalid\n" );
656*b1cdbd2cSJim Jagielski 
657*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
658*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with CHILDREN for \"Desktop\" on Desktop\n" )
659*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
660*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::CHILDREN;
661*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
662*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_True), "TestApplication::impl_testDesktop()\nSearch 3a)-3 invalid\n" );
663*b1cdbd2cSJim Jagielski 
664*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
665*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with SIBLINGS for \"Desktop\" on Desktop\n" )
666*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
667*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::SIBLINGS;
668*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
669*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_True), "TestApplication::impl_testDesktop()\nSearch 3a)-4 invalid\n" );
670*b1cdbd2cSJim Jagielski 
671*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
672*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with AUTO for \"Desktop\" on Desktop\n" )
673*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
674*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::AUTO;
675*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
676*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_True), "TestApplication::impl_testDesktop()\nSearch 3a)-5 invalid\n" );
677*b1cdbd2cSJim Jagielski 
678*b1cdbd2cSJim Jagielski 	//	3b) Search for Task_4
679*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
680*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with SELF for \"Task_4\" on Desktop\n" )
681*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
682*b1cdbd2cSJim Jagielski 	sTargetFrameName	= OUString(RTL_CONSTASCII_USTRINGPARAM("Task_4"));
683*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::SELF;
684*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
685*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_True), "TestApplication::impl_testDesktop()\nSearch 3b)-1 invalid\n" );
686*b1cdbd2cSJim Jagielski 
687*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
688*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with SIBLINGS for \"Task_4\" on Desktop\n" )
689*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
690*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::SIBLINGS;
691*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
692*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_True), "TestApplication::impl_testDesktop()\nSearch 3b)-2 invalid\n" );
693*b1cdbd2cSJim Jagielski 
694*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
695*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with CHILDREN for \"Task_4\" on Desktop\n" )
696*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
697*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::CHILDREN;
698*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
699*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_False), "TestApplication::impl_testDesktop()\nSearch 3b)-3 invalid\n" );
700*b1cdbd2cSJim Jagielski 
701*b1cdbd2cSJim Jagielski 	xTask_4 = xSearchFrame;
702*b1cdbd2cSJim Jagielski 
703*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
704*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with ALL for \"Task_4\" on Desktop\n" )
705*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
706*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::ALL;
707*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
708*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_False), "TestApplication::impl_testDesktop()\nSearch 3b)-4 invalid\n" );
709*b1cdbd2cSJim Jagielski 
710*b1cdbd2cSJim Jagielski 	//	3c) Search for Frame_41
711*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
712*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with SELF for \"Frame_41\" on Desktop\n" )
713*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
714*b1cdbd2cSJim Jagielski 	sTargetFrameName	= OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_41"));
715*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::SELF;
716*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
717*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_True), "TestApplication::impl_testDesktop()\nSearch 3c)-1 invalid\n" );
718*b1cdbd2cSJim Jagielski 
719*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
720*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with SIBLINGS for \"Frame_41\" on Desktop\n" )
721*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
722*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::SIBLINGS;
723*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
724*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_True), "TestApplication::impl_testDesktop()\nSearch 3c)-2 invalid\n" );
725*b1cdbd2cSJim Jagielski 
726*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
727*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with CHILDREN for \"Frame_41\" on Desktop\n" )
728*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
729*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::CHILDREN;
730*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
731*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_False), "TestApplication::impl_testDesktop()\nSearch 3c)-3 invalid\n" );
732*b1cdbd2cSJim Jagielski 
733*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
734*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with ALL for \"Frame_41\" on Desktop\n" )
735*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
736*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::ALL;
737*b1cdbd2cSJim Jagielski 	xSearchFrame		= xDesktopFrame->findFrame(sTargetFrameName, nSearchFlags);
738*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_False), "TestApplication::impl_testDesktop()\nSearch 3c)-4 invalid\n" );
739*b1cdbd2cSJim Jagielski 
740*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
741*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with SELF for \"Frame_41\" on Task_4\n" )
742*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
743*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::SELF;
744*b1cdbd2cSJim Jagielski 	xSearchFrame		= xTask_4->findFrame(sTargetFrameName, nSearchFlags);
745*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_True), "TestApplication::impl_testDesktop()\nSearch 3c)-5 invalid\n" );
746*b1cdbd2cSJim Jagielski 
747*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
748*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with SIBLINGS for \"Frame_41\" on Task_4\n" )
749*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
750*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::SIBLINGS;
751*b1cdbd2cSJim Jagielski 	xSearchFrame		= xTask_4->findFrame(sTargetFrameName, nSearchFlags);
752*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_True), "TestApplication::impl_testDesktop()\nSearch 3c)-6 invalid\n" );
753*b1cdbd2cSJim Jagielski 
754*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
755*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with CHILDREN for \"Frame_41\" on Task_4\n" )
756*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
757*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::CHILDREN;
758*b1cdbd2cSJim Jagielski 	xSearchFrame		= xTask_4->findFrame(sTargetFrameName, nSearchFlags);
759*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_False), "TestApplication::impl_testDesktop()\nSearch 3c)-7 invalid\n" );
760*b1cdbd2cSJim Jagielski 
761*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
762*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, " Search with ALL for \"Frame_41\" on Task_4\n" )
763*b1cdbd2cSJim Jagielski 	WRITE_LOGFILE( LOGFILE_TARGETING, "--------------------------------------------------------------------------------\n" )
764*b1cdbd2cSJim Jagielski 	nSearchFlags		= FrameSearchFlag::ALL;
765*b1cdbd2cSJim Jagielski 	xSearchFrame		= xTask_4->findFrame(sTargetFrameName, nSearchFlags);
766*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xSearchFrame.is()==sal_False), "TestApplication::impl_testDesktop()\nSearch 3c)-8 invalid\n" );
767*b1cdbd2cSJim Jagielski 
768*b1cdbd2cSJim Jagielski 	xFrame_41 = xSearchFrame;
769*b1cdbd2cSJim Jagielski 
770*b1cdbd2cSJim Jagielski 	//	3d) Search for Frame_411
771*b1cdbd2cSJim Jagielski 	//	3e) Search for Frame_112
772*b1cdbd2cSJim Jagielski 	//	3f) Search for Frame_1123
773*b1cdbd2cSJim Jagielski 	//	3g) Search for Frame_11231
774*b1cdbd2cSJim Jagielski 	//	3h) Search for Frame_11221
775*b1cdbd2cSJim Jagielski }
776*b1cdbd2cSJim Jagielski 
777*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
778*b1cdbd2cSJim Jagielski //	helper method to build a new binaer-tree with desktop as top-frame
779*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
impl_buildTree(const Reference<XDesktop> & xDesktop)780*b1cdbd2cSJim Jagielski void TestApplication::impl_buildTree( const Reference< XDesktop >& xDesktop )
781*b1cdbd2cSJim Jagielski {
782*b1cdbd2cSJim Jagielski 	// You can append and remove frames only on XFRames interface of desktop.
783*b1cdbd2cSJim Jagielski 	// But the desktop support this interface not directly! Use getFrames() instantly.
784*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xDesktopSupplier( xDesktop, UNO_QUERY );
785*b1cdbd2cSJim Jagielski 	Reference< XFrames > xFrames = xDesktopSupplier->getFrames();
786*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xFrames.is()==sal_False), "TestApplication::impl_buildTree()\nCan't get framesaccess on desktop.\n\n" )
787*b1cdbd2cSJim Jagielski 
788*b1cdbd2cSJim Jagielski 	// Create some tasks and frames.
789*b1cdbd2cSJim Jagielski 	Reference< XMultiServiceFactory > xServiceManager( getProcessServiceFactory() );
790*b1cdbd2cSJim Jagielski 
791*b1cdbd2cSJim Jagielski 	Reference< XTask >	xTask_1( xServiceManager->createInstance(SERVICENAME_TASK), UNO_QUERY );
792*b1cdbd2cSJim Jagielski 	Reference< XTask >	xTask_2( xServiceManager->createInstance(SERVICENAME_TASK), UNO_QUERY );
793*b1cdbd2cSJim Jagielski 	Reference< XTask >	xTask_3( xServiceManager->createInstance(SERVICENAME_TASK), UNO_QUERY );
794*b1cdbd2cSJim Jagielski 	Reference< XTask >	xTask_4( xServiceManager->createInstance(SERVICENAME_TASK), UNO_QUERY );
795*b1cdbd2cSJim Jagielski 	Reference< XTask >	xTask_5( xServiceManager->createInstance(SERVICENAME_TASK), UNO_QUERY );
796*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_11( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
797*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_12( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
798*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_21( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
799*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_22( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
800*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_31( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
801*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_32( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
802*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_41( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
803*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_42( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
804*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_51( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
805*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_52( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
806*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_111( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
807*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_112( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
808*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_121( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
809*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_411( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
810*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_1121( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
811*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_1122( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
812*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_1123( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
813*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_4111( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
814*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_4112( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
815*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_4113( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
816*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_11221( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
817*b1cdbd2cSJim Jagielski 	Reference< XFrame >	xFrame_11231( xServiceManager->createInstance(SERVICENAME_FRAME), UNO_QUERY );
818*b1cdbd2cSJim Jagielski 
819*b1cdbd2cSJim Jagielski 	// Initialize tasks and frames with names to support easy finding!
820*b1cdbd2cSJim Jagielski 	Reference< XFrame > xTaskFrame_1( xTask_1, UNO_QUERY );
821*b1cdbd2cSJim Jagielski 	Reference< XFrame > xTaskFrame_2( xTask_2, UNO_QUERY );
822*b1cdbd2cSJim Jagielski 	Reference< XFrame > xTaskFrame_3( xTask_3, UNO_QUERY );
823*b1cdbd2cSJim Jagielski 	Reference< XFrame > xTaskFrame_4( xTask_4, UNO_QUERY );
824*b1cdbd2cSJim Jagielski 	Reference< XFrame > xTaskFrame_5( xTask_5, UNO_QUERY );
825*b1cdbd2cSJim Jagielski 
826*b1cdbd2cSJim Jagielski 	xTaskFrame_1->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Task_1")));
827*b1cdbd2cSJim Jagielski 	xTaskFrame_2->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Task_2")));
828*b1cdbd2cSJim Jagielski 	xTaskFrame_3->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Task_3")));
829*b1cdbd2cSJim Jagielski 	xTaskFrame_4->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Task_4")));
830*b1cdbd2cSJim Jagielski 	xTaskFrame_5->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Task_5")));
831*b1cdbd2cSJim Jagielski 	xFrame_11->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_11")));
832*b1cdbd2cSJim Jagielski 	xFrame_12->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_12")));
833*b1cdbd2cSJim Jagielski 	xFrame_21->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_21")));
834*b1cdbd2cSJim Jagielski 	xFrame_22->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_22")));
835*b1cdbd2cSJim Jagielski 	xFrame_31->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_31")));
836*b1cdbd2cSJim Jagielski 	xFrame_32->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_32")));
837*b1cdbd2cSJim Jagielski 	xFrame_41->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_41")));
838*b1cdbd2cSJim Jagielski 	xFrame_42->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_42")));
839*b1cdbd2cSJim Jagielski 	xFrame_51->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_51")));
840*b1cdbd2cSJim Jagielski 	xFrame_52->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_52")));
841*b1cdbd2cSJim Jagielski 	xFrame_111->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_111")));
842*b1cdbd2cSJim Jagielski 	xFrame_112->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_112")));
843*b1cdbd2cSJim Jagielski 	xFrame_121->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_121")));
844*b1cdbd2cSJim Jagielski 	xFrame_411->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_411")));
845*b1cdbd2cSJim Jagielski 	xFrame_1121->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_1121")));
846*b1cdbd2cSJim Jagielski 	xFrame_1122->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_1122")));
847*b1cdbd2cSJim Jagielski 	xFrame_1123->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_1123")));
848*b1cdbd2cSJim Jagielski 	xFrame_4111->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_4111")));
849*b1cdbd2cSJim Jagielski 	xFrame_4112->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_4112")));
850*b1cdbd2cSJim Jagielski 	xFrame_4113->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_4113")));
851*b1cdbd2cSJim Jagielski 	xFrame_11221->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_11221")));
852*b1cdbd2cSJim Jagielski 	xFrame_11231->setName(OUString(RTL_CONSTASCII_USTRINGPARAM("Frame_11231")));
853*b1cdbd2cSJim Jagielski 
854*b1cdbd2cSJim Jagielski 	// Build tree.
855*b1cdbd2cSJim Jagielski 	// Append tasks as childs of desktop.
856*b1cdbd2cSJim Jagielski 	xFrames->append( xTaskFrame_1 );
857*b1cdbd2cSJim Jagielski 	xFrames->append( xTaskFrame_2 );
858*b1cdbd2cSJim Jagielski 	xFrames->append( xTaskFrame_3 );
859*b1cdbd2cSJim Jagielski 	xFrames->append( xTaskFrame_4 );
860*b1cdbd2cSJim Jagielski 	xFrames->append( xTaskFrame_5 );
861*b1cdbd2cSJim Jagielski 
862*b1cdbd2cSJim Jagielski 	// Append frames as childs of tasks.
863*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xTaskFramesSupplier_1( xTask_1, UNO_QUERY );
864*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xTaskFramesSupplier_2( xTask_2, UNO_QUERY );
865*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xTaskFramesSupplier_3( xTask_3, UNO_QUERY );
866*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xTaskFramesSupplier_4( xTask_4, UNO_QUERY );
867*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xTaskFramesSupplier_5( xTask_5, UNO_QUERY );
868*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xFramesSupplier_11( xFrame_11, UNO_QUERY );
869*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xFramesSupplier_12( xFrame_12, UNO_QUERY );
870*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xFramesSupplier_112( xFrame_112, UNO_QUERY );
871*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xFramesSupplier_1122( xFrame_1122, UNO_QUERY );
872*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xFramesSupplier_1123( xFrame_1123, UNO_QUERY );
873*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xFramesSupplier_41( xFrame_41, UNO_QUERY );
874*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xFramesSupplier_411( xFrame_411, UNO_QUERY );
875*b1cdbd2cSJim Jagielski 
876*b1cdbd2cSJim Jagielski 	xFrames = xTaskFramesSupplier_1->getFrames();
877*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_11 );
878*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_12 );
879*b1cdbd2cSJim Jagielski 	xFrames = xTaskFramesSupplier_2->getFrames();
880*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_21 );
881*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_22 );
882*b1cdbd2cSJim Jagielski 	xFrames = xTaskFramesSupplier_3->getFrames();
883*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_31 );
884*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_32 );
885*b1cdbd2cSJim Jagielski 	xFrames = xTaskFramesSupplier_4->getFrames();
886*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_41 );
887*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_42 );
888*b1cdbd2cSJim Jagielski 	xFrames = xTaskFramesSupplier_5->getFrames();
889*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_51 );
890*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_52 );
891*b1cdbd2cSJim Jagielski 	xFrames = xFramesSupplier_11->getFrames();
892*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_111 );
893*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_112 );
894*b1cdbd2cSJim Jagielski 	xFrames = xFramesSupplier_12->getFrames();
895*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_121 );
896*b1cdbd2cSJim Jagielski 	xFrames = xFramesSupplier_112->getFrames();
897*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_1121 );
898*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_1122 );
899*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_1123 );
900*b1cdbd2cSJim Jagielski 	xFrames = xFramesSupplier_1122->getFrames();
901*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_11221 );
902*b1cdbd2cSJim Jagielski 	xFrames = xFramesSupplier_1123->getFrames();
903*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_11231 );
904*b1cdbd2cSJim Jagielski 	xFrames = xFramesSupplier_41->getFrames();
905*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_411 );
906*b1cdbd2cSJim Jagielski 	xFrames = xFramesSupplier_411->getFrames();
907*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_4111 );
908*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_4112 );
909*b1cdbd2cSJim Jagielski 	xFrames->append( xFrame_4113 );
910*b1cdbd2cSJim Jagielski 
911*b1cdbd2cSJim Jagielski 	// Create some active paths.
912*b1cdbd2cSJim Jagielski 	// desktop => task_1 => frame_11 => frame_112 => frame_1122
913*b1cdbd2cSJim Jagielski //	xDesktopSupplier->setActiveFrame( xTaskFrame_1 );
914*b1cdbd2cSJim Jagielski //	xTaskFramesSupplier_1->setActiveFrame( xFrame_11 );
915*b1cdbd2cSJim Jagielski //	xFramesSupplier_11->setActiveFrame( xFrame_112 );
916*b1cdbd2cSJim Jagielski //	xFramesSupplier_112->setActiveFrame( xFrame_1122 );
917*b1cdbd2cSJim Jagielski 	// frame_41 => frame_411 => frame_4111
918*b1cdbd2cSJim Jagielski //	xFramesSupplier_41->setActiveFrame( xFrame_411 );
919*b1cdbd2cSJim Jagielski //	xFramesSupplier_411->setActiveFrame( xFrame_4111 );
920*b1cdbd2cSJim Jagielski 	// task_3 => frame_31
921*b1cdbd2cSJim Jagielski //	xTaskFramesSupplier_3->setActiveFrame( xFrame_31 );
922*b1cdbd2cSJim Jagielski 	// frame_1123 => frame_11231
923*b1cdbd2cSJim Jagielski //	xFramesSupplier_1123->setActiveFrame( xFrame_11231 );
924*b1cdbd2cSJim Jagielski 
925*b1cdbd2cSJim Jagielski //	xTask_1->activate();
926*b1cdbd2cSJim Jagielski //	impl_logTree( xDesktop );
927*b1cdbd2cSJim Jagielski //	xFrame_41->activate();
928*b1cdbd2cSJim Jagielski //	impl_logTree( xDesktop );
929*b1cdbd2cSJim Jagielski //	xFrame_52->activate();
930*b1cdbd2cSJim Jagielski //	impl_logTree( xDesktop );
931*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_TREE, "initiale Hierarchy:" )
932*b1cdbd2cSJim Jagielski 	impl_logTree( xDesktop );
933*b1cdbd2cSJim Jagielski 
934*b1cdbd2cSJim Jagielski //	xFrame_121->activate();
935*b1cdbd2cSJim Jagielski //	impl_logTree( xDesktop );
936*b1cdbd2cSJim Jagielski //	xFrame_41->activate();
937*b1cdbd2cSJim Jagielski //	impl_logTree( xDesktop );
938*b1cdbd2cSJim Jagielski //	xFrame_52->activate();
939*b1cdbd2cSJim Jagielski //	impl_logTree( xDesktop );
940*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_EVENTS, "nach xFrame_411->activate():" )
941*b1cdbd2cSJim Jagielski 	xFrame_411->activate();
942*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_TREE, "nach xFrame_411->activate():" )
943*b1cdbd2cSJim Jagielski 	impl_logTree( xDesktop );
944*b1cdbd2cSJim Jagielski //	xFrame_41->deactivate();
945*b1cdbd2cSJim Jagielski //	impl_logTree( xDesktop );
946*b1cdbd2cSJim Jagielski //	xFrame_4113->activate();
947*b1cdbd2cSJim Jagielski //	impl_logTree( xDesktop );
948*b1cdbd2cSJim Jagielski //	xFrame_21->activate();
949*b1cdbd2cSJim Jagielski //	impl_logTree( xDesktop );
950*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_EVENTS, "nach xFrame_11231->activate():" )
951*b1cdbd2cSJim Jagielski 	xFrame_11231->activate();
952*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_TREE, "nach xFrame_11231->activate():" )
953*b1cdbd2cSJim Jagielski 	impl_logTree( xDesktop );
954*b1cdbd2cSJim Jagielski 
955*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_EVENTS, "nach xFrame_11221->activate():" )
956*b1cdbd2cSJim Jagielski 	xFrame_11221->activate();
957*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_TREE, "nach xFrame_11221->activate():" )
958*b1cdbd2cSJim Jagielski 	impl_logTree( xDesktop );
959*b1cdbd2cSJim Jagielski 
960*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_EVENTS, "nach xFrame_112->deactivate():" )
961*b1cdbd2cSJim Jagielski //	xFrame_112->getCreator()->setActiveFrame( Reference< XFrame >() );
962*b1cdbd2cSJim Jagielski 	xFrame_112->deactivate();
963*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_TREE, "nach xFrame_112->deactivate():" )
964*b1cdbd2cSJim Jagielski 	impl_logTree( xDesktop );
965*b1cdbd2cSJim Jagielski 
966*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_EVENTS, "nach xFrame_41->activate():" )
967*b1cdbd2cSJim Jagielski 	xFrame_41->activate();
968*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_TREE, "nach xFrame_41->activate():" )
969*b1cdbd2cSJim Jagielski 	impl_logTree( xDesktop );
970*b1cdbd2cSJim Jagielski 
971*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_EVENTS, "nach xTask_4->activate():" )
972*b1cdbd2cSJim Jagielski 	xTask_4->activate();
973*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_TREE, "nach xTask_4->activate():" )
974*b1cdbd2cSJim Jagielski 	impl_logTree( xDesktop );
975*b1cdbd2cSJim Jagielski 
976*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_EVENTS, "nach xFrame_1123->deactivate():" )
977*b1cdbd2cSJim Jagielski 	xFrame_1123->deactivate();
978*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_TREE, "nach xFrame_1123->deactivate():" )
979*b1cdbd2cSJim Jagielski 	impl_logTree( xDesktop );
980*b1cdbd2cSJim Jagielski }
981*b1cdbd2cSJim Jagielski 
982*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
983*b1cdbd2cSJim Jagielski //	helper method to log current tree state
984*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
impl_logTree(const Reference<XDesktop> & xDesktop)985*b1cdbd2cSJim Jagielski void TestApplication::impl_logTree( const Reference< XDesktop >& xDesktop )
986*b1cdbd2cSJim Jagielski {
987*b1cdbd2cSJim Jagielski #ifdef ENABLE_SERVICEDEBUG
988*b1cdbd2cSJim Jagielski 	// Use special feature of Desktop-implementation.
989*b1cdbd2cSJim Jagielski 	// NEVER USE THIS IN RELEASE VERSIONS!!!
990*b1cdbd2cSJim Jagielski 	Reference< XSPECIALDEBUGINTERFACE > xDebug( xDesktop, UNO_QUERY );
991*b1cdbd2cSJim Jagielski 
992*b1cdbd2cSJim Jagielski 	// Get a "stream" of all names of frames in tree.
993*b1cdbd2cSJim Jagielski 	OUString sTreeNamesStream = xDebug->dumpVariable( DUMPVARIABLE_TREEINFO, 0 );
994*b1cdbd2cSJim Jagielski 	// And write it to logfile.
995*b1cdbd2cSJim Jagielski 	OString sOutPut = OUStringToOString( sTreeNamesStream, RTL_TEXTENCODING_UTF8 );
996*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_TREE, "\nNew tree log:\n\n"	);
997*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_TREE, sOutPut			);
998*b1cdbd2cSJim Jagielski //	WRITE_LOGFILE( LOGFILENAME_TREE, "\n"						);
999*b1cdbd2cSJim Jagielski #endif
1000*b1cdbd2cSJim Jagielski }
1001*b1cdbd2cSJim Jagielski #endif // TEST_DESKTOP
1002*b1cdbd2cSJim Jagielski 
1003*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
1004*b1cdbd2cSJim Jagielski //	test method for registration of new filters in configuration
1005*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
1006*b1cdbd2cSJim Jagielski #ifdef TEST_FILTERREGISTRATION
impl_testFilterRegistration()1007*b1cdbd2cSJim Jagielski void TestApplication::impl_testFilterRegistration()
1008*b1cdbd2cSJim Jagielski {
1009*b1cdbd2cSJim Jagielski 	Reference< XNameContainer > xContainer( m_xFactory->createInstance( SERVICENAME_FILTERFACTORY ), UNO_QUERY );
1010*b1cdbd2cSJim Jagielski 	LOG_ASSERT( !(xContainer.is()==sal_False), "TestApplication::impl_testFilterRegistration()\nCould not create FilterFactory-service or cast it to XNameContainer.\n" )
1011*b1cdbd2cSJim Jagielski 	if( xContainer.is() == sal_True )
1012*b1cdbd2cSJim Jagielski 	{
1013*b1cdbd2cSJim Jagielski 		Sequence< PropertyValue > lProperties( 8 );
1014*b1cdbd2cSJim Jagielski 
1015*b1cdbd2cSJim Jagielski 		lProperties[0].Name		=	DECLARE_ASCII("Type"					);
1016*b1cdbd2cSJim Jagielski 		lProperties[0].Value	<<=	DECLARE_ASCII("component_DB"			);
1017*b1cdbd2cSJim Jagielski 
1018*b1cdbd2cSJim Jagielski 		lProperties[1].Name		=	DECLARE_ASCII("UIName"					);
1019*b1cdbd2cSJim Jagielski 		lProperties[1].Value	<<=	DECLARE_ASCII("Ein neuer Filter-Eintrag");
1020*b1cdbd2cSJim Jagielski 
1021*b1cdbd2cSJim Jagielski 		lProperties[2].Name		=	DECLARE_ASCII("DocumentService"			);
1022*b1cdbd2cSJim Jagielski 		lProperties[2].Value	<<=	DECLARE_ASCII("test.document.service"	);
1023*b1cdbd2cSJim Jagielski 
1024*b1cdbd2cSJim Jagielski 		lProperties[3].Name		=	DECLARE_ASCII("FilterService"			);
1025*b1cdbd2cSJim Jagielski 		lProperties[3].Value	<<=	DECLARE_ASCII("test.filter.service"		);
1026*b1cdbd2cSJim Jagielski 
1027*b1cdbd2cSJim Jagielski 		lProperties[4].Name		=	DECLARE_ASCII("Flags"					);
1028*b1cdbd2cSJim Jagielski 		lProperties[4].Value	<<=	(sal_Int32)100;
1029*b1cdbd2cSJim Jagielski 
1030*b1cdbd2cSJim Jagielski 		Sequence< OUString > lTempData(1);
1031*b1cdbd2cSJim Jagielski 		lTempData[0] = DECLARE_ASCII("meine UserData");
1032*b1cdbd2cSJim Jagielski 		lProperties[5].Name		=	DECLARE_ASCII("UserData"				);
1033*b1cdbd2cSJim Jagielski 		lProperties[5].Value	<<=	lTempData;
1034*b1cdbd2cSJim Jagielski 
1035*b1cdbd2cSJim Jagielski 		lProperties[6].Name		=	DECLARE_ASCII("FileFormatVersion"		);
1036*b1cdbd2cSJim Jagielski 		lProperties[6].Value	<<=	(sal_Int32)1;
1037*b1cdbd2cSJim Jagielski 
1038*b1cdbd2cSJim Jagielski 		lProperties[7].Name		=	DECLARE_ASCII("TemplateName"			);
1039*b1cdbd2cSJim Jagielski 		lProperties[7].Value	<<=	DECLARE_ASCII("Mein Template Name"		);
1040*b1cdbd2cSJim Jagielski 
1041*b1cdbd2cSJim Jagielski 		Any aProperties;
1042*b1cdbd2cSJim Jagielski 		aProperties <<= lProperties;
1043*b1cdbd2cSJim Jagielski 		xContainer->insertByName( DECLARE_ASCII("mein_eigener_neuer_Filter"), aProperties );
1044*b1cdbd2cSJim Jagielski 
1045*b1cdbd2cSJim Jagielski 		lProperties[0].Name		=	DECLARE_ASCII("Type"					);
1046*b1cdbd2cSJim Jagielski 		lProperties[0].Value	<<=	DECLARE_ASCII("component_DB"			);
1047*b1cdbd2cSJim Jagielski 
1048*b1cdbd2cSJim Jagielski 		lProperties[1].Name		=	DECLARE_ASCII("UIName"					);
1049*b1cdbd2cSJim Jagielski 		lProperties[1].Value	<<=	DECLARE_ASCII("Ein neuer Filter-Eintrag 2");
1050*b1cdbd2cSJim Jagielski 
1051*b1cdbd2cSJim Jagielski 		lProperties[2].Name		=	DECLARE_ASCII("DocumentService"			);
1052*b1cdbd2cSJim Jagielski 		lProperties[2].Value	<<=	DECLARE_ASCII("test.document.service 2"	);
1053*b1cdbd2cSJim Jagielski 
1054*b1cdbd2cSJim Jagielski 		lProperties[3].Name		=	DECLARE_ASCII("FilterService"			);
1055*b1cdbd2cSJim Jagielski 		lProperties[3].Value	<<=	DECLARE_ASCII("test.filter.service 2"		);
1056*b1cdbd2cSJim Jagielski 
1057*b1cdbd2cSJim Jagielski 		lProperties[4].Name		=	DECLARE_ASCII("Flags"					);
1058*b1cdbd2cSJim Jagielski 		lProperties[4].Value	<<=	(sal_Int32)200;
1059*b1cdbd2cSJim Jagielski 
1060*b1cdbd2cSJim Jagielski 		lTempData[0] = DECLARE_ASCII("meine UserData 2");
1061*b1cdbd2cSJim Jagielski 		lProperties[5].Name		=	DECLARE_ASCII("UserData"				);
1062*b1cdbd2cSJim Jagielski 		lProperties[5].Value	<<=	lTempData;
1063*b1cdbd2cSJim Jagielski 
1064*b1cdbd2cSJim Jagielski 		lProperties[6].Name		=	DECLARE_ASCII("FileFormatVersion"		);
1065*b1cdbd2cSJim Jagielski 		lProperties[6].Value	<<=	(sal_Int32)2;
1066*b1cdbd2cSJim Jagielski 
1067*b1cdbd2cSJim Jagielski 		lProperties[7].Name		=	DECLARE_ASCII("TemplateName"			);
1068*b1cdbd2cSJim Jagielski 		lProperties[7].Value	<<=	DECLARE_ASCII("Mein Template Name 2"		);
1069*b1cdbd2cSJim Jagielski 
1070*b1cdbd2cSJim Jagielski 		aProperties <<= lProperties;
1071*b1cdbd2cSJim Jagielski 		xContainer->insertByName( DECLARE_ASCII("mein_eigener_neuer_Filter_2"), aProperties );
1072*b1cdbd2cSJim Jagielski 
1073*b1cdbd2cSJim Jagielski 		xContainer->removeByName( DECLARE_ASCII("mein_eigener_neuer_Filter") );
1074*b1cdbd2cSJim Jagielski 	}
1075*b1cdbd2cSJim Jagielski }
1076*b1cdbd2cSJim Jagielski #endif
1077*b1cdbd2cSJim Jagielski 
1078*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
1079*b1cdbd2cSJim Jagielski //	test method for search mechanism in our frame tree
1080*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
1081*b1cdbd2cSJim Jagielski #ifdef TEST_TREESEARCH
impl_testTreeSearch()1082*b1cdbd2cSJim Jagielski sal_Bool TestApplication::impl_testTreeSearch()
1083*b1cdbd2cSJim Jagielski {
1084*b1cdbd2cSJim Jagielski 	// Build an example tree.
1085*b1cdbd2cSJim Jagielski 	Reference< XFrame > xD		( m_xFactory->createInstance( SERVICENAME_DESKTOP	), UNO_QUERY );
1086*b1cdbd2cSJim Jagielski 	Reference< XFrame > xT1		( m_xFactory->createInstance( SERVICENAME_TASK		), UNO_QUERY );
1087*b1cdbd2cSJim Jagielski 	Reference< XFrame > xT2		( m_xFactory->createInstance( SERVICENAME_TASK		), UNO_QUERY );
1088*b1cdbd2cSJim Jagielski 	Reference< XFrame > xT3		( m_xFactory->createInstance( SERVICENAME_TASK		), UNO_QUERY );
1089*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF11	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1090*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF12	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1091*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF21	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1092*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF22	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1093*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF211	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1094*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF212	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1095*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF221	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1096*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF2111	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1097*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF2112	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1098*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF2121	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1099*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF2122	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1100*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF2211	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1101*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF21111	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1102*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF21112	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1103*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF21121	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1104*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF21122	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1105*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF21211	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1106*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF21212	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1107*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF21221	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1108*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF21222	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1109*b1cdbd2cSJim Jagielski 	Reference< XFrame > xF22111	( m_xFactory->createInstance( SERVICENAME_FRAME		), UNO_QUERY );
1110*b1cdbd2cSJim Jagielski 
1111*b1cdbd2cSJim Jagielski 	xD->setName		( DECLARE_ASCII("D"		) );
1112*b1cdbd2cSJim Jagielski 	xT1->setName	( DECLARE_ASCII("T1"	) );
1113*b1cdbd2cSJim Jagielski 	xT2->setName	( DECLARE_ASCII("T2"	) );
1114*b1cdbd2cSJim Jagielski 	xT3->setName	( DECLARE_ASCII("T3"	) );
1115*b1cdbd2cSJim Jagielski 	xF11->setName	( DECLARE_ASCII("F11"	) );
1116*b1cdbd2cSJim Jagielski 	xF12->setName	( DECLARE_ASCII("F12"	) );
1117*b1cdbd2cSJim Jagielski 	xF21->setName	( DECLARE_ASCII("F21"	) );
1118*b1cdbd2cSJim Jagielski 	xF22->setName	( DECLARE_ASCII("F22"	) );
1119*b1cdbd2cSJim Jagielski 	xF211->setName	( DECLARE_ASCII("F211"	) );
1120*b1cdbd2cSJim Jagielski 	xF212->setName	( DECLARE_ASCII("F212"	) );
1121*b1cdbd2cSJim Jagielski 	xF221->setName	( DECLARE_ASCII("F221"	) );
1122*b1cdbd2cSJim Jagielski 	xF2111->setName	( DECLARE_ASCII("F2111"	) );
1123*b1cdbd2cSJim Jagielski 	xF2112->setName	( DECLARE_ASCII("F2112"	) );
1124*b1cdbd2cSJim Jagielski 	xF2121->setName	( DECLARE_ASCII("F2121"	) );
1125*b1cdbd2cSJim Jagielski 	xF2122->setName	( DECLARE_ASCII("F2122"	) );
1126*b1cdbd2cSJim Jagielski 	xF2211->setName	( DECLARE_ASCII("F2211"	) );
1127*b1cdbd2cSJim Jagielski 	xF21111->setName( DECLARE_ASCII("F21111") );
1128*b1cdbd2cSJim Jagielski 	xF21112->setName( DECLARE_ASCII("F21112") );
1129*b1cdbd2cSJim Jagielski 	xF21121->setName( DECLARE_ASCII("F21121") );
1130*b1cdbd2cSJim Jagielski 	xF21122->setName( DECLARE_ASCII("F21122") );
1131*b1cdbd2cSJim Jagielski 	xF21211->setName( DECLARE_ASCII("F21211") );
1132*b1cdbd2cSJim Jagielski 	xF21212->setName( DECLARE_ASCII("F21212") );
1133*b1cdbd2cSJim Jagielski 	xF21221->setName( DECLARE_ASCII("F21221") );
1134*b1cdbd2cSJim Jagielski 	xF21222->setName( DECLARE_ASCII("F21222") );
1135*b1cdbd2cSJim Jagielski 	xF22111->setName( DECLARE_ASCII("F22111") );
1136*b1cdbd2cSJim Jagielski 
1137*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSD		( xD		, UNO_QUERY );
1138*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xST1		( xT1		, UNO_QUERY );
1139*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xST2		( xT2		, UNO_QUERY );
1140*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xST3		( xT3		, UNO_QUERY );
1141*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF11		( xF11		, UNO_QUERY );
1142*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF12		( xF12		, UNO_QUERY );
1143*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF21		( xF21		, UNO_QUERY );
1144*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF22		( xF22		, UNO_QUERY );
1145*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF211		( xF211		, UNO_QUERY );
1146*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF212		( xF212		, UNO_QUERY );
1147*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF221		( xF221		, UNO_QUERY );
1148*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF2111	( xF2111	, UNO_QUERY );
1149*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF2112	( xF2112	, UNO_QUERY );
1150*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF2121	( xF2121	, UNO_QUERY );
1151*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF2122	( xF2122	, UNO_QUERY );
1152*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF2211	( xF2211	, UNO_QUERY );
1153*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF21111	( xF21111	, UNO_QUERY );
1154*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF21112	( xF21112	, UNO_QUERY );
1155*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF21121	( xF21121	, UNO_QUERY );
1156*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF21122	( xF21122	, UNO_QUERY );
1157*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF21211	( xF21211	, UNO_QUERY );
1158*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF21212	( xF21212	, UNO_QUERY );
1159*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF21221	( xF21221	, UNO_QUERY );
1160*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF21222	( xF21222	, UNO_QUERY );
1161*b1cdbd2cSJim Jagielski 	Reference< XFramesSupplier > xSF22111	( xF22111	, UNO_QUERY );
1162*b1cdbd2cSJim Jagielski 
1163*b1cdbd2cSJim Jagielski 	xSD->getFrames()->append		( xT1		);
1164*b1cdbd2cSJim Jagielski 	xSD->getFrames()->append		( xT2		);
1165*b1cdbd2cSJim Jagielski 	xSD->getFrames()->append		( xT3		);
1166*b1cdbd2cSJim Jagielski 	xST1->getFrames()->append		( xF11		);
1167*b1cdbd2cSJim Jagielski 	xST1->getFrames()->append		( xF12		);
1168*b1cdbd2cSJim Jagielski 	xST2->getFrames()->append		( xF21		);
1169*b1cdbd2cSJim Jagielski 	xST2->getFrames()->append		( xF22		);
1170*b1cdbd2cSJim Jagielski 	xSF21->getFrames()->append		( xF211		);
1171*b1cdbd2cSJim Jagielski 	xSF21->getFrames()->append		( xF212		);
1172*b1cdbd2cSJim Jagielski 	xSF211->getFrames()->append		( xF2111	);
1173*b1cdbd2cSJim Jagielski 	xSF211->getFrames()->append		( xF2112	);
1174*b1cdbd2cSJim Jagielski 	xSF212->getFrames()->append		( xF2121	);
1175*b1cdbd2cSJim Jagielski 	xSF212->getFrames()->append		( xF2122	);
1176*b1cdbd2cSJim Jagielski 	xSF2111->getFrames()->append	( xF21111	);
1177*b1cdbd2cSJim Jagielski 	xSF2111->getFrames()->append	( xF21112	);
1178*b1cdbd2cSJim Jagielski 	xSF2112->getFrames()->append	( xF21121	);
1179*b1cdbd2cSJim Jagielski 	xSF2112->getFrames()->append	( xF21122	);
1180*b1cdbd2cSJim Jagielski 	xSF2121->getFrames()->append	( xF21211	);
1181*b1cdbd2cSJim Jagielski 	xSF2121->getFrames()->append	( xF21212	);
1182*b1cdbd2cSJim Jagielski 	xSF2122->getFrames()->append	( xF21221	);
1183*b1cdbd2cSJim Jagielski 	xSF2122->getFrames()->append	( xF21222	);
1184*b1cdbd2cSJim Jagielski 	xSF22->getFrames()->append		( xF221		);
1185*b1cdbd2cSJim Jagielski 	xSF221->getFrames()->append		( xF2211	);
1186*b1cdbd2cSJim Jagielski 	xSF2211->getFrames()->append	( xF22111	);
1187*b1cdbd2cSJim Jagielski 
1188*b1cdbd2cSJim Jagielski 	sal_Int32 nFlags = 0;
1189*b1cdbd2cSJim Jagielski 
1190*b1cdbd2cSJim Jagielski 	// Test deep down search
1191*b1cdbd2cSJim Jagielski 	nFlags = FrameSearchFlag::CHILDREN;
1192*b1cdbd2cSJim Jagielski 	if	(
1193*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("T1"		), nFlags )	!=	xT1		)	||
1194*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("T2"		), nFlags )	!=	xT2		)	||
1195*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("T3"		), nFlags )	!=	xT3		)	||
1196*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F11"	), nFlags )	!=	xF11	)	||
1197*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F12"	), nFlags )	!=	xF12	)	||
1198*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21"	), nFlags )	!=	xF21	)	||
1199*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F22"	), nFlags )	!=	xF22	)	||
1200*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F211"	), nFlags )	!=	xF211	)	||
1201*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F212"	), nFlags )	!=	xF212	)	||
1202*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F2111"	), nFlags )	!=	xF2111	)	||
1203*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F2112"	), nFlags )	!=	xF2112	)	||
1204*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F2121"	), nFlags )	!=	xF2121	)	||
1205*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F2122"	), nFlags )	!=	xF2122	)	||
1206*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21111"	), nFlags )	!=	xF21111	)	||
1207*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21112"	), nFlags )	!=	xF21112	)	||
1208*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21121"	), nFlags )	!=	xF21121	)	||
1209*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21122"	), nFlags )	!=	xF21122	)	||
1210*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21211"	), nFlags )	!=	xF21211	)	||
1211*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21212"	), nFlags )	!=	xF21212	)	||
1212*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21221"	), nFlags )	!=	xF21221	)	||
1213*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21222"	), nFlags )	!=	xF21222	)	||
1214*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F221"	), nFlags )	!=	xF221	)	||
1215*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F2211"	), nFlags )	!=	xF2211	)	||
1216*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F22111"	), nFlags )	!=	xF22111	)
1217*b1cdbd2cSJim Jagielski 		)
1218*b1cdbd2cSJim Jagielski 	{
1219*b1cdbd2cSJim Jagielski 		LOG_ERROR( "TestApplikation::impl_testTreeSearch()", "deep down search failed" )
1220*b1cdbd2cSJim Jagielski 		return sal_False;
1221*b1cdbd2cSJim Jagielski 	}
1222*b1cdbd2cSJim Jagielski 
1223*b1cdbd2cSJim Jagielski 	// Test flat down search
1224*b1cdbd2cSJim Jagielski 	nFlags = FrameSearchFlag::CHILDREN | FrameSearchFlag::SIBLINGS;
1225*b1cdbd2cSJim Jagielski 	if	(
1226*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("T1"		), nFlags )	!=	xT1		)	||
1227*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("T2"		), nFlags )	!=	xT2		)	||
1228*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("T3"		), nFlags )	!=	xT3		)	||
1229*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F11"	), nFlags )	!=	xF11	)	||
1230*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F12"	), nFlags )	!=	xF12	)	||
1231*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21"	), nFlags )	!=	xF21	)	||
1232*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F22"	), nFlags )	!=	xF22	)	||
1233*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F211"	), nFlags )	!=	xF211	)	||
1234*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F212"	), nFlags )	!=	xF212	)	||
1235*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F2111"	), nFlags )	!=	xF2111	)	||
1236*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F2112"	), nFlags )	!=	xF2112	)	||
1237*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F2121"	), nFlags )	!=	xF2121	)	||
1238*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F2122"	), nFlags )	!=	xF2122	)	||
1239*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21111"	), nFlags )	!=	xF21111	)	||
1240*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21112"	), nFlags )	!=	xF21112	)	||
1241*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21121"	), nFlags )	!=	xF21121	)	||
1242*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21122"	), nFlags )	!=	xF21122	)	||
1243*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21211"	), nFlags )	!=	xF21211	)	||
1244*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21212"	), nFlags )	!=	xF21212	)	||
1245*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21221"	), nFlags )	!=	xF21221	)	||
1246*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F21222"	), nFlags )	!=	xF21222	)	||
1247*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F221"	), nFlags )	!=	xF221	)	||
1248*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F2211"	), nFlags )	!=	xF2211	)	||
1249*b1cdbd2cSJim Jagielski 			( xD->findFrame( DECLARE_ASCII("F22111"	), nFlags )	!=	xF22111	)
1250*b1cdbd2cSJim Jagielski 		)
1251*b1cdbd2cSJim Jagielski 	{
1252*b1cdbd2cSJim Jagielski 		LOG_ERROR( "TestApplikation::impl_testTreeSearch()", "flat down search failed" )
1253*b1cdbd2cSJim Jagielski 		return sal_False;
1254*b1cdbd2cSJim Jagielski 	}
1255*b1cdbd2cSJim Jagielski 
1256*b1cdbd2cSJim Jagielski 	// Test deep up search
1257*b1cdbd2cSJim Jagielski 	// All targets must be found. Control search steps in log files!
1258*b1cdbd2cSJim Jagielski 	nFlags = FrameSearchFlag::PARENT;
1259*b1cdbd2cSJim Jagielski 	if	(
1260*b1cdbd2cSJim Jagielski 			( xF11->findFrame	( DECLARE_ASCII("T1"), nFlags )	!=	xT1	)	||	// search for valid targets
1261*b1cdbd2cSJim Jagielski 			( xF12->findFrame	( DECLARE_ASCII("T1"), nFlags )	!=	xT1	)	||
1262*b1cdbd2cSJim Jagielski 			( xF21->findFrame	( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1263*b1cdbd2cSJim Jagielski 			( xF22->findFrame	( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1264*b1cdbd2cSJim Jagielski 			( xF211->findFrame	( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1265*b1cdbd2cSJim Jagielski 			( xF212->findFrame	( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1266*b1cdbd2cSJim Jagielski 			( xF221->findFrame	( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1267*b1cdbd2cSJim Jagielski 			( xF2111->findFrame	( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1268*b1cdbd2cSJim Jagielski 			( xF2121->findFrame	( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1269*b1cdbd2cSJim Jagielski 			( xF2122->findFrame	( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1270*b1cdbd2cSJim Jagielski 			( xF2211->findFrame	( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1271*b1cdbd2cSJim Jagielski 			( xF21111->findFrame( DECLARE_ASCII("T2"), nFlags )	!=	xT2 )	||
1272*b1cdbd2cSJim Jagielski 			( xF21112->findFrame( DECLARE_ASCII("T2"), nFlags )	!=	xT2 )	||
1273*b1cdbd2cSJim Jagielski 			( xF21121->findFrame( DECLARE_ASCII("T2"), nFlags )	!=	xT2 )	||
1274*b1cdbd2cSJim Jagielski 			( xF21122->findFrame( DECLARE_ASCII("T2"), nFlags )	!=	xT2 )	||
1275*b1cdbd2cSJim Jagielski 			( xF21211->findFrame( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1276*b1cdbd2cSJim Jagielski 			( xF21212->findFrame( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1277*b1cdbd2cSJim Jagielski 			( xF21221->findFrame( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1278*b1cdbd2cSJim Jagielski 			( xF21222->findFrame( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1279*b1cdbd2cSJim Jagielski 			( xF22111->findFrame( DECLARE_ASCII("T2"), nFlags )	!=	xT2	)	||
1280*b1cdbd2cSJim Jagielski 			( xF11->findFrame	( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||	// search for existing but non valid targets
1281*b1cdbd2cSJim Jagielski 			( xF12->findFrame	( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1282*b1cdbd2cSJim Jagielski 			( xF21->findFrame	( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1283*b1cdbd2cSJim Jagielski 			( xF22->findFrame	( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1284*b1cdbd2cSJim Jagielski 			( xF211->findFrame	( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1285*b1cdbd2cSJim Jagielski 			( xF212->findFrame	( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1286*b1cdbd2cSJim Jagielski 			( xF221->findFrame	( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1287*b1cdbd2cSJim Jagielski 			( xF2111->findFrame	( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1288*b1cdbd2cSJim Jagielski 			( xF2121->findFrame	( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1289*b1cdbd2cSJim Jagielski 			( xF2122->findFrame	( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1290*b1cdbd2cSJim Jagielski 			( xF2211->findFrame	( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1291*b1cdbd2cSJim Jagielski 			( xF21111->findFrame( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1292*b1cdbd2cSJim Jagielski 			( xF21112->findFrame( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1293*b1cdbd2cSJim Jagielski 			( xF21121->findFrame( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1294*b1cdbd2cSJim Jagielski 			( xF21122->findFrame( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1295*b1cdbd2cSJim Jagielski 			( xF21211->findFrame( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1296*b1cdbd2cSJim Jagielski 			( xF21212->findFrame( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1297*b1cdbd2cSJim Jagielski 			( xF21221->findFrame( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1298*b1cdbd2cSJim Jagielski 			( xF21222->findFrame( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)	||
1299*b1cdbd2cSJim Jagielski 			( xF22111->findFrame( DECLARE_ASCII("T3"), nFlags ).is()	==	sal_True	)
1300*b1cdbd2cSJim Jagielski 		)
1301*b1cdbd2cSJim Jagielski 	{
1302*b1cdbd2cSJim Jagielski 		LOG_ERROR( "TestApplikation::impl_testTreeSearch()", "deep up search failed" )
1303*b1cdbd2cSJim Jagielski 		return sal_False;
1304*b1cdbd2cSJim Jagielski 	}
1305*b1cdbd2cSJim Jagielski 
1306*b1cdbd2cSJim Jagielski 	// Test inside/outside tasks search
1307*b1cdbd2cSJim Jagielski 	// No frames outside current task should be found if TASKS flag isnt set.
1308*b1cdbd2cSJim Jagielski 	// Otherwise he must be found!
1309*b1cdbd2cSJim Jagielski 	if	(
1310*b1cdbd2cSJim Jagielski 			( xF21211->findFrame( DECLARE_ASCII("F12"	),	FrameSearchFlag::ALL								)		== xF12		)	||
1311*b1cdbd2cSJim Jagielski 			( xF21211->findFrame( DECLARE_ASCII("F22111"),	FrameSearchFlag::GLOBAL 							)		!= xF22111	)	||
1312*b1cdbd2cSJim Jagielski 			( xF21211->findFrame( DECLARE_ASCII("T4"	),	FrameSearchFlag::GLOBAL | FrameSearchFlag::CREATE	).is()	== sal_False)
1313*b1cdbd2cSJim Jagielski 		)
1314*b1cdbd2cSJim Jagielski 	{
1315*b1cdbd2cSJim Jagielski 		LOG_ERROR( "TestApplikation::impl_testTreeSearch()", "inside/outside task search failed" )
1316*b1cdbd2cSJim Jagielski 		return sal_False;
1317*b1cdbd2cSJim Jagielski 	}
1318*b1cdbd2cSJim Jagielski 
1319*b1cdbd2cSJim Jagielski 	// Test SELF
1320*b1cdbd2cSJim Jagielski 	// Use the desktop, one task and one frame node to do that.
1321*b1cdbd2cSJim Jagielski 	// The desktop must ignore these question ... all other must return himself.
1322*b1cdbd2cSJim Jagielski 	LOG_ASSERT2( (xD->findFrame 	(	DECLARE_ASCII(""),	FrameSearchFlag::SELF	)	== xD	), "TestApplication::impl_testTreeSearch()", "SELF search for D failed\n"	)
1323*b1cdbd2cSJim Jagielski 	LOG_ASSERT2( (xT1->findFrame	(	DECLARE_ASCII(""),	FrameSearchFlag::SELF	)	!= xT1	), "TestApplication::impl_testTreeSearch()", "SELF search for T1 failed\n"	)
1324*b1cdbd2cSJim Jagielski 	LOG_ASSERT2( (xF12->findFrame	(	DECLARE_ASCII(""),	FrameSearchFlag::SELF	)	!= xF12	), "TestApplication::impl_testTreeSearch()", "SELF search for F12 failed\n"	)
1325*b1cdbd2cSJim Jagielski 
1326*b1cdbd2cSJim Jagielski 	// Test special task search at desktop
1327*b1cdbd2cSJim Jagielski 	// These search allow TASKS and CREATE flags only!
1328*b1cdbd2cSJim Jagielski 	// We make no deep search - we work on direct children of desktop only.
1329*b1cdbd2cSJim Jagielski 	// Supported for desktop only.
1330*b1cdbd2cSJim Jagielski 	LOG_ASSERT2( (xD->findFrame		(	DECLARE_ASCII("T1"),	FrameSearchFlag::TASKS								)		!= xT1			), "TestApplication::impl_testTreeSearch()", "special TASKS search for T1 failed\n"				)
1331*b1cdbd2cSJim Jagielski 	LOG_ASSERT2( (xD->findFrame		(	DECLARE_ASCII("T2"),	FrameSearchFlag::TASKS								)		!= xT2			), "TestApplication::impl_testTreeSearch()", "special TASKS search for T2 failed\n"				)
1332*b1cdbd2cSJim Jagielski 	LOG_ASSERT2( (xD->findFrame		(	DECLARE_ASCII("T3"),	FrameSearchFlag::TASKS								)		!= xT3			), "TestApplication::impl_testTreeSearch()", "special TASKS search for T3 failed\n"				)
1333*b1cdbd2cSJim Jagielski 	// Attention: T4 was created before!
1334*b1cdbd2cSJim Jagielski 	LOG_ASSERT2( (xD->findFrame		(	DECLARE_ASCII("T5"),	FrameSearchFlag::TASKS								).is()	== sal_True		), "TestApplication::impl_testTreeSearch()", "special TASKS search for T5 failed\n"				)
1335*b1cdbd2cSJim Jagielski 	LOG_ASSERT2( (xD->findFrame		(	DECLARE_ASCII("T5"),	FrameSearchFlag::TASKS | FrameSearchFlag::CREATE	).is()	== sal_False	), "TestApplication::impl_testTreeSearch()", "special TASKS+CREATE search for T5 failed\n"		)
1336*b1cdbd2cSJim Jagielski 	LOG_ASSERT2( (xD->findFrame		(	DECLARE_ASCII("F12"),	FrameSearchFlag::TASKS								).is()	== sal_True		), "TestApplication::impl_testTreeSearch()", "special TASKS search for F12 failed\n"			)
1337*b1cdbd2cSJim Jagielski 	LOG_ASSERT2( (xF12->findFrame	(	DECLARE_ASCII("T1"),	FrameSearchFlag::TASKS								).is()	== sal_True		), "TestApplication::impl_testTreeSearch()", "special TASKS search for T1 from F12 failed\n"	)
1338*b1cdbd2cSJim Jagielski 	LOG_ASSERT2( (xF22111->findFrame(	DECLARE_ASCII("T1"),	FrameSearchFlag::TASKS								).is()	== sal_True		), "TestApplication::impl_testTreeSearch()", "special TASKS search for T1 from F22111 failed\n"	)
1339*b1cdbd2cSJim Jagielski 
1340*b1cdbd2cSJim Jagielski 	return sal_True;
1341*b1cdbd2cSJim Jagielski }
1342*b1cdbd2cSJim Jagielski #endif
1343