/* * Copyright 2012 Charlie Mordant. * * Licensed 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 org.ops4j.pax.jdbc.test.derbyclient; import static org.hamcrest.CoreMatchers.is; import static org.junit.Assume.assumeThat; import static org.ops4j.pax.exam.CoreOptions.options; import java.net.Inet4Address; import java.net.InetAddress; import java.sql.SQLException; import java.util.Properties; import javax.inject.Inject; import org.apache.derby.drda.NetworkServerControl; import org.junit.Rule; import org.junit.Test; import org.junit.rules.ExpectedException; import org.junit.runner.RunWith; import org.ops4j.pax.exam.Configuration; import org.ops4j.pax.exam.Option; import org.ops4j.pax.exam.junit.PaxExam; import org.ops4j.pax.exam.util.Filter; import org.ops4j.pax.jdbc.derbyclient.constants.ClientConnectionConstant; import org.ops4j.pax.jdbc.test.AbstractJdbcTest; import org.ops4j.pax.jdbc.test.ServerConfiguration; import org.osgi.service.jdbc.DataSourceFactory; @RunWith(PaxExam.class) public class DerbyClientNativeDataSourceTest extends AbstractJdbcTest { @Rule public ExpectedException thrown = ExpectedException.none(); @Inject @Filter(value = "(osgi.jdbc.driver.name=derbyclient)") private DataSourceFactory dsf; private ServerConfiguration dbConfig = new ServerConfiguration("derbyclient"); public void startDerbyServer() throws Exception { InetAddress addr = Inet4Address.getByName(dbConfig.getServerName()); Integer port = new Integer(dbConfig.getPortNumber()); NetworkServerControl server = new NetworkServerControl(addr, port); server.start(null); } @Configuration public Option[] config() throws Exception { startDerbyServer(); return options(regressionDefaults(), // mvnBundle("org.apache.derby", "derbyclient"), // mvnBundle("org.ops4j.pax.jdbc", "pax-jdbc-derbyclient") // ); } @Test public void createDataSourceAndConnection() throws SQLException, InterruptedException { Properties props = new Properties(); props.setProperty(DataSourceFactory.JDBC_DATABASE_NAME, dbConfig.getDatabaseName()); props.setProperty(DataSourceFactory.JDBC_USER, dbConfig.getUser()); props.setProperty(DataSourceFactory.JDBC_PASSWORD, dbConfig.getPassword()); props.setProperty(DataSourceFactory.JDBC_PORT_NUMBER, dbConfig.getPortNumberSt()); props.setProperty(DataSourceFactory.JDBC_SERVER_NAME, dbConfig.getServerName()); props.setProperty(ClientConnectionConstant.CREATE_DATABASE, "create"); dsf.createDataSource(props).getConnection().close(); } @Test public void connectWithDefaultPort() throws SQLException { assumeThat(dbConfig.getPortNumber(), is(1527)); Properties props = new Properties(); props.setProperty(DataSourceFactory.JDBC_DATABASE_NAME, dbConfig.getDatabaseName()); props.setProperty(DataSourceFactory.JDBC_USER, dbConfig.getUser()); props.setProperty(DataSourceFactory.JDBC_PASSWORD, dbConfig.getPassword()); props.setProperty(DataSourceFactory.JDBC_SERVER_NAME, dbConfig.getServerName()); props.setProperty(ClientConnectionConstant.CREATE_DATABASE, "create"); dsf.createDataSource(props).getConnection().close(); } @Test public void connectWithDefaultHostAndPort() throws SQLException { assumeThat(dbConfig.getPortNumber(), is(1527)); assumeThat(dbConfig.getServerName(), is("localhost")); Properties props = new Properties(); props.setProperty(DataSourceFactory.JDBC_DATABASE_NAME, dbConfig.getDatabaseName()); props.setProperty(DataSourceFactory.JDBC_USER, dbConfig.getUser()); props.setProperty(DataSourceFactory.JDBC_PASSWORD, dbConfig.getPassword()); props.setProperty(ClientConnectionConstant.CREATE_DATABASE, "create"); dsf.createDataSource(props).getConnection().close(); } }