1 /*************************************************************************
2  *
3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4  *
5  * Copyright 2000, 2010 Oracle and/or its affiliates.
6  *
7  * OpenOffice.org - a multi-platform office productivity suite
8  *
9  * This file is part of OpenOffice.org.
10  *
11  * OpenOffice.org is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License version 3
13  * only, as published by the Free Software Foundation.
14  *
15  * OpenOffice.org is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU Lesser General Public License version 3 for more details
19  * (a copy is included in the LICENSE file that accompanied this code).
20  *
21  * You should have received a copy of the GNU Lesser General Public License
22  * version 3 along with OpenOffice.org.  If not, see
23  * <http://www.openoffice.org/license.html>
24  * for a copy of the LGPLv3 License.
25  *
26  ************************************************************************/
27 
28 package ifc.linguistic2;
29 
30 import lib.MultiMethodTest;
31 
32 import com.sun.star.lang.Locale;
33 import com.sun.star.linguistic2.XSupportedLocales;
34 
35 /**
36 * Testing <code>com.sun.star.linguistic2.XSupportedLocales</code>
37 * interface methods:
38 * <ul>
39 *   <li><code>getLocales()</code></li>
40 *   <li><code>hasLocale()</code></li>
41 * </ul> <p>
42 * @see com.sun.star.linguistic2.XSupportedLocales
43 */
44 public class _XSupportedLocales extends MultiMethodTest {
45 
46     public XSupportedLocales oObj = null;
47     public static Locale[] locales = new Locale[0];
48 
49     /**
50     * Test calls the method, stores returned value and checks it. <p>
51     * Has <b> OK </b> status if length of returned array isn't zero. <p>
52     */
53     public void _getLocales() {
54         locales = oObj.getLocales();
55         tRes.tested("getLocales()", locales.length > 0);
56     }
57 
58     /**
59     * Test calls the method for every language from list of supported languages,
60     * calls the method for one unsupported language and checks
61     * all returned values. <p>
62     * Has <b> OK </b> status if all returned values for supported languages
63     * are equal to true and if returned value for unsupported language is equal
64     * to false. <p>
65     * The following method tests are to be completed successfully before :
66     * <ul>
67     *  <li> <code> getLocales() </code> : to have list of
68     *  all supported languages </li>
69     * </ul>
70     */
71     public void _hasLocale() {
72         requiredMethod("getLocales()");
73         boolean res = true;
74 
75         // first check all available locales
76         for (int i=0; i< locales.length; i++) {
77             res &= oObj.hasLocale(locales[i]);
78         }
79 
80         // now create a invalid locale
81         Locale invalid = new Locale("myLanguage","myCountry","");
82         res &= !oObj.hasLocale(invalid);
83 
84         tRes.tested("hasLocale()", res);
85     }
86 
87 }  // finish class XSupportedLocales
88 
89 
90