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