【Java开源代码栏目提醒】:网学会员为需要Java开源代码的朋友们搜集整理了CompositeUserTypeTest.java相关资料,希望对各位网友有所帮助!
//$Id: CompositeUserTypeTest.java 8703 2005-11-29 20:04:18Z steveebersole $
package org.hibernate.test.cut;
import java.math.BigDecimal;
import java.util.Currency;
import java.util.List;
import junit.framework.Test;
import junit.framework.TestSuite;
import org.hibernate.Session;
import org.hibernate.dialect.HSQLDialect;
import org.hibernate.dialect.Oracle9Dialect;
import org.hibernate.test.TestCase;
/**
* @author Gavin King
*/
public class CompositeUserTypeTest extends TestCase {
public CompositeUserTypeTest(String str) {
super(str);
}
public void testCompositeUserType() {
Session s = openSession();
org.hibernate.Transaction t = s.beginTransaction();
Transaction tran = new Transaction();
tran.setDescription("a small transaction");
tran.setValue( new MonetoryAmount( new BigDecimal(1.5), Currency.getInstance("USD") ) );
s.persist(tran);
List result = s.createQuery("from Transaction tran where tran.value.amount > 1.0 and tran.value.currency = 'USD'").list();
assertEquals( result.size(), 1 );
tran.getValue().setCurrency( Currency.getInstance("AUD") );
result = s.createQuery("from Transaction tran where tran.value.amount > 1.0 and tran.value.currency = 'AUD'").list();
assertEquals( result.size(), 1 );
if ( !(getDialect() instanceof HSQLDialect) && ! (getDialect() instanceof Oracle9Dialect) ) {
result = s.createQuery("from Transaction txn where txn.value = (1.5, 'AUD')").list();
assertEquals( result.size(), 1 );
result = s.createQuery("from Transaction where value = (1.5, 'AUD')").list();
assertEquals( result.size(), 1 );
}
s.delete(tran);
t.commit();
s.close();
}
protected String[] getMappings() {
return new String[] { "cut/types.hbm.xml", "cut/Transaction.hbm.
xml" };
}
public static Test suite() {
return new TestSuite(CompositeUserTypeTest.class);
}
}