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 mod._odbc;
29 
30 import java.io.PrintWriter;
31 
32 import lib.Status;
33 import lib.StatusException;
34 import lib.TestCase;
35 import lib.TestEnvironment;
36 import lib.TestParameters;
37 
38 import com.sun.star.beans.PropertyValue;
39 import com.sun.star.lang.XMultiServiceFactory;
40 import com.sun.star.uno.XInterface;
41 
42 /**
43  * Here <code>com.sun.star.sdbc.Driver</code> service is tested.<p>
44  * Test allows to run object tests in several threads concurently.
45  * @see com.sun.star.sdbc.Driver
46  * @see com.sun.star.sdbc.XDriver
47  * @see ifc.sdbc._XDriver
48  */
49 public class ODBCDriver extends TestCase {
50     /**
51      * Creates an instance of the service
52      * <code>com.sun.star.sdbc.Driver</code>. <p>
53      * Object relations created :
54      * <ul>
55      *  <li> <code>'XDriver.URL'</code> for {@link ifc.sdbc._XDriver}:
56      *      is the URL of the database to which to connect.
57      *      The URL is obtained from the parameter <code>odbc.url</code></li>
58      *  <li> <code>'XDriver.UNSUITABLE_URL'</code> for {@link ifc.sdbc._XDriver}:
59      *      the wrong kind of URL to connect using given driver.
60      *      The URL is obtained from the parameter <code>jdbc.url</code></li>
61      *  <li> <code>'XDriver.INFO'</code> for {@link ifc.sdbc._XDriver}:
62      *      a list of arbitrary string tag/value pairs as connection arguments.
63      *      </li>
64      * </ul>
65      */
66     protected synchronized TestEnvironment createTestEnvironment(TestParameters Param, PrintWriter log) {
67 
68         XInterface oObj = null;
69 
70         try {
71             oObj = (XInterface)((XMultiServiceFactory)Param.getMSF()).createInstance(
72                 "com.sun.star.comp.sdbc.ODBCDriver");
73         } catch (com.sun.star.uno.Exception e) {
74             e.printStackTrace(log);
75             throw new StatusException(Status.failed("Couldn't create object"));
76         }
77 
78         log.println("creating a new environment for ODBCDriver object");
79         TestEnvironment tEnv = new TestEnvironment(oObj);
80 
81         //adding relation for sdbc.XDriver
82         String odbcURL = (String) Param.get("odbc.url");
83         if (odbcURL == null) {
84             throw new StatusException(Status.failed(
85                 "Couldn't get 'odbc.url' from ini-file"));
86         }
87         tEnv.addObjRelation("XDriver.URL", "sdbc:odbc:" + odbcURL);
88 
89         PropertyValue[] info = new PropertyValue[0];
90         tEnv.addObjRelation("XDriver.INFO", info);
91 
92         String jdbcUrl = (String) Param.get("jdbc.url");
93         if (jdbcUrl == null) {
94             throw new StatusException(Status.failed(
95                 "Couldn't get 'jdbc.url' from ini-file"));
96         }
97         tEnv.addObjRelation("XDriver.UNSUITABLE_URL", "jdbc:" + jdbcUrl);
98 
99         return tEnv;
100     }
101 }
102