Java tutorial
/** * The MIT License * * Original work sponsored and donated by National Board of e-Health (NSI), Denmark (http://www.nsi.dk) * * Copyright (C) 2011 National Board of e-Health (NSI), Denmark (http://www.nsi.dk) * * Permission is hereby granted, free of charge, to any person obtaining a copy of * this software and associated documentation files (the "Software"), to deal in * the Software without restriction, including without limitation the rights to * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies * of the Software, and to permit persons to whom the Software is furnished to do * so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all * copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ package dk.nsi.minlog.test; import static java.lang.System.getProperty; import java.io.File; import java.util.ArrayList; import javax.sql.DataSource; import org.springframework.beans.factory.config.PropertyPlaceholderConfigurer; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.DependsOn; import org.springframework.core.io.ClassPathResource; import org.springframework.core.io.FileSystemResource; import org.springframework.core.io.Resource; import org.springframework.jdbc.datasource.DataSourceTransactionManager; import org.springframework.jdbc.datasource.DriverManagerDataSource; import org.springframework.transaction.PlatformTransactionManager; import org.springframework.transaction.annotation.EnableTransactionManagement; import org.springframework.transaction.annotation.TransactionManagementConfigurer; import com.avaje.ebean.config.ServerConfig; import com.avaje.ebean.springsupport.factory.EbeanServerFactoryBean; import com.avaje.ebean.springsupport.txn.SpringAwareJdbcTransactionManager; import com.googlecode.flyway.core.Flyway; import dk.nsi.minlog.domain.LogEntry; /** * Creates an embedded mysql server process to run tests against. * * @author kpi * */ @Configuration @EnableTransactionManagement @ComponentScan({ "dk.nsi.minlog.ws.dao.ebean" }) public class TestDBConfig implements TransactionManagementConfigurer { public static String JAVA_IO_TMPDIR = "java.io.tmpdir"; @Bean public static PropertyPlaceholderConfigurer configuration() { final PropertyPlaceholderConfigurer props = new PropertyPlaceholderConfigurer(); props.setLocations(new Resource[] { new ClassPathResource("default.properties"), new FileSystemResource(getProperty("jboss.server.config.url") + "minlog." + getProperty("user.name") + ".properties"), new ClassPathResource("minlog." + getProperty("user.name") + ".properties"), new ClassPathResource("jdbc.default.properties"), new FileSystemResource(getProperty("jboss.server.config.url") + "jdbc." + getProperty("user.name") + ".properties"), new ClassPathResource("jdbc." + getProperty("user.name") + ".properties"), new FileSystemResource(getProperty("user.home") + "/.minlog/passwords.properties") }); props.setIgnoreResourceNotFound(true); props.setSystemPropertiesMode(PropertyPlaceholderConfigurer.SYSTEM_PROPERTIES_MODE_OVERRIDE); return props; } @Bean public File getDatabaseDir() { File ourAppDir = new File(System.getProperty(JAVA_IO_TMPDIR)); File databaseDir = new File(ourAppDir, "min-log-test"); return databaseDir; } @Bean public DataSource dataSource() { final DriverManagerDataSource dataSource = new DriverManagerDataSource("jdbc:mysql:mxj:///minlog" + "?server.basedir=" + getDatabaseDir() + "&createDatabaseIfNotExist=true", "root", ""); dataSource.setDriverClassName("com.mysql.jdbc.Driver"); return dataSource; } @Bean public PlatformTransactionManager txManager() { return new DataSourceTransactionManager(dataSource()); } @Override public PlatformTransactionManager annotationDrivenTransactionManager() { return txManager(); } @Bean public Flyway flyway(DataSource dataSource) { Flyway flyway = new Flyway(); flyway.setDisableInitCheck(true); flyway.setDataSource(dataSource); return flyway; } @Bean @DependsOn("flyway") public EbeanServerFactoryBean ebeanServer(DataSource dataSource) throws Exception { final EbeanServerFactoryBean factoryBean = new EbeanServerFactoryBean(); final ServerConfig serverConfig = new ServerConfig(); final ArrayList<Class<?>> classes = new ArrayList<Class<?>>(); classes.add(LogEntry.class); serverConfig.setName("localhostConfig"); serverConfig.setClasses(classes); serverConfig.setDataSource(dataSource); serverConfig.setNamingConvention(new com.avaje.ebean.config.MatchingNamingConvention()); serverConfig.setExternalTransactionManager(new SpringAwareJdbcTransactionManager()); factoryBean.setServerConfig(serverConfig); return factoryBean; } }