Dom4jTestpublic class Dom4jTest extends org.hibernate.junit.functional.FunctionalTestCase
Constructors Summary |
---|
public Dom4jTest(String str)
super( str );
|
Methods Summary |
---|
public void | configure(org.hibernate.cfg.Configuration cfg)
cfg.setProperty( Environment.DEFAULT_ENTITY_MODE, EntityMode.DOM4J.toString() );
| public java.lang.String[] | getMappings()
return new String[] {
"entitymode/dom4j/basic/Account.hbm.xml",
"entitymode/dom4j/basic/AB.hbm.xml",
"entitymode/dom4j/basic/Employer.hbm.xml"
};
| public static void | print(org.dom4j.Element elt)
XMLHelper.dump( elt );
| public static junit.framework.Test | suite()
return new FunctionalTestClassTestSuite( Dom4jTest.class );
| public void | testCompositeId()
Element a = DocumentFactory.getInstance().createElement( "a" );
a.addAttribute("id", "1");
a.addElement("x").setText("foo bar");
//Element bs = a.addElement("bs");
Element b = a.addElement("b");
//b.addElement("bId").setText("1");
//b.addElement("aId").setText("1");
b.addAttribute("bId", "1");
b.addAttribute("aId", "1");
b.setText("foo foo");
b = a.addElement("b");
//b.addElement("bId").setText("2");
//b.addElement("aId").setText("1");
b.addAttribute("bId", "2");
b.addAttribute("aId", "1");
b.setText("bar bar");
Session s = openSession();
Transaction t = s.beginTransaction();
s.persist("A", a);
t.commit();
s.close();
s = openSession();
t = s.beginTransaction();
a = (Element) s.createCriteria("A").uniqueResult();
assertEquals( a.elements("b").size(), 2 );
print(a);
s.delete("A", a);
t.commit();
s.close();
| public void | testDom4j()
Element acct = DocumentFactory.getInstance().createElement( "account" );
acct.addAttribute( "id", "abc123" );
acct.addElement( "balance" ).setText( "123.45" );
Element cust = acct.addElement( "customer" );
cust.addAttribute( "id", "xyz123" );
Element foo1 = cust.addElement( "stuff" ).addElement( "foo" );
foo1.setText( "foo" );
foo1.addAttribute("bar", "x");
Element foo2 = cust.element( "stuff" ).addElement( "foo" );
foo2.setText( "bar" );
foo2.addAttribute("bar", "y");
cust.addElement( "amount" ).setText( "45" );
cust.setText( "An example customer" );
Element name = cust.addElement( "name" );
name.addElement( "first" ).setText( "Gavin" );
name.addElement( "last" ).setText( "King" );
Element loc = DocumentFactory.getInstance().createElement( "location" );
loc.addElement( "address" ).setText( "Karbarook Avenue" );
print( acct );
Session s = openSession();
Transaction t = s.beginTransaction();
s.persist( "Location", loc );
cust.addElement( "location" ).addAttribute( "id", loc.attributeValue( "id" ) );
s.persist( "Account", acct );
t.commit();
s.close();
print( loc );
s = openSession();
t = s.beginTransaction();
cust = (Element) s.get( "Customer", "xyz123" );
print( cust );
acct = (Element) s.get( "Account", "abc123" );
print( acct );
assertEquals( acct.element( "customer" ), cust );
cust.element( "name" ).element( "first" ).setText( "Gavin A" );
Element foo3 = cust.element("stuff").addElement("foo");
foo3.setText("baz");
foo3.addAttribute("bar", "z");
cust.element("amount").setText("3");
cust.addElement("amount").setText("56");
t.commit();
s.close();
System.out.println();
acct.element( "balance" ).setText( "3456.12" );
cust.addElement( "address" ).setText( "Karbarook Ave" );
assertEquals( acct.element( "customer" ), cust );
cust.setText( "Still the same example!" );
s = openSession();
t = s.beginTransaction();
s.saveOrUpdate( "Account", acct );
t.commit();
s.close();
s = openSession();
t = s.beginTransaction();
cust = (Element) s.get( "Customer", "xyz123" );
print( cust );
acct = (Element) s.get( "Account", "abc123" );
print( acct );
assertEquals( acct.element( "customer" ), cust );
t.commit();
s.close();
System.out.println();
s = openSession();
t = s.beginTransaction();
cust = (Element) s.createCriteria( "Customer" )
.add( Example.create( cust ) )
.uniqueResult();
print( cust );
t.commit();
s.close();
System.out.println();
s = openSession();
t = s.beginTransaction();
acct = (Element) s.createQuery( "from Account a left join fetch a.customer" )
.uniqueResult();
print( acct );
t.commit();
s.close();
System.out.println();
s = openSession();
t = s.beginTransaction();
Map m = (Map) s.createQuery( "select a as acc from Account a left join fetch a.customer" )
.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP).uniqueResult();
acct = (Element)m.get("acc");
print( acct );
t.commit();
s.close();
System.out.println();
s = openSession();
t = s.beginTransaction();
acct = (Element) s.createQuery( "from Account" ).uniqueResult();
print( acct );
t.commit();
s.close();
System.out.println();
s = openSession();
t = s.beginTransaction();
cust = (Element) s.createQuery( "from Customer c left join fetch c.stuff" ).uniqueResult();
print( cust );
t.commit();
s.close();
System.out.println();
s = openSession();
t = s.beginTransaction();
cust = (Element) s.createQuery( "from Customer c left join fetch c.morestuff" ).uniqueResult();
print( cust );
t.commit();
s.close();
System.out.println();
s = openSession();
t = s.beginTransaction();
cust = (Element) s.createQuery( "from Customer c left join fetch c.morestuff" ).uniqueResult();
print( cust );
cust = (Element) s.createQuery( "from Customer c left join fetch c.stuff" ).uniqueResult();
print( cust );
t.commit();
s.close();
System.out.println();
s = openSession();
t = s.beginTransaction();
cust = (Element) s.createQuery( "from Customer c left join fetch c.accounts" ).uniqueResult();
Element a1 = cust.element( "accounts" ).addElement( "account" );
a1.addElement( "balance" ).setText( "12.67" );
a1.addAttribute( "id", "lkj345" );
a1.addAttribute("acnum", "0");
Element a2 = cust.element( "accounts" ).addElement( "account" );
a2.addElement( "balance" ).setText( "10000.00" );
a2.addAttribute( "id", "hsh987" );
a2.addAttribute("acnum", "1");
print( cust );
t.commit();
s.close();
System.out.println();
s = openSession();
t = s.beginTransaction();
cust = (Element) s.createQuery( "from Customer c left join fetch c.accounts" ).uniqueResult();
print( cust );
t.commit();
s.close();
// clean up
s = openSession();
t = s.beginTransaction();
s.delete( "Account", acct );
s.delete( "Location", loc );
s.createQuery( "delete from Account" ).executeUpdate();
t.commit();
s.close();
| public void | testMapIndexEmision()
Element acct = DocumentFactory.getInstance().createElement( "account" );
acct.addAttribute( "id", "abc123" );
acct.addElement( "balance" ).setText( "123.45" );
Element cust = acct.addElement( "customer" );
cust.addAttribute( "id", "xyz123" );
Element foo1 = cust.addElement( "stuff" ).addElement( "foo" );
foo1.setText( "foo" );
foo1.addAttribute("bar", "x");
Element foo2 = cust.element( "stuff" ).addElement( "foo" );
foo2.setText( "bar" );
foo2.addAttribute("bar", "y");
cust.addElement( "amount" ).setText( "45" );
cust.setText( "An example customer" );
Element name = cust.addElement( "name" );
name.addElement( "first" ).setText( "Gavin" );
name.addElement( "last" ).setText( "King" );
print( acct );
Element loc = DocumentFactory.getInstance().createElement( "location" );
loc.addElement( "address" ).setText( "Karbarook Avenue" );
Session s = openSession();
Transaction t = s.beginTransaction();
s.persist( "Location", loc );
cust.addElement( "location" ).addAttribute( "id", loc.attributeValue( "id" ) );
s.persist( "Account", acct );
t.commit();
s.close();
s = openSession();
t = s.beginTransaction();
cust = ( Element ) s.get( "Customer", "xyz123" );
print( cust );
assertEquals( "Incorrect stuff-map size", 2, cust.element( "stuff" ).elements( "foo" ).size() );
Element stuffElement = ( Element ) cust.element( "stuff" ).elements( "foo" ).get( 0 );
assertNotNull( "No map-key value present", stuffElement.attribute( "bar" ) );
t.commit();
s.close();
s = openSession();
t = s.beginTransaction();
s.delete( "Account", acct );
s.delete( "Location", loc );
t.commit();
s.close();
|
|