/** * Copyright (C) 2011 JTalks.org Team * This library 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 2.1 of the License, or (at your option) any later version. * This library 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 library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ package org.jtalks.poulpe.util.databasebackup.domain; import static org.testng.Assert.*; import org.jtalks.poulpe.util.databasebackup.persistence.SqlTypes; import org.testng.annotations.BeforeMethod; import org.testng.annotations.Test; public class ColumnMetaDataTest { private ColumnMetaData sut1, sut2, differentSut; @BeforeMethod public void beforeMethod() { sut1 = ColumnMetaData.getInstance("columnTypeA", SqlTypes.INT).setSize(32).setAutoincrement(true) .setDefaultValue("5") .setNullable(false).setComment("true - sid is user, false - sid is a granted authority"); sut2 = ColumnMetaData.getInstance("columnTypeA", SqlTypes.INT).setSize(32).setAutoincrement(true) .setDefaultValue("5") .setNullable(false).setComment("true - sid is user, false - sid is a granted authority"); differentSut = ColumnMetaData.getInstance("columnTypeB", SqlTypes.VARCHAR).setSize(8).setAutoincrement(false) .setDefaultValue("").setNullable(true); } @Test public void twoNotEqualTableColumnAreNotEquals() { assertFalse(sut1.equals(differentSut)); assertFalse(sut1.hashCode() == differentSut.hashCode()); } @Test public void twoEqualTableColumnAreEquals() { assertEquals(sut1, sut2); assertEquals(sut1.hashCode(), sut2.hashCode()); } @Test(expectedExceptions = NullPointerException.class) public void constructThrowsExceptionWhenColumnTypeIsNull() { ColumnMetaData tableColumn = ColumnMetaData.getInstance("columnTypeA", null); } @Test(expectedExceptions = NullPointerException.class) public void constructThrowsExceptionWhenColumnNaemIsNull() { ColumnMetaData tableColumn = ColumnMetaData.getInstance(null, SqlTypes.INT); } }