diff --git a/play-ebean/src/main/java/play/db/ebean/DefaultEbeanConfig.java b/play-ebean/src/main/java/play/db/ebean/DefaultEbeanConfig.java index d121cfc..ccb7186 100644 --- a/play-ebean/src/main/java/play/db/ebean/DefaultEbeanConfig.java +++ b/play-ebean/src/main/java/play/db/ebean/DefaultEbeanConfig.java @@ -24,22 +24,23 @@ /** Ebean server configuration. */ @Singleton public class DefaultEbeanConfig implements EbeanConfig { - private final Boolean ddlGenerate; - private final String defaultServer; private final Map serverConfigs; + private final Boolean generateEvolutionsScripts; + public DefaultEbeanConfig( - Boolean ddlGenerate, String defaultServer, Map serverConfigs) { - this.ddlGenerate = ddlGenerate; + String defaultServer, + Map serverConfigs, + Boolean generateEvolutionsScripts) { this.defaultServer = defaultServer; this.serverConfigs = serverConfigs; + this.generateEvolutionsScripts = generateEvolutionsScripts; } - @Override - public Boolean ddlGenerate() { - return ddlGenerate; + public DefaultEbeanConfig(String defaultServer, Map serverConfigs) { + this(defaultServer, serverConfigs, true); } @Override @@ -52,14 +53,20 @@ public Map serverConfigs() { return serverConfigs; } + @Override + public Boolean generateEvolutionsScripts() { + return generateEvolutionsScripts; + } + @Singleton public static class EbeanConfigParser implements Provider { + private static final Logger.ALogger LOGGER = Logger.of(DefaultEbeanConfig.class); private final Config config; + private final Environment environment; - private final DBApi dbApi; - private static final Logger.ALogger LOGGER = Logger.of(DefaultEbeanConfig.class); + private final DBApi dbApi; @Inject public EbeanConfigParser(Config config, Environment environment, DBApi dbApi) { @@ -109,7 +116,9 @@ public EbeanConfig parse() { } return new DefaultEbeanConfig( - ebeanConfig.getDdlGenerate(), ebeanConfig.getDefaultDatasource(), serverConfigs); + ebeanConfig.getDefaultDatasource(), + serverConfigs, + ebeanConfig.generateEvolutionsScripts()); } private void setServerConfigDataSource(String key, DatabaseConfig serverConfig) { diff --git a/play-ebean/src/main/java/play/db/ebean/EbeanConfig.java b/play-ebean/src/main/java/play/db/ebean/EbeanConfig.java index b1d9ec3..f28bf29 100644 --- a/play-ebean/src/main/java/play/db/ebean/EbeanConfig.java +++ b/play-ebean/src/main/java/play/db/ebean/EbeanConfig.java @@ -8,9 +8,9 @@ import java.util.Map; public interface EbeanConfig { - Boolean ddlGenerate(); - String defaultServer(); Map serverConfigs(); + + Boolean generateEvolutionsScripts(); } diff --git a/play-ebean/src/main/java/play/db/ebean/EbeanDynamicEvolutions.java b/play-ebean/src/main/java/play/db/ebean/EbeanDynamicEvolutions.java index 7a87072..8fda66b 100644 --- a/play-ebean/src/main/java/play/db/ebean/EbeanDynamicEvolutions.java +++ b/play-ebean/src/main/java/play/db/ebean/EbeanDynamicEvolutions.java @@ -64,7 +64,7 @@ public void create() { if (environment.isProd()) { return; } - if (config.ddlGenerate().equals(Boolean.FALSE)) { + if (Boolean.FALSE.equals(config.generateEvolutionsScripts())) { return; } config diff --git a/play-ebean/src/main/java/play/db/ebean/EbeanParsedConfig.java b/play-ebean/src/main/java/play/db/ebean/EbeanParsedConfig.java index 613741c..25631f6 100644 --- a/play-ebean/src/main/java/play/db/ebean/EbeanParsedConfig.java +++ b/play-ebean/src/main/java/play/db/ebean/EbeanParsedConfig.java @@ -16,20 +16,23 @@ * database connection pools to create. */ public class EbeanParsedConfig { - - private final Boolean ddlGenerate; private final String defaultDatasource; + private final Map> datasourceModels; + private final Boolean generateEvolutionsScripts; + public EbeanParsedConfig( - Boolean ddlGenerate, String defaultDatasource, Map> datasourceModels) { - this.ddlGenerate = ddlGenerate; + String defaultDatasource, + Map> datasourceModels, + Boolean generateEvolutionsScripts) { this.defaultDatasource = defaultDatasource; this.datasourceModels = datasourceModels; + this.generateEvolutionsScripts = generateEvolutionsScripts; } - public Boolean getDdlGenerate() { - return ddlGenerate; + public EbeanParsedConfig(String defaultDatasource, Map> datasourceModels) { + this(defaultDatasource, datasourceModels, true); } public String getDefaultDatasource() { @@ -40,6 +43,10 @@ public Map> getDatasourceModels() { return datasourceModels; } + public Boolean generateEvolutionsScripts() { + return generateEvolutionsScripts; + } + /** * Parse a play configuration. * @@ -50,8 +57,9 @@ public Map> getDatasourceModels() { public static EbeanParsedConfig parseFromConfig(Config config) { Config playEbeanConfig = config.getConfig("play.ebean"); String ebeanConfigKey = playEbeanConfig.getString("config"); - Boolean ebeanDdlGenerateKey = playEbeanConfig.getBoolean("ddlGenerate"); - String ebeanDefaultDatasourceKey = playEbeanConfig.getString("defaultDatasource"); + String ebeanDefaultDatasource = playEbeanConfig.getString("defaultDatasource"); + Boolean ebeanGenerateEvolutionsScripts = + playEbeanConfig.getBoolean("generateEvolutionsScripts"); Map> datasourceModels = new HashMap<>(); @@ -72,6 +80,7 @@ public static EbeanParsedConfig parseFromConfig(Config config) { datasourceModels.put(key, models); }); } - return new EbeanParsedConfig(ebeanDdlGenerateKey, ebeanDefaultDatasourceKey, datasourceModels); + return new EbeanParsedConfig( + ebeanDefaultDatasource, datasourceModels, ebeanGenerateEvolutionsScripts); } } diff --git a/play-ebean/src/main/resources/reference.conf b/play-ebean/src/main/resources/reference.conf index e286490..dfce38b 100644 --- a/play-ebean/src/main/resources/reference.conf +++ b/play-ebean/src/main/resources/reference.conf @@ -7,10 +7,10 @@ play { # The key for ebean config config = "ebean" - # The key to control the generation of the evolution SQL files - ddlGenerate = true - # The name of the default ebean datasource defaultDatasource = "default" + + # The key to control the generation of the Evolutions scripts + generateEvolutionsScripts = true } } diff --git a/play-ebean/src/test/java/play/db/ebean/EbeanParsedConfigTest.java b/play-ebean/src/test/java/play/db/ebean/EbeanParsedConfigTest.java index 9448eb0..fd89969 100644 --- a/play-ebean/src/test/java/play/db/ebean/EbeanParsedConfigTest.java +++ b/play-ebean/src/test/java/play/db/ebean/EbeanParsedConfigTest.java @@ -24,9 +24,9 @@ private EbeanParsedConfig parse(Map config) { @Test public void defaultConfig() { EbeanParsedConfig config = parse(Collections.emptyMap()); - assertThat(config.getDdlGenerate(), equalTo(Boolean.TRUE)); assertThat(config.getDefaultDatasource(), equalTo("default")); assertThat(config.getDatasourceModels().size(), equalTo(0)); + assertThat(config.generateEvolutionsScripts(), equalTo(Boolean.TRUE)); } @Test @@ -54,9 +54,10 @@ public void customDefault() { } @Test - public void disableDdlGenerate() { - EbeanParsedConfig config = parse(ImmutableMap.of("play.ebean.ddlGenerate", false)); - assertThat(config.getDdlGenerate(), equalTo(Boolean.FALSE)); + public void disableGenerateEvolutionsScripts() { + EbeanParsedConfig config = + parse(ImmutableMap.of("play.ebean.generateEvolutionsScripts", false)); + assertThat(config.generateEvolutionsScripts(), equalTo(Boolean.FALSE)); } @Test