/*
* Copyright 2016 Vincenzo Mazzeo.
*
* 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.hsqldb;
import static org.ops4j.pax.exam.CoreOptions.options;
import java.sql.SQLException;
import java.util.Properties;
import javax.inject.Inject;
import org.junit.Test;
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.test.AbstractJdbcTest;
import org.ops4j.pax.jdbc.test.ServerConfiguration;
import org.osgi.service.jdbc.DataSourceFactory;
@RunWith(PaxExam.class)
public class HsqldbDataSourceTest extends AbstractJdbcTest {
@Inject
@Filter("(osgi.jdbc.driver.class=org.hsqldb.jdbc.JDBCDriver)")
private DataSourceFactory dsf;
@Configuration
public Option[] config() {
return options(regressionDefaults(), //
mvnBundle("org.ops4j.pax.jdbc", "pax-jdbc"), //
mvnBundle("org.ops4j.pax.jdbc", "pax-jdbc-hsqldb"), //
mvnBundle("org.hsqldb", "hsqldb") //
);
}
@Test
public void createDataSourceAndConnection() throws SQLException {
ServerConfiguration config = new ServerConfiguration("hsqldb");
Properties props = new Properties();
props.setProperty(DataSourceFactory.JDBC_URL, "jdbc:hsqldb:mem:.");
props.setProperty(DataSourceFactory.JDBC_USER, config.getUser());
props.setProperty(DataSourceFactory.JDBC_PASSWORD, config.getPassword());
dsf.createDataSource(props).getConnection().close();
}
}