/* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * 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 . */ 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. */ @Override 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); } }