您的位置:軟件測試 > 開源軟件測試 > 開源功能測試工具 >
Hibernate配置文件在單元測試中的靈活運(yùn)用
作者:網(wǎng)絡(luò)轉(zhuǎn)載 發(fā)布時間:[ 2012/11/29 13:35:31 ] 推薦標(biāo)簽:

除了指定.properties文件之外,還可以指定.hbm.xml文件,下面列出幾個常用的方法:

 

addClass(Class)
addFile(File)
addFile(String)
addURL(URL)

前面我們已經(jīng)講了,configure()方法默認(rèn)是通過訪問hibernate.cfg.xml的<mapping>元素來加載我們提供的.hbm.xml文件,上面列出的方法可以直接指定hbm.xml文件,例如addClass()方法可以直接通過指定class來加載對應(yīng)的映射文件,hibernate會將提供的class的全名(包括package)自動轉(zhuǎn)化為文件路徑,如net.sf.hibernate.examples.quickstart.Cat.class對應(yīng)了net/sf/hibernate/examples/quickstart/Cat.hbm.xml,還可以用addFile方法直接指定映射文件。

例一:

 

Configuration config = new Configuration().addClass(Cat.class);

例二:

 

Configuration config = new Configuration().addURL(Configuration.class.getResource ("Cat.hbm.xml"));

例三:

 

Configuration config = new Configuration().addFile("Cat.hbm.xml");

3.5 總結(jié)
Configuration提供的這些方法的好處如下:

1. 一個應(yīng)用中往往有很多.hbm.xml映射文件,開發(fā)的過程中如果只是為了測試某個或幾個Java PO(Persistence Object),我們沒有必要把所有的.hbm.xml都加載到內(nèi)存,這樣可以通過addClass或者addFile直接,顯得非常靈活。

2. 學(xué)習(xí)Hibernate的過程中,往往需要通過練習(xí)來體會Hibernate提供的各種特征,而很多特征是需要修改配置文件的,如果要觀察相同的代碼在不同的特征下的表現(xiàn),需要手工改配置文件,這樣太麻煩了,而且容易出錯,我們可以提供多個配置文件,每個配置文件針對需要的特征而配置,這樣我們在調(diào)用程序的時候,把不同的配置文件作為參數(shù)傳遞進(jìn)去,而程序代碼里面使用setProperties和addFile指定傳入的配置文件參數(shù)可以了。

3. 在單元測試中,特別是在集成測試?yán)锩,整個過程是自動化的,我們不能手工干預(yù)測試過程,往往需要準(zhǔn)備多個配置文件針對不同的測試案例,這個時候setProperties和addFile方法顯得特別有用了,在不同的測試案例中用這些方法來指定相應(yīng)的配置文件,這樣可以做到自動化測試,保證了持續(xù)性。

3.6 應(yīng)用舉例
在剛開始學(xué)習(xí)hibernate的時候,對于hibernate的hbm映射文件里的各種配置參數(shù)沒有一個感性的認(rèn)識,例如inverse="true",lazy="true"這樣的配置參數(shù),不通過實踐是無法體會到其作用的,傳統(tǒng)的方法是每需要測試一種參數(shù)的效果更改相應(yīng)的配置文件,然后運(yùn)行測試來觀察結(jié)果,如果能夠靈活的運(yùn)用Configuration提供的定制配置的方法,我們可以提供多個配置文件,每個配置文件里面有不同的配置參數(shù),配合相應(yīng)的測試案例方便多了。

例如針對ono-to-many和many-to-one的雙向關(guān)聯(lián)的映射關(guān)系,我們想測試在one-to-many一方使用inverse="false"和inverse="true"的不同效果,假設(shè)已經(jīng)正確的配置好了hibernate.properties,那么還需要提供兩個不同的hbm.xml文件,假設(shè)分別名為bidirect.inverse.false.hbm.xml和bidirect.inverse.true.hbm.xml。

然后需要寫兩個不同的測試案例,分別針對兩個不同的配置文件進(jìn)行測試可以了,這樣的好處是,不用針對不同的測試案例修改配置文件,特別是在集成測試的時候,一切都是自動化的,如果每測試一個案例需要手工去更改配置文件,這肯定是一個失敗的測試。

代碼模板如下:

 

FalseInverseTest.java文件
import junit.framework.TestCase;
import net.sf.hibernate.HibernateException;
import net.sf.hibernate.Session;
import net.sf.hibernate.Transaction;
import net.sf.hibernate.cfg.Configuration;

/**
* test false inverse
*/
public class FalseInverseTest extends TestCase {

private Session session;
private Transaction tx;

protected void setUp() throws Exception {
Configuration cfg = new Configuration().addFile("bidirect.inverse.false.hbm.xml");
session = cfg.buildSessionFactory().openSession();
tx = session.beginTransaction();
}

protected void tearDown() throws Exception {
tx.commit();
session.close();
}

public void testLogic() {
//在此編寫測試代碼
}

}

TrueInverseTest.java文件

 

import junit.framework.TestCase;
import net.sf.hibernate.HibernateException;
import net.sf.hibernate.Session;
import net.sf.hibernate.Transaction;
import net.sf.hibernate.cfg.Configuration;

/**
* test true inverse
*/
public class TrueInverseTest extends TestCase {

private Session session;
private Transaction tx;

protected void setUp() throws Exception {
Configuration cfg = new Configuration().addFile("bidirect.inverse.true.hbm.xml");
session = cfg.buildSessionFactory().openSession();
tx = session.beginTransaction();
}

protected void tearDown() throws Exception {
tx.commit();
session.close();
}

public void testLogic() {
//在此編寫測試代碼
}

}

結(jié)束語
通過對Hibernate默認(rèn)的配置文件的加載順序和Hibernate提供的加載配置文件的方法的討論,我們對在使用到Hibernate的項目的單元測試中使用多個Hibernate配置文件有了比較清楚的認(rèn)識。

持續(xù)集成中的測試的特征是自動化和持續(xù)性,不能手工干預(yù)其過程,在使用到Hibernate的項目如果要實現(xiàn)持續(xù)集成,要為不同的測試案例提供不同的配置文件,而不是針對不同的測試案例進(jìn)行手工調(diào)整,因此,在使用到Hibernate的項目中靈活的運(yùn)用多配置文件,可以提高測試的效率,保證自動化和持續(xù)性。

注1:有關(guān)的代碼請參考Environment類的static{}。

注2:如果在hibernate.cfg.xml的<property/>配置的name沒有以hibernate開頭,那么configure()內(nèi)部會自動在前面添加hibernate,例如connection.url,hibernate會自動將其轉(zhuǎn)化為hibernate.connection.url。

上一頁123下一頁
軟件測試工具 | 聯(lián)系我們 | 投訴建議 | 誠聘英才 | 申請使用列表 | 網(wǎng)站地圖
滬ICP備07036474 2003-2017 版權(quán)所有 上海澤眾軟件科技有限公司 Shanghai ZeZhong Software Co.,Ltd