public class QueryDslConditionsTest extends AbstractQueryDslTest {
@BeforeMethod(alwaysRun = true)
protected void populateCache() throws Exception {
// create the test objects
User user1 = new User();
user1.setId(1);
user1.setName("John");
user1.setSurname("Doe");
user1.setGender(User.Gender.MALE);
user1.setAge(22);
user1.setAccountIds(new HashSet<Integer>(Arrays.asList(1, 2)));
Address address1 = new Address();
address1.setStreet("Main Street");
address1.setPostCode("X1234");
user1.setAddresses(Collections.singletonList(address1));
User user2 = new User();
user2.setId(2);
user2.setName("Spider");
user2.setSurname("Man");
user2.setGender(User.Gender.MALE);
user2.setAccountIds(Collections.singleton(3));
Address address2 = new Address();
address2.setStreet("Old Street");
address2.setPostCode("Y12");
Address address3 = new Address();
address3.setStreet("Bond Street");
address3.setPostCode("ZZ");
user2.setAddresses(Arrays.asList(address2, address3));
User user3 = new User();
user3.setId(3);
user3.setName("Spider");
user3.setSurname("Woman");
user3.setGender(User.Gender.FEMALE);
user3.setAccountIds(Collections.<Integer>emptySet());
Account account1 = new Account();
account1.setId(1);
account1.setDescription("John Doe's first bank account");
account1.setCreationDate(DATE_FORMAT.parse("2013-01-03"));
Account account2 = new Account();
account2.setId(2);
account2.setDescription("John Doe's second bank account");
account2.setCreationDate(DATE_FORMAT.parse("2013-01-04"));
Account account3 = new Account();
account3.setId(3);
account3.setCreationDate(DATE_FORMAT.parse("2013-01-20"));
Transaction transaction0 = new Transaction();
transaction0.setId(0);
transaction0.setDescription("Birthday present");
transaction0.setAccountId(1);
transaction0.setAmount(1800);
transaction0.setDate(DATE_FORMAT.parse("2012-09-07"));
transaction0.setDebit(false);
Transaction transaction1 = new Transaction();
transaction1.setId(1);
transaction1.setDescription("Feb. rent payment");
transaction1.setAccountId(1);
transaction1.setAmount(1500);
transaction1.setDate(DATE_FORMAT.parse("2013-01-05"));
transaction1.setDebit(true);
Transaction transaction2 = new Transaction();
transaction2.setId(2);
transaction2.setDescription("Starbucks");
transaction2.setAccountId(1);
transaction2.setAmount(23);
transaction2.setDate(DATE_FORMAT.parse("2013-01-09"));
transaction2.setDebit(true);
Transaction transaction3 = new Transaction();
transaction3.setId(3);
transaction3.setDescription("Hotel");
transaction3.setAccountId(2);
transaction3.setAmount(45);
transaction3.setDate(DATE_FORMAT.parse("2013-02-27"));
transaction3.setDebit(true);
Transaction transaction4 = new Transaction();
transaction4.setId(4);
transaction4.setDescription("Last january");
transaction4.setAccountId(2);
transaction4.setAmount(95);
transaction4.setDate(DATE_FORMAT.parse("2013-01-31"));
transaction4.setDebit(true);
Transaction transaction5 = new Transaction();
transaction5.setId(5);
transaction5.setDescription("Popcorn");
transaction5.setAccountId(2);
transaction5.setAmount(5);
transaction5.setDate(DATE_FORMAT.parse("2013-01-01"));
transaction5.setDebit(true);
// persist and index the test objects
// we put all of them in the same cache for the sake of simplicity
cache.put("user_" + user1.getId(), user1);
cache.put("user_" + user2.getId(), user2);
cache.put("user_" + user3.getId(), user3);
cache.put("account_" + account1.getId(), account1);
cache.put("account_" + account2.getId(), account2);
cache.put("account_" + account3.getId(), account3);
cache.put("transaction_" + transaction0.getId(), transaction0);
cache.put("transaction_" + transaction1.getId(), transaction1);