1*ef39d40dSAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*ef39d40dSAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*ef39d40dSAndrew Rist * or more contributor license agreements. See the NOTICE file 5*ef39d40dSAndrew Rist * distributed with this work for additional information 6*ef39d40dSAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*ef39d40dSAndrew Rist * to you under the Apache License, Version 2.0 (the 8*ef39d40dSAndrew Rist * "License"); you may not use this file except in compliance 9*ef39d40dSAndrew Rist * with the License. You may obtain a copy of the License at 10cdf0e10cSrcweir * 11*ef39d40dSAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12cdf0e10cSrcweir * 13*ef39d40dSAndrew Rist * Unless required by applicable law or agreed to in writing, 14*ef39d40dSAndrew Rist * software distributed under the License is distributed on an 15*ef39d40dSAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*ef39d40dSAndrew Rist * KIND, either express or implied. See the License for the 17*ef39d40dSAndrew Rist * specific language governing permissions and limitations 18*ef39d40dSAndrew Rist * under the License. 19cdf0e10cSrcweir * 20*ef39d40dSAndrew Rist *************************************************************/ 21*ef39d40dSAndrew Rist 22*ef39d40dSAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir package ifc.ui.dialogs; 25cdf0e10cSrcweir 26cdf0e10cSrcweir import lib.MultiMethodTest; 27cdf0e10cSrcweir import lib.Status; 28cdf0e10cSrcweir import lib.StatusException; 29cdf0e10cSrcweir 30cdf0e10cSrcweir import com.sun.star.lang.EventObject; 31cdf0e10cSrcweir import com.sun.star.lang.XMultiServiceFactory; 32cdf0e10cSrcweir import com.sun.star.ui.dialogs.FilePickerEvent; 33cdf0e10cSrcweir import com.sun.star.ui.dialogs.XExecutableDialog; 34cdf0e10cSrcweir import com.sun.star.ui.dialogs.XFilePicker; 35cdf0e10cSrcweir import com.sun.star.ui.dialogs.XFilePickerListener; 36cdf0e10cSrcweir import com.sun.star.ui.dialogs.XFilePickerNotifier; 37cdf0e10cSrcweir import com.sun.star.uno.UnoRuntime; 38cdf0e10cSrcweir import com.sun.star.util.XCancellable; 39cdf0e10cSrcweir 40cdf0e10cSrcweir 41cdf0e10cSrcweir /** 42cdf0e10cSrcweir * Testing <code>com.sun.star.ui.XFilePickerNotifier</code> 43cdf0e10cSrcweir * interface methods : 44cdf0e10cSrcweir * <ul> 45cdf0e10cSrcweir * <li><code> addFilePickerListener()</code></li> 46cdf0e10cSrcweir * <li><code> removeFilePickerListener()</code></li> 47cdf0e10cSrcweir * </ul> <p> 48cdf0e10cSrcweir * The object must implement <code>XFilePicker</code> 49cdf0e10cSrcweir * interface to check if a listener was called. <p> 50cdf0e10cSrcweir * Test is <b> NOT </b> multithread compilant. <p> 51cdf0e10cSrcweir * @see com.sun.star.ui.XFilePickerNotifier 52cdf0e10cSrcweir */ 53cdf0e10cSrcweir public class _XFilePickerNotifier extends MultiMethodTest { 54cdf0e10cSrcweir 55cdf0e10cSrcweir public XFilePickerNotifier oObj = null; 56cdf0e10cSrcweir private XFilePicker fps = null ; 57cdf0e10cSrcweir private String dir1 = null, 58cdf0e10cSrcweir dir2 = null ; 59cdf0e10cSrcweir ExecThread eThread = null; 60cdf0e10cSrcweir 61cdf0e10cSrcweir 62cdf0e10cSrcweir /** 63cdf0e10cSrcweir * Listener implementation which sets a flag if some of its 64cdf0e10cSrcweir * methods was called. 65cdf0e10cSrcweir */ 66cdf0e10cSrcweir protected class TestListener implements XFilePickerListener { 67cdf0e10cSrcweir public boolean called = false ; 68cdf0e10cSrcweir dialogSizeChanged()69cdf0e10cSrcweir public void dialogSizeChanged() { 70cdf0e10cSrcweir called = true; 71cdf0e10cSrcweir } 72cdf0e10cSrcweir fileSelectionChanged(FilePickerEvent e)73cdf0e10cSrcweir public void fileSelectionChanged(FilePickerEvent e) { 74cdf0e10cSrcweir called = true; 75cdf0e10cSrcweir } 76cdf0e10cSrcweir directoryChanged(FilePickerEvent e)77cdf0e10cSrcweir public void directoryChanged(FilePickerEvent e) { 78cdf0e10cSrcweir log.println("***** Directory Changed *****"); 79cdf0e10cSrcweir called = true; 80cdf0e10cSrcweir } 81cdf0e10cSrcweir helpRequested(FilePickerEvent e)82cdf0e10cSrcweir public String helpRequested(FilePickerEvent e) { 83cdf0e10cSrcweir called = true; 84cdf0e10cSrcweir return "help"; 85cdf0e10cSrcweir } 86cdf0e10cSrcweir controlStateChanged(FilePickerEvent e)87cdf0e10cSrcweir public void controlStateChanged(FilePickerEvent e) { 88cdf0e10cSrcweir called = true; 89cdf0e10cSrcweir } 90cdf0e10cSrcweir disposing(EventObject e)91cdf0e10cSrcweir public void disposing(EventObject e) {} 92cdf0e10cSrcweir } 93cdf0e10cSrcweir 94cdf0e10cSrcweir TestListener listener = new TestListener() ; 95cdf0e10cSrcweir 96cdf0e10cSrcweir /** 97cdf0e10cSrcweir * Tries to query object for <code>XFilePicker</code> interface, and 98cdf0e10cSrcweir * initializes two different URLs for changing file picker directory. <p> 99cdf0e10cSrcweir * @throw StatusException If object doesn't support <code>XFilePicker</code> 100cdf0e10cSrcweir * interface. 101cdf0e10cSrcweir */ before()102cdf0e10cSrcweir public void before() { 103cdf0e10cSrcweir fps = (XFilePicker) UnoRuntime.queryInterface 104cdf0e10cSrcweir (XFilePicker.class, oObj) ; 105cdf0e10cSrcweir 106cdf0e10cSrcweir if (fps == null) { 107cdf0e10cSrcweir log.println("The object doesnt implement XFilePicker") ; 108cdf0e10cSrcweir throw new StatusException(Status.failed 109cdf0e10cSrcweir ("The object doesnt implement XFilePicker")); 110cdf0e10cSrcweir } 111cdf0e10cSrcweir 112cdf0e10cSrcweir XExecutableDialog exD = (XExecutableDialog) UnoRuntime.queryInterface( 113cdf0e10cSrcweir XExecutableDialog.class, tEnv.getTestObject()); 114cdf0e10cSrcweir 115cdf0e10cSrcweir dir1 = util.utils.getOfficeTemp((XMultiServiceFactory)tParam.getMSF()); 116cdf0e10cSrcweir dir2 = util.utils.getFullTestURL(""); 117cdf0e10cSrcweir eThread = new ExecThread(exD); 118cdf0e10cSrcweir } 119cdf0e10cSrcweir 120cdf0e10cSrcweir /** 121cdf0e10cSrcweir * Adds a listener, then tries to change display directory and 122cdf0e10cSrcweir * checks if the listener was called. <p> 123cdf0e10cSrcweir * Has <b>OK</b> status if a listener method was called. 124cdf0e10cSrcweir */ _addFilePickerListener()125cdf0e10cSrcweir public void _addFilePickerListener() { 126cdf0e10cSrcweir oObj.addFilePickerListener(listener) ; 127cdf0e10cSrcweir 128cdf0e10cSrcweir try { 129cdf0e10cSrcweir log.println("***** Setting DisplayDirectory to " + dir1); 130cdf0e10cSrcweir fps.setDisplayDirectory(dir1) ; 131cdf0e10cSrcweir log.println("***** Getting: " + fps.getDisplayDirectory()); 132cdf0e10cSrcweir openDialog(); 133cdf0e10cSrcweir log.println("***** Setting DisplayDirectory to " + dir2); 134cdf0e10cSrcweir fps.setDisplayDirectory(dir2) ; 135cdf0e10cSrcweir log.println("***** Getting: " + fps.getDisplayDirectory()); 136cdf0e10cSrcweir 137cdf0e10cSrcweir } catch(com.sun.star.lang.IllegalArgumentException e) { 138cdf0e10cSrcweir log.println("!!! Exception changing dir !!!") ; 139cdf0e10cSrcweir e.printStackTrace(log) ; 140cdf0e10cSrcweir } 141cdf0e10cSrcweir 142cdf0e10cSrcweir shortWait(); 143cdf0e10cSrcweir 144cdf0e10cSrcweir if (!listener.called) { 145cdf0e10cSrcweir log.println("Listener wasn't called :-("); 146cdf0e10cSrcweir } 147cdf0e10cSrcweir 148cdf0e10cSrcweir closeDialog(); 149cdf0e10cSrcweir 150cdf0e10cSrcweir tRes.tested("addFilePickerListener()", listener.called) ; 151cdf0e10cSrcweir } 152cdf0e10cSrcweir 153cdf0e10cSrcweir /** 154cdf0e10cSrcweir * Removes the listener and changes display directory. <p> 155cdf0e10cSrcweir * Has <b>OK</b> status if the listener wasn't called. <p> 156cdf0e10cSrcweir * The following method tests are to be completed successfully before : 157cdf0e10cSrcweir * <ul> 158cdf0e10cSrcweir * <li> <code> addFilePickerListener </code> </li> 159cdf0e10cSrcweir * </ul> 160cdf0e10cSrcweir */ _removeFilePickerListener()161cdf0e10cSrcweir public void _removeFilePickerListener() { 162cdf0e10cSrcweir requiredMethod("addFilePickerListener()") ; 163cdf0e10cSrcweir 164cdf0e10cSrcweir oObj.removeFilePickerListener(listener) ; 165cdf0e10cSrcweir 166cdf0e10cSrcweir listener.called = false ; 167cdf0e10cSrcweir 168cdf0e10cSrcweir try { 169cdf0e10cSrcweir fps.setDisplayDirectory(dir1) ; 170cdf0e10cSrcweir openDialog(); 171cdf0e10cSrcweir fps.setDisplayDirectory(dir2) ; 172cdf0e10cSrcweir } catch(com.sun.star.lang.IllegalArgumentException e) { 173cdf0e10cSrcweir log.println("!!! Exception changing dir !!!") ; 174cdf0e10cSrcweir e.printStackTrace(log) ; 175cdf0e10cSrcweir } 176cdf0e10cSrcweir 177cdf0e10cSrcweir shortWait(); 178cdf0e10cSrcweir 179cdf0e10cSrcweir closeDialog(); 180cdf0e10cSrcweir 181cdf0e10cSrcweir tRes.tested("removeFilePickerListener()", !listener.called) ; 182cdf0e10cSrcweir } 183cdf0e10cSrcweir 184cdf0e10cSrcweir /** 185cdf0e10cSrcweir * Calls <code>execute()</code> method in a separate thread. 186cdf0e10cSrcweir * Necessary to check if this method works 187cdf0e10cSrcweir */ 188cdf0e10cSrcweir protected class ExecThread extends Thread { 189cdf0e10cSrcweir 190cdf0e10cSrcweir public short execRes = (short) 17 ; 191cdf0e10cSrcweir private XExecutableDialog Diag = null ; 192cdf0e10cSrcweir ExecThread(XExecutableDialog Diag)193cdf0e10cSrcweir public ExecThread(XExecutableDialog Diag) { 194cdf0e10cSrcweir this.Diag = Diag ; 195cdf0e10cSrcweir } 196cdf0e10cSrcweir run()197cdf0e10cSrcweir public void run() { 198cdf0e10cSrcweir try { 199cdf0e10cSrcweir execRes = Diag.execute(); 200cdf0e10cSrcweir System.out.println("HERE: "+execRes); 201cdf0e10cSrcweir } catch (Exception e) { 202cdf0e10cSrcweir log.println("Thread has been interrupted ..."); 203cdf0e10cSrcweir } 204cdf0e10cSrcweir } 205cdf0e10cSrcweir } 206cdf0e10cSrcweir 207cdf0e10cSrcweir /** 208cdf0e10cSrcweir * Sleeps for 0.5 sec. to allow StarOffice to react on <code> 209cdf0e10cSrcweir * reset</code> call. 210cdf0e10cSrcweir */ shortWait()211cdf0e10cSrcweir private void shortWait() { 212cdf0e10cSrcweir try { 213cdf0e10cSrcweir Thread.sleep(2000) ; 214cdf0e10cSrcweir } catch (InterruptedException e) { 215cdf0e10cSrcweir log.println("While waiting :" + e) ; 216cdf0e10cSrcweir } 217cdf0e10cSrcweir } 218cdf0e10cSrcweir closeDialog()219cdf0e10cSrcweir private void closeDialog() { 220cdf0e10cSrcweir XCancellable canc = (XCancellable) UnoRuntime.queryInterface( 221cdf0e10cSrcweir XCancellable.class, tEnv.getTestObject()); 222cdf0e10cSrcweir if (canc != null) { 223cdf0e10cSrcweir log.println("Cancelling Dialog"); 224cdf0e10cSrcweir canc.cancel(); 225cdf0e10cSrcweir } else { 226cdf0e10cSrcweir this.disposeEnvironment(); 227cdf0e10cSrcweir } 228cdf0e10cSrcweir 229cdf0e10cSrcweir long st = System.currentTimeMillis(); 230cdf0e10cSrcweir boolean toLong = false; 231cdf0e10cSrcweir 232cdf0e10cSrcweir log.println("waiting for dialog to close"); 233cdf0e10cSrcweir 234cdf0e10cSrcweir while (eThread.isAlive() && !toLong) { 235cdf0e10cSrcweir //wait for dialog to close 236cdf0e10cSrcweir toLong = (System.currentTimeMillis()-st > 10000); 237cdf0e10cSrcweir } 238cdf0e10cSrcweir 239cdf0e10cSrcweir log.println("done"); 240cdf0e10cSrcweir 241cdf0e10cSrcweir try { 242cdf0e10cSrcweir if (eThread.isAlive()) { 243cdf0e10cSrcweir log.println("Interrupting Thread"); 244cdf0e10cSrcweir eThread.interrupt(); 245cdf0e10cSrcweir eThread.yield(); 246cdf0e10cSrcweir } 247cdf0e10cSrcweir } catch (Exception e) { 248cdf0e10cSrcweir // who cares ;-) 249cdf0e10cSrcweir } 250cdf0e10cSrcweir 251cdf0e10cSrcweir st = System.currentTimeMillis(); 252cdf0e10cSrcweir toLong = false; 253cdf0e10cSrcweir 254cdf0e10cSrcweir log.println("waiting for interruption to work"); 255cdf0e10cSrcweir 256cdf0e10cSrcweir while (eThread.isAlive() && !toLong) { 257cdf0e10cSrcweir //wait for dialog to close 258cdf0e10cSrcweir toLong = (System.currentTimeMillis()-st > 10000); 259cdf0e10cSrcweir } 260cdf0e10cSrcweir 261cdf0e10cSrcweir log.println("DialogThread alive: "+eThread.isAlive()); 262cdf0e10cSrcweir 263cdf0e10cSrcweir log.println("done"); 264cdf0e10cSrcweir 265cdf0e10cSrcweir } 266cdf0e10cSrcweir openDialog()267cdf0e10cSrcweir private void openDialog() { 268cdf0e10cSrcweir log.println("Starting Dialog"); 269cdf0e10cSrcweir if (eThread.isAlive()) { 270cdf0e10cSrcweir log.println("second interrupt"); 271cdf0e10cSrcweir eThread.interrupt(); 272cdf0e10cSrcweir eThread.yield(); 273cdf0e10cSrcweir } 274cdf0e10cSrcweir 275cdf0e10cSrcweir XExecutableDialog exD = (XExecutableDialog) UnoRuntime.queryInterface( 276cdf0e10cSrcweir XExecutableDialog.class, tEnv.getTestObject()); 277cdf0e10cSrcweir 278cdf0e10cSrcweir dir1 = util.utils.getOfficeTemp((XMultiServiceFactory)tParam.getMSF()); 279cdf0e10cSrcweir dir2 = util.utils.getFullTestURL(""); 280cdf0e10cSrcweir eThread = new ExecThread(exD); 281cdf0e10cSrcweir 282cdf0e10cSrcweir eThread.start(); 283cdf0e10cSrcweir } 284cdf0e10cSrcweir } 285cdf0e10cSrcweir 286cdf0e10cSrcweir 287