/*
* Copyright 2004-2015 the Seasar Foundation and the Others.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
* either express or implied. See the License for the specific language
* governing permissions and limitations under the License.
*/
package org.seasar.extension.jdbc.gen.internal.generator;
import java.io.File;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.sql.DataSource;
import org.junit.Before;
import org.junit.Test;
import org.seasar.extension.jdbc.annotation.ReferentialActionType;
import org.seasar.extension.jdbc.gen.desc.ForeignKeyDesc;
import org.seasar.extension.jdbc.gen.desc.TableDesc;
import org.seasar.extension.jdbc.gen.generator.GenerationContext;
import org.seasar.extension.jdbc.gen.internal.dialect.StandardGenDialect;
import org.seasar.extension.jdbc.gen.internal.model.TableModelFactoryImpl;
import org.seasar.extension.jdbc.gen.model.SqlIdentifierCaseType;
import org.seasar.extension.jdbc.gen.model.SqlKeywordCaseType;
import org.seasar.extension.jdbc.gen.model.TableModel;
import org.seasar.framework.mock.sql.MockConnection;
import org.seasar.framework.mock.sql.MockDataSource;
import org.seasar.framework.mock.sql.MockPreparedStatement;
import org.seasar.framework.mock.sql.MockResultSet;
import org.seasar.framework.util.ArrayMap;
import org.seasar.framework.util.TextUtil;
import static org.junit.Assert.*;
/**
* @author taedium
*
*/
public class GenerateForeignKeyTest {
private GeneratorImplStub generator;
private DataSource dataSource;
private TableModelFactoryImpl factory;
/**
*
* @throws Exception
*/
@Before
public void setUp() throws Exception {
generator = new GeneratorImplStub();
dataSource = new MockDataSource() {
@Override
public Connection getConnection() throws SQLException {
return new MockConnection() {
@Override
public MockPreparedStatement prepareMockStatement(String sql) {
return new MockPreparedStatement(this, sql) {
@Override
public ResultSet executeQuery() throws SQLException {
MockResultSet resultSet = new MockResultSet();
ArrayMap map = new ArrayMap();
map.put(null, 200);
resultSet.addRowData(map);
return resultSet;
}
};
}
};
}
};
factory = new TableModelFactoryImpl(new StandardGenDialect(),
dataSource, SqlIdentifierCaseType.ORIGINALCASE,
SqlKeywordCaseType.ORIGINALCASE, ';', null, false) {
@Override
protected Long getNextValue(String sequenceName, int allocationSize) {
return null;
}
};
}
/**
*
* @throws Exception
*/
@Test
public void testCreate() throws Exception {
ForeignKeyDesc foreignKeyDesc = new ForeignKeyDesc();
foreignKeyDesc.addColumnName("FK1-1");
foreignKeyDesc.addColumnName("FK1-2");
foreignKeyDesc.setReferencedCatalogName("CCC");
foreignKeyDesc.setReferencedSchemaName("DDD");
foreignKeyDesc.setReferencedTableName("FOO");
foreignKeyDesc.setReferencedFullTableName("CCC.DDD.FOO");
foreignKeyDesc.addReferencedColumnName("REF1-1");
foreignKeyDesc.addReferencedColumnName("REF1-2");
ForeignKeyDesc foreignKeyDesc2 = new ForeignKeyDesc();
foreignKeyDesc2.addColumnName("FK2-1");
foreignKeyDesc2.addColumnName("FK2-2");
foreignKeyDesc2.setReferencedCatalogName("EEE");
foreignKeyDesc2.setReferencedSchemaName("FFF");
foreignKeyDesc2.setReferencedTableName("BAR");
foreignKeyDesc2.setReferencedFullTableName("EEE.FFF.BAR");
foreignKeyDesc2.addReferencedColumnName("REF2-1");
foreignKeyDesc2.addReferencedColumnName("REF2-2");
TableDesc tableDesc = new TableDesc();
tableDesc.setCatalogName("AAA");
tableDesc.setSchemaName("BBB");
tableDesc.setName("HOGE");
tableDesc.setCanonicalName("aaa.bbb.hoge");
tableDesc.addForeignKeyDesc(foreignKeyDesc);
tableDesc.addForeignKeyDesc(foreignKeyDesc2);
TableModel model = factory.getTableModel(tableDesc);
GenerationContext context = new GenerationContextImpl(model, new File(
"file"), "sql/create-foreignkey.ftl", "UTF-8", false);
generator.generate(context);
String path = getClass().getName().replace(".", "/") + "_Create.txt";
assertEquals(TextUtil.readUTF8(path), generator.getResult());
}
/**
*
* @throws Exception
*/
@Test
public void testCreate_referentialAction() throws Exception {
ForeignKeyDesc foreignKeyDesc = new ForeignKeyDesc();
foreignKeyDesc.addColumnName("FK1-1");
foreignKeyDesc.addColumnName("FK1-2");
foreignKeyDesc.setReferencedCatalogName("CCC");
foreignKeyDesc.setReferencedSchemaName("DDD");
foreignKeyDesc.setReferencedTableName("FOO");
foreignKeyDesc.setReferencedFullTableName("CCC.DDD.FOO");
foreignKeyDesc.addReferencedColumnName("REF1-1");
foreignKeyDesc.addReferencedColumnName("REF1-2");
foreignKeyDesc.setOnDelete(ReferentialActionType.CASCADE);
foreignKeyDesc.setOnUpdate(ReferentialActionType.RESTRICT);
ForeignKeyDesc foreignKeyDesc2 = new ForeignKeyDesc();
foreignKeyDesc2.addColumnName("FK2-1");
foreignKeyDesc2.addColumnName("FK2-2");
foreignKeyDesc2.setReferencedCatalogName("EEE");
foreignKeyDesc2.setReferencedSchemaName("FFF");
foreignKeyDesc2.setReferencedTableName("BAR");
foreignKeyDesc2.setReferencedFullTableName("EEE.FFF.BAR");
foreignKeyDesc2.addReferencedColumnName("REF2-1");
foreignKeyDesc2.addReferencedColumnName("REF2-2");
foreignKeyDesc2.setOnDelete(ReferentialActionType.NO_ACTION);
foreignKeyDesc2.setOnUpdate(ReferentialActionType.NO_ACTION);
TableDesc tableDesc = new TableDesc();
tableDesc.setCatalogName("AAA");
tableDesc.setSchemaName("BBB");
tableDesc.setName("HOGE");
tableDesc.setCanonicalName("aaa.bbb.hoge");
tableDesc.addForeignKeyDesc(foreignKeyDesc);
tableDesc.addForeignKeyDesc(foreignKeyDesc2);
TableModel model = factory.getTableModel(tableDesc);
GenerationContext context = new GenerationContextImpl(model, new File(
"file"), "sql/create-foreignkey.ftl", "UTF-8", false);
generator.generate(context);
String path = getClass().getName().replace(".", "/")
+ "_Create_referentialAction.txt";
assertEquals(TextUtil.readUTF8(path), generator.getResult());
}
/**
*
* @throws Exception
*/
@Test
public void testDrop() throws Exception {
ForeignKeyDesc foreignKeyDesc = new ForeignKeyDesc();
foreignKeyDesc.addColumnName("FK1-1");
foreignKeyDesc.addColumnName("FK1-2");
foreignKeyDesc.setReferencedCatalogName("CCC");
foreignKeyDesc.setReferencedSchemaName("DDD");
foreignKeyDesc.setReferencedTableName("FOO");
foreignKeyDesc.setReferencedFullTableName("CCC.DDD.FOO");
foreignKeyDesc.addReferencedColumnName("REF1-1");
foreignKeyDesc.addReferencedColumnName("REF1-2");
ForeignKeyDesc foreignKeyDesc2 = new ForeignKeyDesc();
foreignKeyDesc2.addColumnName("FK2-1");
foreignKeyDesc2.addColumnName("FK2-2");
foreignKeyDesc2.setReferencedCatalogName("EEE");
foreignKeyDesc2.setReferencedSchemaName("FFF");
foreignKeyDesc2.setReferencedTableName("BAR");
foreignKeyDesc2.setReferencedFullTableName("EEE.FFF.BAR");
foreignKeyDesc2.addReferencedColumnName("REF2-1");
foreignKeyDesc2.addReferencedColumnName("REF2-2");
TableDesc tableDesc = new TableDesc();
tableDesc.setCatalogName("AAA");
tableDesc.setSchemaName("BBB");
tableDesc.setName("HOGE");
tableDesc.setCanonicalName("aaa.bbb.hoge");
tableDesc.addForeignKeyDesc(foreignKeyDesc);
tableDesc.addForeignKeyDesc(foreignKeyDesc2);
TableModel model = factory.getTableModel(tableDesc);
GenerationContext context = new GenerationContextImpl(model, new File(
"file"), "sql/drop-foreignkey.ftl", "UTF-8", false);
generator.generate(context);
String path = getClass().getName().replace(".", "/") + "_Drop.txt";
assertEquals(TextUtil.readUTF8(path), generator.getResult());
}
}