/*
* Copyright 2016 Hammock and its contributors
*
* 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 ws.ament.hammock.flyway;
import javax.annotation.sql.DataSourceDefinition;
import javax.enterprise.inject.spi.Extension;
import javax.inject.Inject;
import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import org.assertj.core.api.Assertions;
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.shrinkwrap.api.ShrinkWrap;
import org.jboss.shrinkwrap.api.asset.EmptyAsset;
import org.jboss.shrinkwrap.api.spec.JavaArchive;
import org.junit.Test;
import org.junit.runner.RunWith;
import ws.ament.hammock.jpa.DataSourceDefinitionBuilder;
import ws.ament.hammock.jpa.DataSourceExtension;
import ws.ament.hammock.jpa.Database;
@RunWith(Arquillian.class)
@DataSourceDefinition(name="__default",className = "",url="jdbc:h2:./target/hammocktest")
public class FlywayTest {
@Deployment
public static JavaArchive createDeployment() {
return ShrinkWrap.create(JavaArchive.class)
.addClasses(DataSourceDefinitionBuilder.class)
.addAsManifestResource(EmptyAsset.INSTANCE, "beans.xml")
.addAsServiceProvider(Extension.class, DataSourceExtension.class, FlywayExtension.class);
}
@Inject
@Database("__default")
private DataSource testds;
@Test
public void shouldApplyMigrations() throws Exception{
Connection connection = testds.getConnection();
try(PreparedStatement preparedStatement = connection.prepareStatement("select count(*) from \"schema_version\"");
ResultSet rs = preparedStatement.executeQuery()) {
rs.next();
int anInt = rs.getInt(1);
Assertions.assertThat(anInt).isEqualTo(1);
}
}
}