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.linguistic2;
25cdf0e10cSrcweir 
26cdf0e10cSrcweir import lib.MultiMethodTest;
27cdf0e10cSrcweir 
28cdf0e10cSrcweir import com.sun.star.lang.Locale;
29cdf0e10cSrcweir import com.sun.star.linguistic2.XSupportedLocales;
30cdf0e10cSrcweir 
31cdf0e10cSrcweir /**
32cdf0e10cSrcweir * Testing <code>com.sun.star.linguistic2.XSupportedLocales</code>
33cdf0e10cSrcweir * interface methods:
34cdf0e10cSrcweir * <ul>
35cdf0e10cSrcweir *   <li><code>getLocales()</code></li>
36cdf0e10cSrcweir *   <li><code>hasLocale()</code></li>
37cdf0e10cSrcweir * </ul> <p>
38cdf0e10cSrcweir * @see com.sun.star.linguistic2.XSupportedLocales
39cdf0e10cSrcweir */
40cdf0e10cSrcweir public class _XSupportedLocales extends MultiMethodTest {
41cdf0e10cSrcweir 
42cdf0e10cSrcweir     public XSupportedLocales oObj = null;
43cdf0e10cSrcweir     public static Locale[] locales = new Locale[0];
44cdf0e10cSrcweir 
45cdf0e10cSrcweir     /**
46cdf0e10cSrcweir     * Test calls the method, stores returned value and checks it. <p>
47cdf0e10cSrcweir     * Has <b> OK </b> status if length of returned array isn't zero. <p>
48cdf0e10cSrcweir     */
_getLocales()49cdf0e10cSrcweir     public void _getLocales() {
50cdf0e10cSrcweir         locales = oObj.getLocales();
51cdf0e10cSrcweir         tRes.tested("getLocales()", locales.length > 0);
52cdf0e10cSrcweir     }
53cdf0e10cSrcweir 
54cdf0e10cSrcweir     /**
55cdf0e10cSrcweir     * Test calls the method for every language from list of supported languages,
56cdf0e10cSrcweir     * calls the method for one unsupported language and checks
57cdf0e10cSrcweir     * all returned values. <p>
58cdf0e10cSrcweir     * Has <b> OK </b> status if all returned values for supported languages
59cdf0e10cSrcweir     * are equal to true and if returned value for unsupported language is equal
60cdf0e10cSrcweir     * to false. <p>
61cdf0e10cSrcweir     * The following method tests are to be completed successfully before :
62cdf0e10cSrcweir     * <ul>
63cdf0e10cSrcweir     *  <li> <code> getLocales() </code> : to have list of
64cdf0e10cSrcweir     *  all supported languages </li>
65cdf0e10cSrcweir     * </ul>
66cdf0e10cSrcweir     */
_hasLocale()67cdf0e10cSrcweir     public void _hasLocale() {
68cdf0e10cSrcweir         requiredMethod("getLocales()");
69cdf0e10cSrcweir         boolean res = true;
70cdf0e10cSrcweir 
71cdf0e10cSrcweir         // first check all available locales
72cdf0e10cSrcweir         for (int i=0; i< locales.length; i++) {
73cdf0e10cSrcweir             res &= oObj.hasLocale(locales[i]);
74cdf0e10cSrcweir         }
75cdf0e10cSrcweir 
76cdf0e10cSrcweir         // now create a invalid locale
77cdf0e10cSrcweir         Locale invalid = new Locale("myLanguage","myCountry","");
78cdf0e10cSrcweir         res &= !oObj.hasLocale(invalid);
79cdf0e10cSrcweir 
80cdf0e10cSrcweir         tRes.tested("hasLocale()", res);
81cdf0e10cSrcweir     }
82cdf0e10cSrcweir 
83cdf0e10cSrcweir }  // finish class XSupportedLocales
84cdf0e10cSrcweir 
85cdf0e10cSrcweir 
86