org.qi4j.library.sql.datasource.ExternalDataSourceTest.java Source code

Java tutorial

Introduction

Here is the source code for org.qi4j.library.sql.datasource.ExternalDataSourceTest.java

Source

/*
 * Copyright (c) 2012, Paul Merlin. All Rights Reserved.
 *
 * 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.qi4j.library.sql.datasource;

import java.sql.Connection;
import java.sql.SQLException;
import javax.sql.DataSource;
import org.apache.commons.dbcp.BasicDataSource;
import org.junit.Test;
import org.qi4j.api.common.Visibility;
import org.qi4j.bootstrap.AssemblyException;
import org.qi4j.bootstrap.ModuleAssembly;
import org.qi4j.library.sql.assembly.ExternalDataSourceAssembler;
import org.qi4j.library.sql.common.SQLUtil;
import org.qi4j.test.AbstractQi4jTest;

public class ExternalDataSourceTest extends AbstractQi4jTest {

    @Override
    public void assemble(ModuleAssembly module) throws AssemblyException {
        BasicDataSource externalDataSource = new BasicDataSource();
        externalDataSource.setDriverClassName("org.apache.derby.jdbc.EmbeddedDriver");
        externalDataSource.setUrl("jdbc:derby:memory:testdbexternal;create=true");
        // START SNIPPET: assembly
        new ExternalDataSourceAssembler(externalDataSource).visibleIn(Visibility.module)
                .identifiedBy("datasource-external-id")
                .withCircuitBreaker(DataSources.newDataSourceCircuitBreaker()).assemble(module);
        // END SNIPPET: assembly
    }

    @Test
    public void test() throws SQLException {
        DataSource dataSource = module.findService(DataSource.class).get();
        Connection connection = dataSource.getConnection();
        try {
            connection.getMetaData();
        } finally {
            SQLUtil.closeQuietly(connection);
        }
    }

}