Skip to content

Commit

Permalink
Revert "refactoring iluwatar#1012: Remove deprecated method to ease H…
Browse files Browse the repository at this point in the history
…ibernate upgrade (iluwatar#2125)"

This reverts commit 9822f04.
  • Loading branch information
robertvolkmann committed Nov 6, 2022
1 parent 8ceb926 commit c779252
Show file tree
Hide file tree
Showing 5 changed files with 30 additions and 58 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -27,12 +27,10 @@
import com.iluwatar.servicelayer.hibernate.HibernateUtil;
import java.lang.reflect.ParameterizedType;
import java.util.List;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;
import org.hibernate.Criteria;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.query.Query;
import org.hibernate.criterion.Restrictions;

/**
* Base class for Dao implementations.
Expand All @@ -59,12 +57,9 @@ public E find(Long id) {
E result;
try (var session = getSessionFactory().openSession()) {
tx = session.beginTransaction();
CriteriaBuilder criteriaBuilder = session.getCriteriaBuilder();
CriteriaQuery<E> builderQuery = criteriaBuilder.createQuery(persistentClass);
Root<E> root = builderQuery.from(persistentClass);
builderQuery.select(root).where(criteriaBuilder.equal(root.get("id"), id));
Query<E> query = session.createQuery(builderQuery);
result = query.uniqueResult();
var criteria = session.createCriteria(persistentClass);
criteria.add(Restrictions.idEq(id));
result = (E) criteria.uniqueResult();
tx.commit();
} catch (Exception e) {
if (tx != null) {
Expand Down Expand Up @@ -128,12 +123,8 @@ public List<E> findAll() {
List<E> result;
try (var session = getSessionFactory().openSession()) {
tx = session.beginTransaction();
CriteriaBuilder criteriaBuilder = session.getCriteriaBuilder();
CriteriaQuery<E> builderQuery = criteriaBuilder.createQuery(persistentClass);
Root<E> root = builderQuery.from(persistentClass);
builderQuery.select(root);
Query<E> query = session.createQuery(builderQuery);
result = query.getResultList();
Criteria criteria = session.createCriteria(persistentClass);
result = criteria.list();
} catch (Exception e) {
if (tx != null) {
tx.rollback();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,12 +25,8 @@
package com.iluwatar.servicelayer.spell;

import com.iluwatar.servicelayer.common.DaoBaseImpl;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;
import org.hibernate.Transaction;
import org.hibernate.query.Query;

import org.hibernate.criterion.Restrictions;

/**
* SpellDao implementation.
Expand All @@ -43,12 +39,9 @@ public Spell findByName(String name) {
Spell result;
try (var session = getSessionFactory().openSession()) {
tx = session.beginTransaction();
CriteriaBuilder criteriaBuilder = session.getCriteriaBuilder();
CriteriaQuery<Spell> builderQuery = criteriaBuilder.createQuery(Spell.class);
Root<Spell> root = builderQuery.from(Spell.class);
builderQuery.select(root).where(criteriaBuilder.equal(root.get("name"), name));
Query<Spell> query = session.createQuery(builderQuery);
result = query.uniqueResult();
var criteria = session.createCriteria(persistentClass);
criteria.add(Restrictions.eq("name", name));
result = (Spell) criteria.uniqueResult();
tx.commit();
} catch (Exception e) {
if (tx != null) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,12 +25,8 @@
package com.iluwatar.servicelayer.spellbook;

import com.iluwatar.servicelayer.common.DaoBaseImpl;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;
import org.hibernate.Transaction;
import org.hibernate.query.Query;

import org.hibernate.criterion.Restrictions;

/**
* SpellbookDao implementation.
Expand All @@ -43,12 +39,9 @@ public Spellbook findByName(String name) {
Spellbook result;
try (var session = getSessionFactory().openSession()) {
tx = session.beginTransaction();
CriteriaBuilder criteriaBuilder = session.getCriteriaBuilder();
CriteriaQuery<Spellbook> builderQuery = criteriaBuilder.createQuery(Spellbook.class);
Root<Spellbook> root = builderQuery.from(Spellbook.class);
builderQuery.select(root).where(criteriaBuilder.equal(root.get("name"), name));
Query<Spellbook> query = session.createQuery(builderQuery);
result = query.uniqueResult();
var criteria = session.createCriteria(persistentClass);
criteria.add(Restrictions.eq("name", name));
result = (Spellbook) criteria.uniqueResult();
tx.commit();
} catch (Exception e) {
if (tx != null) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,11 +25,8 @@
package com.iluwatar.servicelayer.wizard;

import com.iluwatar.servicelayer.common.DaoBaseImpl;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;
import org.hibernate.Transaction;
import org.hibernate.query.Query;
import org.hibernate.criterion.Restrictions;

/**
* WizardDao implementation.
Expand All @@ -42,12 +39,9 @@ public Wizard findByName(String name) {
Wizard result;
try (var session = getSessionFactory().openSession()) {
tx = session.beginTransaction();
CriteriaBuilder criteriaBuilder = session.getCriteriaBuilder();
CriteriaQuery<Wizard> builderQuery = criteriaBuilder.createQuery(Wizard.class);
Root<Wizard> root = builderQuery.from(Wizard.class);
builderQuery.select(root).where(criteriaBuilder.equal(root.get("name"), name));
Query<Wizard> query = session.createQuery(builderQuery);
result = query.uniqueResult();
var criteria = session.createCriteria(persistentClass);
criteria.add(Restrictions.eq("name", name));
result = (Wizard) criteria.uniqueResult();
tx.commit();
} catch (Exception e) {
if (tx != null) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,10 +26,11 @@

import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertNotNull;
import static org.mockito.Matchers.eq;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.verifyNoInteractions;
import static org.mockito.Mockito.verifyNoMoreInteractions;
import static org.mockito.Mockito.verifyZeroInteractions;
import static org.mockito.Mockito.when;

import com.iluwatar.servicelayer.spell.Spell;
Expand All @@ -55,7 +56,7 @@ void testFindAllWizards() {
final var spellDao = mock(SpellDao.class);

final var service = new MagicServiceImpl(wizardDao, spellbookDao, spellDao);
verifyNoInteractions(wizardDao, spellbookDao, spellDao);
verifyZeroInteractions(wizardDao, spellbookDao, spellDao);

service.findAllWizards();
verify(wizardDao).findAll();
Expand All @@ -69,7 +70,7 @@ void testFindAllSpellbooks() {
final var spellDao = mock(SpellDao.class);

final var service = new MagicServiceImpl(wizardDao, spellbookDao, spellDao);
verifyNoInteractions(wizardDao, spellbookDao, spellDao);
verifyZeroInteractions(wizardDao, spellbookDao, spellDao);

service.findAllSpellbooks();
verify(spellbookDao).findAll();
Expand All @@ -83,7 +84,7 @@ void testFindAllSpells() {
final var spellDao = mock(SpellDao.class);

final var service = new MagicServiceImpl(wizardDao, spellbookDao, spellDao);
verifyNoInteractions(wizardDao, spellbookDao, spellDao);
verifyZeroInteractions(wizardDao, spellbookDao, spellDao);

service.findAllSpells();
verify(spellDao).findAll();
Expand All @@ -102,17 +103,17 @@ void testFindWizardsWithSpellbook() {
when(spellbook.getWizards()).thenReturn(wizards);

final var spellbookDao = mock(SpellbookDao.class);
when(spellbookDao.findByName(bookname)).thenReturn(spellbook);
when(spellbookDao.findByName(eq(bookname))).thenReturn(spellbook);

final var wizardDao = mock(WizardDao.class);
final var spellDao = mock(SpellDao.class);


final var service = new MagicServiceImpl(wizardDao, spellbookDao, spellDao);
verifyNoInteractions(wizardDao, spellbookDao, spellDao, spellbook);
verifyZeroInteractions(wizardDao, spellbookDao, spellDao, spellbook);

final var result = service.findWizardsWithSpellbook(bookname);
verify(spellbookDao).findByName(bookname);
verify(spellbookDao).findByName(eq(bookname));
verify(spellbook).getWizards();

assertNotNull(result);
Expand All @@ -139,13 +140,13 @@ void testFindWizardsWithSpell() throws Exception {

final var spellName = "spellname";
final var spellDao = mock(SpellDao.class);
when(spellDao.findByName(spellName)).thenReturn(spell);
when(spellDao.findByName(eq(spellName))).thenReturn(spell);

final var service = new MagicServiceImpl(wizardDao, spellbookDao, spellDao);
verifyNoInteractions(wizardDao, spellbookDao, spellDao, spellbook);
verifyZeroInteractions(wizardDao, spellbookDao, spellDao, spellbook);

final var result = service.findWizardsWithSpell(spellName);
verify(spellDao).findByName(spellName);
verify(spellDao).findByName(eq(spellName));
verify(spellbook).getWizards();

assertNotNull(result);
Expand Down

0 comments on commit c779252

Please sign in to comment.