/* * SonarQube * Copyright (C) 2009-2017 SonarSource SA * mailto:info AT sonarsource DOT com * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 3 of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ package org.sonar.server.platform.db.migration.def; import org.junit.Rule; import org.junit.Test; import org.junit.rules.ExpectedException; import org.sonar.db.dialect.Dialect; import org.sonar.db.dialect.H2; import org.sonar.db.dialect.MsSql; import org.sonar.db.dialect.MySql; import org.sonar.db.dialect.Oracle; import org.sonar.db.dialect.PostgreSql; import static org.assertj.core.api.Assertions.assertThat; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.when; import static org.sonar.server.platform.db.migration.def.IntegerColumnDef.newIntegerColumnDefBuilder; public class IntegerColumnDefTest { @Rule public ExpectedException expectedException = ExpectedException.none(); private IntegerColumnDef underTest = newIntegerColumnDefBuilder().setColumnName("a").build(); @Test public void builder_setColumnName_throws_IAE_if_name_is_not_lowercase() { IntegerColumnDef.Builder builder = newIntegerColumnDefBuilder(); expectedException.expect(IllegalArgumentException.class); expectedException.expectMessage("Column name must be lower case and contain only alphanumeric chars or '_', got 'T'"); builder.setColumnName("T"); } @Test public void builder_build_throws_NPE_if_no_name_was_set() { IntegerColumnDef.Builder builder = newIntegerColumnDefBuilder(); expectedException.expect(NullPointerException.class); expectedException.expectMessage("Column name cannot be null"); builder.build(); } @Test public void integerColumDef_is_nullable_by_default() { assertThat(newIntegerColumnDefBuilder().setColumnName("a").build().isNullable()).isTrue(); } @Test public void builder_setNullable_sets_nullable_field_of_IntegerColumnDef() { assertThat(newIntegerColumnDefBuilder().setColumnName("a").setIsNullable(true).build().isNullable()).isTrue(); assertThat(newIntegerColumnDefBuilder().setColumnName("a").setIsNullable(false).build().isNullable()).isFalse(); } @Test public void builder_setColumnName_sets_name_field_of_IntegerColumnDef() { assertThat(newIntegerColumnDefBuilder().setColumnName("a").build().getName()).isEqualTo("a"); } @Test public void builder_setDefaultValue_sets_default_value_field_of_IntegerColumnDef() { assertThat(newIntegerColumnDefBuilder().setColumnName("a").setDefaultValue(42).build().getDefaultValue()).isEqualTo(42); } @Test public void default_value_is_null_by_default() { assertThat(newIntegerColumnDefBuilder().setColumnName("a").build().getDefaultValue()).isNull(); } @Test public void generateSqlType_for_MsSql() { assertThat(underTest.generateSqlType(new MsSql())).isEqualTo("INT"); } @Test public void generateSqlType_for_MySql() { assertThat(underTest.generateSqlType(new MySql())).isEqualTo("INTEGER"); } @Test public void generateSqlType_for_Oracle() { assertThat(underTest.generateSqlType(new Oracle())).isEqualTo("NUMBER(38,0)"); } @Test public void generateSqlType_for_H2() { assertThat(underTest.generateSqlType(new H2())).isEqualTo("INTEGER"); } @Test public void generateSqlType_for_PostgreSql() { assertThat(underTest.generateSqlType(new PostgreSql())).isEqualTo("INTEGER"); } @Test public void generateSqlType_thows_IAE_for_unknown_dialect() { Dialect dialect = mock(Dialect.class); when(dialect.getId()).thenReturn("AAA"); expectedException.expect(IllegalArgumentException.class); expectedException.expectMessage("Unsupported dialect id AAA"); underTest.generateSqlType(dialect); } }