Session s = openSession();
s.enableFilter( "region" ).setParameter( "userRegion", "US" );
Transaction t = s.beginTransaction();
prepareTestData( s );
s.clear();
List results;
Iterator itr;
results = s.createQuery( "from Person" ).list();
assertEquals( "Incorrect qry result count", 4, results.size() );
s.clear();
results = s.createQuery( "from Employee" ).list();
assertEquals( "Incorrect qry result count", 2, results.size() );
s.clear();
results = new ArrayList( new HashSet( s.createQuery( "from Person as p left join fetch p.minions" ).list() ) );
assertEquals( "Incorrect qry result count", 4, results.size() );
itr = results.iterator();
while ( itr.hasNext() ) {
// find john
final Person p = ( Person ) itr.next();
if ( p.getName().equals( "John Doe" ) ) {
Employee john = ( Employee ) p;
assertEquals( "Incorrect fecthed minions count", 1, john.getMinions().size() );
break;
}
}
s.clear();
results = new ArrayList( new HashSet( s.createQuery( "from Employee as p left join fetch p.minions" ).list() ) );
assertEquals( "Incorrect qry result count", 2, results.size() );
itr = results.iterator();
while ( itr.hasNext() ) {
// find john
final Person p = ( Person ) itr.next();
if ( p.getName().equals( "John Doe" ) ) {
Employee john = ( Employee ) p;
assertEquals( "Incorrect fecthed minions count", 1, john.getMinions().size() );
break;
}
}
t.commit();
s.close();
s = openSession();
t = s.beginTransaction();
s.delete( "from Person" );
t.commit();
s.close();