2003-10-06 12:30:52 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 13:33:07 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2003-10-06 12:30:52 +00:00
|
|
|
*
|
2010-02-12 15:01:35 +01:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2003-10-06 12:30:52 +00:00
|
|
|
*
|
2008-04-10 13:33:07 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2003-10-06 12:30:52 +00:00
|
|
|
*
|
2008-04-10 13:33:07 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2003-10-06 12:30:52 +00:00
|
|
|
*
|
2008-04-10 13:33:07 +00:00
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
2003-10-06 12:30:52 +00:00
|
|
|
*
|
2008-04-10 13:33:07 +00:00
|
|
|
* OpenOffice.org is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Lesser General Public License version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
2003-10-06 12:30:52 +00:00
|
|
|
*
|
2008-04-10 13:33:07 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2003-10-06 12:30:52 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
package ifc.frame;
|
|
|
|
|
|
|
|
|
|
|
|
import com.sun.star.beans.PropertyValue;
|
|
|
|
import com.sun.star.util.URL;
|
|
|
|
import lib.MultiMethodTest;
|
|
|
|
import lib.Status;
|
|
|
|
import lib.StatusException;
|
|
|
|
import com.sun.star.frame.XNotifyingDispatch;
|
|
|
|
import com.sun.star.frame.DispatchResultEvent;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Testing <code>com.sun.star.frame.XNotifyingDispatch</code>
|
|
|
|
* interface methods :
|
|
|
|
* <ul>
|
|
|
|
* <li><code> dispatchWithNotification()</code></li>
|
|
|
|
* </ul> <p>
|
|
|
|
* This test needs the following object relations :
|
|
|
|
* <ul>
|
|
|
|
* <li> <code>'XDispatch.URL'</code> (of type <code>com.sun.star.util.URL
|
|
|
|
* </code>): URL for passing to <code>dispatch()</code> method. </li>
|
|
|
|
* <li> <code>[OPTIONAL] 'XNotifyingDispatchArgument'</code>
|
|
|
|
* (of type sequence<code>com::sun::star::beans::PropertyValue
|
|
|
|
* </code>): argumets for <code>dispatchWithNotification()</code> method. </li>
|
|
|
|
* <ul> <p>
|
|
|
|
* @see com.sun.star.frame.XDispatch
|
|
|
|
* @see com.sun.star.frame.XNotifyingDispatch
|
|
|
|
* @see ifc.frmae._XDispatch
|
|
|
|
*/
|
|
|
|
public class _XNotifyingDispatch extends MultiMethodTest {
|
|
|
|
|
|
|
|
public XNotifyingDispatch oObj = null;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Listener implementation which sets flags on appropriate method calls
|
|
|
|
*/
|
|
|
|
protected class TestNotificationListener implements
|
|
|
|
com.sun.star.frame.XDispatchResultListener {
|
|
|
|
public boolean disposingCalled = false ;
|
|
|
|
public boolean finishedDispatch = false ;
|
|
|
|
private java.io.PrintWriter log = null ;
|
|
|
|
|
|
|
|
public TestNotificationListener(java.io.PrintWriter log) {
|
|
|
|
this.log = log ;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void disposing(com.sun.star.lang.EventObject e) {
|
|
|
|
disposingCalled = true ;
|
|
|
|
log.println(" disposing was called.") ;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void dispatchFinished( DispatchResultEvent e) {
|
|
|
|
finishedDispatch = true ;
|
|
|
|
log.println(" dispatchFinished was called.") ;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
TestNotificationListener notificationListener = null;
|
|
|
|
PropertyValue[] arguments = null;
|
|
|
|
URL url = null ;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves object relations and creates new listeners.
|
|
|
|
* @throws StatusException If one of relations not found.
|
|
|
|
*/
|
|
|
|
public void before() {
|
|
|
|
notificationListener = new TestNotificationListener(log) ;
|
|
|
|
url = (URL) tEnv.getObjRelation("XDispatch.URL") ;
|
|
|
|
|
|
|
|
if (url == null) throw new StatusException
|
|
|
|
(Status.failed("Relation not found.")) ;
|
|
|
|
|
|
|
|
arguments = (PropertyValue[])
|
|
|
|
tEnv.getObjRelation("XNotifyingDispatchArgument");
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Calls the method using URL and arguments from relation. <p>
|
|
|
|
* Has <b> OK </b> status if listener is called.
|
|
|
|
* The following method tests are to be completed successfully before :
|
|
|
|
*/
|
|
|
|
public void _dispatchWithNotification() {
|
|
|
|
|
|
|
|
boolean result = true ;
|
|
|
|
|
|
|
|
oObj.dispatchWithNotification(url, arguments, notificationListener);
|
|
|
|
|
|
|
|
try {
|
|
|
|
Thread.sleep(200);
|
|
|
|
}
|
|
|
|
catch(java.lang.InterruptedException e) {}
|
|
|
|
|
|
|
|
log.println("Listener called: "+ notificationListener.finishedDispatch);
|
|
|
|
|
|
|
|
result = notificationListener.finishedDispatch;
|
|
|
|
|
|
|
|
|
|
|
|
tRes.tested("dispatchWithNotification()", result) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|