use of org.hibernate.tool.schema.extract.internal.TableInformationImpl in project hibernate-orm by hibernate.
the class CheckForExistingForeignKeyTest method testCheckForExistingForeignKeyOne2One.
/**
* Check detection of existing foreign key with the same mappings for a simple mapping (table1.objectId =>
* table2.id).
*
* @throws SecurityException - error
* @throws NoSuchMethodException - error
* @throws InvocationTargetException - error
* @throws IllegalArgumentException - error
* @throws IllegalAccessException - error
* @throws NoSuchFieldException - error
*/
@Test
public void testCheckForExistingForeignKeyOne2One() throws NoSuchMethodException, SecurityException, IllegalAccessException, IllegalArgumentException, InvocationTargetException, NoSuchFieldException {
// Get the private method
Method method = AbstractSchemaMigrator.class.getDeclaredMethod("checkForExistingForeignKey", ForeignKey.class, TableInformation.class);
method.setAccessible(true);
ForeignKey foreignKey = new ForeignKey();
// Make sure the match is not successful based on key name
foreignKey.setName("objectId2id_1");
foreignKey.addColumn(new Column("id"));
foreignKey.setReferencedTable(new Table("table2"));
Name schemaName = new Name(new Identifier("-", false), new Identifier("-", false));
InformationExtractor informationExtractor = Mockito.mock(InformationExtractor.class);
IdentifierHelper identifierHelper = new IdentifierHelperImpl();
List<ForeignKeyInformation> fks = new ArrayList<>();
fks.add(getForeignKeyInformation("table2", "id", "object2Id_2"));
Mockito.when(informationExtractor.getForeignKeys(Mockito.any())).thenReturn(fks);
QualifiedTableName tableName = new QualifiedTableName(schemaName, new Identifier("-", false));
TableInformation tableInformation = new TableInformationImpl(informationExtractor, identifierHelper, tableName, false, null);
AbstractSchemaMigrator schemaMigrator = new SchemaMigrator();
// Check single-column-key to single-column-key, existing (table1.objectId => table2.id)
boolean found = (boolean) method.invoke(schemaMigrator, foreignKey, tableInformation);
Assert.assertTrue("Key should be found", found);
}
use of org.hibernate.tool.schema.extract.internal.TableInformationImpl in project hibernate-orm by hibernate.
the class CheckForExistingForeignKeyTest method testForeignKeyWithoutName.
/**
* If the key has no name it should never be found. Result is that those keys are always recreated. But keys always
* have a name so this is no problem.
*
* @throws NoSuchMethodException - error
* @throws SecurityException - error
* @throws IllegalAccessException - error
* @throws IllegalArgumentException - error
* @throws InvocationTargetException - error
*/
@Test
public void testForeignKeyWithoutName() throws NoSuchMethodException, SecurityException, IllegalAccessException, IllegalArgumentException, InvocationTargetException {
// Get the private method
Method method = AbstractSchemaMigrator.class.getDeclaredMethod("checkForExistingForeignKey", ForeignKey.class, TableInformation.class);
method.setAccessible(true);
// foreignKey name with same name should match
ForeignKey foreignKey = new ForeignKey();
TableInformation tableInformation = new TableInformationImpl(null, null, null, false, null);
boolean found = (boolean) method.invoke(new SchemaMigrator(), foreignKey, tableInformation);
Assert.assertFalse("Key should not be found", found);
}
use of org.hibernate.tool.schema.extract.internal.TableInformationImpl in project hibernate-orm by hibernate.
the class CheckForExistingForeignKeyTest method testKeyWithSameNameNotExists.
/**
* Check detection of existing foreign keys with the same name exists.
*
* @throws SecurityException - error
* @throws NoSuchMethodException - error
* @throws InvocationTargetException - error
* @throws IllegalArgumentException - error
* @throws IllegalAccessException - error
* @throws NoSuchFieldException - error
*/
@Test
public void testKeyWithSameNameNotExists() throws NoSuchMethodException, SecurityException, IllegalAccessException, IllegalArgumentException, InvocationTargetException, NoSuchFieldException {
// Get the private method
Method method = AbstractSchemaMigrator.class.getDeclaredMethod("checkForExistingForeignKey", ForeignKey.class, TableInformation.class);
method.setAccessible(true);
ForeignKey foreignKey = new ForeignKey();
foreignKey.setName("objectId2id_1");
foreignKey.addColumn(new Column("id"));
foreignKey.setReferencedTable(new Table("table2"));
InformationExtractor informationExtractor = Mockito.mock(InformationExtractor.class);
IdentifierHelper identifierHelper = new IdentifierHelperImpl();
List<ForeignKeyInformation> fks = new ArrayList<>();
fks.add(new ForeignKeyInformationImpl(new Identifier("objectId2id_2", false), new ArrayList<>()));
Mockito.when(informationExtractor.getForeignKeys(Mockito.any())).thenReturn(fks);
Name schemaName = new Name(new Identifier("-", false), new Identifier("-", false));
QualifiedTableName tableName = new QualifiedTableName(schemaName, new Identifier("-", false));
TableInformation tableInformation = new TableInformationImpl(informationExtractor, identifierHelper, tableName, false, null);
// foreignKey name with same name should match
boolean found = (boolean) method.invoke(new SchemaMigrator(), foreignKey, tableInformation);
Assert.assertFalse("Key should not be found", found);
}
use of org.hibernate.tool.schema.extract.internal.TableInformationImpl in project hibernate-orm by hibernate.
the class CheckForExistingForeignKeyTest method getColumnInformation.
private ColumnInformation getColumnInformation(String tableName, String columnName) {
Name schemaName = new Name(new Identifier("-", false), new Identifier("-", false));
TableInformation containingTableInformation = new TableInformationImpl(null, null, new QualifiedTableName(schemaName, new Identifier(tableName, false)), false, null);
Identifier columnIdentifier = new Identifier(columnName, false);
int typeCode = 0;
String typeName = null;
int columnSize = 0;
int decimalDigits = 0;
TruthValue nullable = null;
ColumnInformationImpl columnInformation = new ColumnInformationImpl(containingTableInformation, columnIdentifier, typeCode, typeName, columnSize, decimalDigits, nullable);
return columnInformation;
}
use of org.hibernate.tool.schema.extract.internal.TableInformationImpl in project hibernate-orm by hibernate.
the class CheckForExistingForeignKeyTest method testCheckForNotExistingForeignKeyOne2One.
/**
* Check detection of not existing foreign key with the same mappings for a simple mapping (table1.objectId =>
* table2.id).
*
* @throws SecurityException - error
* @throws NoSuchMethodException - error
* @throws InvocationTargetException - error
* @throws IllegalArgumentException - error
* @throws IllegalAccessException - error
* @throws NoSuchFieldException - error
*/
@Test
public void testCheckForNotExistingForeignKeyOne2One() throws NoSuchMethodException, SecurityException, IllegalAccessException, IllegalArgumentException, InvocationTargetException, NoSuchFieldException {
// Get the private method
Method method = AbstractSchemaMigrator.class.getDeclaredMethod("checkForExistingForeignKey", ForeignKey.class, TableInformation.class);
method.setAccessible(true);
ForeignKey foreignKey = new ForeignKey();
// Make sure the match is not successful based on key name
foreignKey.setName("objectId2id_1");
foreignKey.addColumn(new Column("id"));
foreignKey.setReferencedTable(new Table("table2"));
Name schemaName = new Name(new Identifier("-", false), new Identifier("-", false));
InformationExtractor informationExtractor = Mockito.mock(InformationExtractor.class);
IdentifierHelper identifierHelper = new IdentifierHelperImpl();
List<ForeignKeyInformation> fks = new ArrayList<>();
fks.add(getForeignKeyInformation("table2", "blah", "blahKey_001"));
fks.add(getForeignKeyInformation("table3", "id", "blahKey_002"));
fks.add(getForeignKeyInformation("table3", "blah", "blahKey_003"));
Mockito.when(informationExtractor.getForeignKeys(Mockito.any())).thenReturn(fks);
QualifiedTableName tableName = new QualifiedTableName(schemaName, new Identifier("-", false));
TableInformation tableInformation = new TableInformationImpl(informationExtractor, identifierHelper, tableName, false, null);
AbstractSchemaMigrator schemaMigrator = new SchemaMigrator();
// Check single-column-key to single-column-key, existing (table1.objectId => table2.id)
boolean found = (boolean) method.invoke(schemaMigrator, foreignKey, tableInformation);
Assert.assertFalse("Key should not be found", found);
}
Aggregations