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
10*ef39d40dSAndrew Rist  *
11*ef39d40dSAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12*ef39d40dSAndrew Rist  *
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.
19*ef39d40dSAndrew Rist  *
20*ef39d40dSAndrew Rist  *************************************************************/
21*ef39d40dSAndrew Rist 
22*ef39d40dSAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir package ifc.util;
25cdf0e10cSrcweir 
26cdf0e10cSrcweir import lib.MultiMethodTest;
27cdf0e10cSrcweir 
28cdf0e10cSrcweir import com.sun.star.util.XModeSelector;
29cdf0e10cSrcweir 
30cdf0e10cSrcweir /**
31cdf0e10cSrcweir * Testing <code>com.sun.star.util.XModeSelector</code>
32cdf0e10cSrcweir * interface methods :
33cdf0e10cSrcweir * <ul>
34cdf0e10cSrcweir *  <li><code>setMode()</code></li>
35cdf0e10cSrcweir *  <li><code>getMode()</code></li>
36cdf0e10cSrcweir *  <li><code>getSupportedModes()</code></li>
37cdf0e10cSrcweir *  <li><code>supportsMode()</code></li>
38cdf0e10cSrcweir * </ul> <p>
39cdf0e10cSrcweir * Test is <b> NOT </b> multithread compilant. <p>
40cdf0e10cSrcweir * @see com.sun.star.util.XModeSelector
41cdf0e10cSrcweir */
42cdf0e10cSrcweir public class _XModeSelector extends MultiMethodTest {
43cdf0e10cSrcweir     public XModeSelector oObj = null;
44cdf0e10cSrcweir 
45cdf0e10cSrcweir     String[] supportedModes;
46cdf0e10cSrcweir     /**
47cdf0e10cSrcweir     * Calls the method and as argument pass one of the supported modes
48cdf0e10cSrcweir     * that was returned by method getSupportedMode.<p>
49cdf0e10cSrcweir     * Has <b> OK </b> status if no runtime exceptions occured.
50cdf0e10cSrcweir     */
_setMode()51cdf0e10cSrcweir     public void _setMode() {
52cdf0e10cSrcweir         requiredMethod("getSupportedModes()");
53cdf0e10cSrcweir         try {
54cdf0e10cSrcweir             oObj.setMode(supportedModes[0]);
55cdf0e10cSrcweir         } catch(com.sun.star.lang.NoSupportException e) {
56cdf0e10cSrcweir             log.println("Method setMode() doesn't support mode '"
57cdf0e10cSrcweir                  + supportedModes[0] + "'");
58cdf0e10cSrcweir             tRes.tested("setMode()", false);
59cdf0e10cSrcweir             return ;
60cdf0e10cSrcweir         }
61cdf0e10cSrcweir         tRes.tested("setMode()", true);
62cdf0e10cSrcweir     }
63cdf0e10cSrcweir 
64cdf0e10cSrcweir     /**
65cdf0e10cSrcweir     * Calls the method and check returned value.<p>
66cdf0e10cSrcweir     * Has <b> OK </b> status if no runtime exceptions occured
67cdf0e10cSrcweir     * and returned value is equal to value that was set by method setMode.
68cdf0e10cSrcweir     */
_getMode()69cdf0e10cSrcweir     public void _getMode() {
70cdf0e10cSrcweir         requiredMethod("setMode()");
71cdf0e10cSrcweir         String curMode = oObj.getMode();
72cdf0e10cSrcweir         tRes.tested("getMode()", curMode.equals(supportedModes[0]));
73cdf0e10cSrcweir     }
74cdf0e10cSrcweir 
75cdf0e10cSrcweir     /**
76cdf0e10cSrcweir     * Calls the method and checks value returned by method.<p>
77cdf0e10cSrcweir     * Has <b> OK </b> status if no runtime exceptions occured
78cdf0e10cSrcweir     * and returned value is not null.
79cdf0e10cSrcweir     */
_getSupportedModes()80cdf0e10cSrcweir     public void _getSupportedModes() {
81cdf0e10cSrcweir         supportedModes = oObj.getSupportedModes();
82cdf0e10cSrcweir         tRes.tested("getSupportedModes()", supportedModes != null);
83cdf0e10cSrcweir     }
84cdf0e10cSrcweir 
85cdf0e10cSrcweir     /**
86cdf0e10cSrcweir     * Calls the method. First  one of the supported modes that was returned
87cdf0e10cSrcweir     * by method getSupportedMode is passed as argument.
88cdf0e10cSrcweir     * Then the method is called again and the mode that is certainly not supported
89cdf0e10cSrcweir     * is passed. Checks up returned values in both cases.<p>
90cdf0e10cSrcweir     * Has <b> OK </b> status if no runtime exceptions occured,
91cdf0e10cSrcweir     * returned value is true in first call and is false in second call.
92cdf0e10cSrcweir     */
_supportsMode()93cdf0e10cSrcweir     public void _supportsMode() {
94cdf0e10cSrcweir         requiredMethod("getSupportedModes()");
95cdf0e10cSrcweir         boolean result = oObj.supportsMode(supportedModes[0]) &&
96cdf0e10cSrcweir             ! oObj.supportsMode(supportedModes[0] + "_ForTest");
97cdf0e10cSrcweir         tRes.tested("supportsMode()", result);
98cdf0e10cSrcweir     }
99cdf0e10cSrcweir }// finish class _XModeSelector
100cdf0e10cSrcweir 
101