package io.ebean.config.dbplatform; import io.ebean.config.DbTypeConfig; import io.ebean.config.ServerConfig; import io.ebean.config.dbplatform.mysql.MySqlPlatform; import io.ebean.dbmigration.ddlgeneration.platform.PlatformDdl; import org.junit.Test; import static org.assertj.core.api.Assertions.assertThat; public class MySqlPlatformTest { MySqlPlatform mySqlPlatform = new MySqlPlatform(); @Test public void testTypeConversion() { PlatformDdl ddl = mySqlPlatform.getPlatformDdl(); assertThat(ddl.convert("clob", false)).isEqualTo("longtext"); assertThat(ddl.convert("json", false)).isEqualTo("longtext"); assertThat(ddl.convert("jsonb", false)).isEqualTo("longtext"); assertThat(ddl.convert("varchar(20)", false)).isEqualTo("varchar(20)"); assertThat(ddl.convert("boolean", false)).isEqualTo("tinyint(1) default 0"); assertThat(ddl.convert("bit", false)).isEqualTo("tinyint(1) default 0"); } @Test public void uuid_default() { MySqlPlatform platform = new MySqlPlatform(); platform.configure(new DbTypeConfig()); DbPlatformType dbType = platform.getDbTypeMap().get(DbPlatformType.UUID); assertThat(dbType.renderType(0, 0)).isEqualTo("varchar(40)"); } @Test public void uuid_as_binary() { MySqlPlatform platform = new MySqlPlatform(); DbTypeConfig config = new DbTypeConfig(); config.setDbUuid(ServerConfig.DbUuid.AUTO_BINARY); platform.configure(config); DbPlatformType dbType = platform.getDbTypeMap().get(DbPlatformType.UUID); assertThat(dbType.renderType(0, 0)).isEqualTo("binary(16)"); } }