/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ package ifc.sdbc; import lib.MultiMethodTest; import lib.Status; import lib.StatusException; import com.sun.star.beans.PropertyValue; import com.sun.star.sdbc.XConnection; import com.sun.star.sdbc.XDriverManager; /** * Testing com.sun.star.sdbc.XDriverManager * interface methods : *

* Required object relations : *

* @see com.sun.star.sdbc.XDriverManager */ public class _XDriverManager extends MultiMethodTest { // oObj filled by MultiMethodTest public XDriverManager oObj = null; String sdbcURL = null; String jdbcURL = null; PropertyValue[] jdbcINFO = null; /** * Retrieves the required object relations. */ protected void before() { sdbcURL = (String)tEnv.getObjRelation("SDBC.URL"); if (sdbcURL == null) { throw new StatusException( Status.failed("Couldn't get relation 'SDBC.URL'")); } jdbcURL = (String)tEnv.getObjRelation("JDBC.URL"); if (jdbcURL == null) { throw new StatusException( Status.failed("Couldn't get relation 'JDBC.URL'")); } jdbcINFO = (PropertyValue[])tEnv.getObjRelation("JDBC.INFO"); if (jdbcINFO == null) { throw new StatusException( Status.failed("Couldn't get relation 'JDBC.INFO'")); } } /** * Calls the method with the url received from the relation * SDBC.URL. * Has OK status if exception wasn't thrown and * if returned value isn't null. */ public void _getConnection() { boolean res = true; try { log.println("getConnection(" + sdbcURL + ")"); XConnection connection = oObj.getConnection(sdbcURL); res = connection != null; } catch(com.sun.star.sdbc.SQLException e) { log.println("Unexpected exception"); e.printStackTrace(log); res = false; } tRes.tested("getConnection()", res); } /** * Calls the method with the url received from the relation * JDBC.URL and with info received from the relation * JDBC.INFO. * Has OK status if exception wasn't thrown and * if returned value isn't null. */ public void _getConnectionWithInfo() { boolean res = true; try { log.println("getConnectionWithInfo(" + jdbcURL + ")"); XConnection connection = oObj.getConnectionWithInfo(jdbcURL, jdbcINFO); res = connection != null; } catch(com.sun.star.sdbc.SQLException e) { log.println("Unexpected exception"); e.printStackTrace(log); res = false; } tRes.tested("getConnectionWithInfo()", res); } /** * Calls the method and checks returned value. * Has OK status if timeout that was set and timeout that was returned by * the method getLoginTimeout() are equal. */ public void _setLoginTimeout() { requiredMethod("getLoginTimeout()"); final int TO = 111; log.println("setLoginTimeout(" + TO + ")"); oObj.setLoginTimeout(TO); int timeout = oObj.getLoginTimeout(); log.println("getLoginTimeout(): " + timeout); tRes.tested("setLoginTimeout()", timeout == TO); } /** * Calls the method. */ public void _getLoginTimeout() { int timeout = oObj.getLoginTimeout(); log.println("getLoginTimeout(): " + timeout); tRes.tested("getLoginTimeout()", true); } }