Search in sources :

Example 1 with Bid

use of org.jpwh.model.fetching.nplusoneselects.Bid in project microservices by pwillhan.

the class NPlusOneSelects method storeTestData.

public FetchTestData storeTestData() throws Exception {
    UserTransaction tx = TM.getUserTransaction();
    tx.begin();
    EntityManager em = JPA.createEntityManager();
    Long[] itemIds = new Long[3];
    Long[] userIds = new Long[3];
    User johndoe = new User("johndoe");
    em.persist(johndoe);
    userIds[0] = johndoe.getId();
    User janeroe = new User("janeroe");
    em.persist(janeroe);
    userIds[1] = janeroe.getId();
    User robertdoe = new User("robertdoe");
    em.persist(robertdoe);
    userIds[2] = robertdoe.getId();
    Item item = new Item("Item One", CalendarUtil.TOMORROW.getTime(), johndoe);
    em.persist(item);
    itemIds[0] = item.getId();
    for (int i = 1; i <= 3; i++) {
        Bid bid = new Bid(item, robertdoe, new BigDecimal(9 + i));
        item.getBids().add(bid);
        em.persist(bid);
    }
    item = new Item("Item Two", CalendarUtil.TOMORROW.getTime(), johndoe);
    em.persist(item);
    itemIds[1] = item.getId();
    for (int i = 1; i <= 1; i++) {
        Bid bid = new Bid(item, janeroe, new BigDecimal(2 + i));
        item.getBids().add(bid);
        em.persist(bid);
    }
    item = new Item("Item Three", CalendarUtil.AFTER_TOMORROW.getTime(), janeroe);
    em.persist(item);
    itemIds[2] = item.getId();
    for (int i = 1; i <= 1; i++) {
        Bid bid = new Bid(item, johndoe, new BigDecimal(3 + i));
        item.getBids().add(bid);
        em.persist(bid);
    }
    tx.commit();
    em.close();
    FetchTestData testData = new FetchTestData();
    testData.items = new TestData(itemIds);
    testData.users = new TestData(userIds);
    return testData;
}
Also used : UserTransaction(javax.transaction.UserTransaction) Item(org.jpwh.model.fetching.nplusoneselects.Item) EntityManager(javax.persistence.EntityManager) User(org.jpwh.model.fetching.nplusoneselects.User) TestData(org.jpwh.shared.util.TestData) Bid(org.jpwh.model.fetching.nplusoneselects.Bid) BigDecimal(java.math.BigDecimal)

Example 2 with Bid

use of org.jpwh.model.fetching.nplusoneselects.Bid in project microservices by pwillhan.

the class NPlusOneSelects method fetchBids.

@Test
public void fetchBids() throws Exception {
    storeTestData();
    loadEventListener.reset();
    UserTransaction tx = TM.getUserTransaction();
    try {
        tx.begin();
        EntityManager em = JPA.createEntityManager();
        List<Item> items = em.createQuery("select i from Item i").getResultList();
        // select * from ITEM
        assertEquals(loadEventListener.getLoadCount(Item.class), 3);
        assertEquals(loadEventListener.getLoadCount(Bid.class), 0);
        for (Item item : items) {
            // Each bids collection has to be loaded with an additional SELECT
            assertTrue(item.getBids().size() > 0);
        // select * from BID where ITEM_ID = ?
        }
        assertEquals(loadEventListener.getLoadCount(Bid.class), 5);
        tx.commit();
        em.close();
    } finally {
        TM.rollback();
    }
}
Also used : UserTransaction(javax.transaction.UserTransaction) Item(org.jpwh.model.fetching.nplusoneselects.Item) EntityManager(javax.persistence.EntityManager) Bid(org.jpwh.model.fetching.nplusoneselects.Bid) JPATest(org.jpwh.env.JPATest) Test(org.testng.annotations.Test)

Example 3 with Bid

use of org.jpwh.model.fetching.nplusoneselects.Bid in project microservices by pwillhan.

the class EagerQuery method storeTestData.

public FetchTestData storeTestData() throws Exception {
    UserTransaction tx = TM.getUserTransaction();
    tx.begin();
    EntityManager em = JPA.createEntityManager();
    Long[] itemIds = new Long[3];
    Long[] userIds = new Long[3];
    User johndoe = new User("johndoe");
    em.persist(johndoe);
    userIds[0] = johndoe.getId();
    User janeroe = new User("janeroe");
    em.persist(janeroe);
    userIds[1] = janeroe.getId();
    User robertdoe = new User("robertdoe");
    em.persist(robertdoe);
    userIds[2] = robertdoe.getId();
    Item item = new Item("Item One", CalendarUtil.TOMORROW.getTime(), johndoe);
    em.persist(item);
    itemIds[0] = item.getId();
    for (int i = 1; i <= 3; i++) {
        Bid bid = new Bid(item, robertdoe, new BigDecimal(9 + i));
        item.getBids().add(bid);
        em.persist(bid);
    }
    item = new Item("Item Two", CalendarUtil.TOMORROW.getTime(), johndoe);
    em.persist(item);
    itemIds[1] = item.getId();
    for (int i = 1; i <= 1; i++) {
        Bid bid = new Bid(item, janeroe, new BigDecimal(2 + i));
        item.getBids().add(bid);
        em.persist(bid);
    }
    item = new Item("Item Three", CalendarUtil.AFTER_TOMORROW.getTime(), janeroe);
    em.persist(item);
    itemIds[2] = item.getId();
    for (int i = 1; i <= 1; i++) {
        Bid bid = new Bid(item, johndoe, new BigDecimal(3 + i));
        item.getBids().add(bid);
        em.persist(bid);
    }
    tx.commit();
    em.close();
    FetchTestData testData = new FetchTestData();
    testData.items = new TestData(itemIds);
    testData.users = new TestData(userIds);
    return testData;
}
Also used : UserTransaction(javax.transaction.UserTransaction) Item(org.jpwh.model.fetching.nplusoneselects.Item) EntityManager(javax.persistence.EntityManager) User(org.jpwh.model.fetching.nplusoneselects.User) TestData(org.jpwh.shared.util.TestData) Bid(org.jpwh.model.fetching.nplusoneselects.Bid) BigDecimal(java.math.BigDecimal)

Aggregations

EntityManager (javax.persistence.EntityManager)3 UserTransaction (javax.transaction.UserTransaction)3 Bid (org.jpwh.model.fetching.nplusoneselects.Bid)3 Item (org.jpwh.model.fetching.nplusoneselects.Item)3 BigDecimal (java.math.BigDecimal)2 User (org.jpwh.model.fetching.nplusoneselects.User)2 TestData (org.jpwh.shared.util.TestData)2 JPATest (org.jpwh.env.JPATest)1 Test (org.testng.annotations.Test)1