JFinal Tables自動生成對應Model及Model程式碼& JUnit 測試單元的編寫
阿新 • • 發佈:2019-02-13
這幾天在研究JFinal,對ActiveRecord有點興趣,但其執行必須先將Table對應的Model註冊才行, 通過JFinal提供的Model生成工具對資料庫批量生成Model, 生成器的呼叫:
package autogen; import javax.sql.DataSource; import com.freestyle.app.config.db.OMSDatasource; import com.freestyle.common.db.mybatis.MybatisUtils; import com.jfinal.kit.PathKit; import com.jfinal.plugin.activerecord.dialect.PostgreSqlDialect; import com.jfinal.plugin.activerecord.generator.Generator; public class JFinalModelGenerator { private static DataSource getDataSource() { return OMSDatasource.getDatasource(); } public static void main(String[] args) { MybatisUtils.closeSession(MybatisUtils.getSession()); String baseModelPackageName="com.freestyle.app.study1.model.base"; String baseModelOutDir=PathKit.getWebRootPath()+"/src/main/java/com/freestyle/app/study1/model/base"; String modelPackageName="com.freestyle.app.study1.model"; String modelOutputDir=baseModelOutDir+"/.."; Generator generator=new Generator(getDataSource(),baseModelPackageName,baseModelOutDir,modelPackageName,modelOutputDir); //generator.setGenerateChainSetter(false); generator.addExcludedTable(""); generator.setGenerateDaoInModel(true); generator.setGenerateChainSetter(true); generator.setGenerateDataDictionary(false); generator.setDialect(new PostgreSqlDialect()); generator.addExcludedTable("hibernate_sequences"); generator.generate(); } public JFinalModelGenerator() { // TODO Auto-generated constructor stub } }
跑了完,Model&baseModel都出來了。
為了能脫離web環境測試ActiveRecord,我寫了一個JFinal DB的測試基類:
package test.package1; import org.junit.After; import org.junit.Before; import com.freestyle.app.config.db.OMSDatasource; import com.freestyle.app.study1.model._MappingKit; import com.freestyle.common.db.mybatis.MybatisUtils; import com.jfinal.plugin.activerecord.ActiveRecordPlugin; import com.jfinal.plugin.activerecord.dialect.PostgreSqlDialect; public class JFinalBaseTestUnit { protected static ActiveRecordPlugin activeRecord; @Before public void setUp() throws Exception { MybatisUtils.closeSession(MybatisUtils.getSession()); activeRecord=new ActiveRecordPlugin(OMSDatasource.getDatasource()); activeRecord.setDialect(new PostgreSqlDialect()); activeRecord.setDevMode(true); activeRecord.setShowSql(true); _MappingKit.mapping(activeRecord); activeRecord.start(); } @After public void tearDown() throws Exception { activeRecord.stop(); } }
現在測試下TaUser表的呼叫,新建一個測試單元base on JFinalBaseTestUnit:
package test.package1; import org.junit.Test; import com.freestyle.app.study1.model.TaUser; public class TestJFinalDemo extends JFinalBaseTestUnit { public TestJFinalDemo() { // TODO Auto-generated constructor stub } @Test public void testTaUser() { TaUser dao=TaUser.dao; for (TaUser item:dao.find("select * from ta_user where fa_login like ?", "sale%")) { System.out.println(item.toString()); } } }
pageNumber : 1
pageSize : 10
totalPage : 3
totalRow : 23