Одна из жалоб на предыдущие версии Entity CMP 2.
А как насчет тестирования запросов к базе данных? Нужно ли убедиться в том, что запрос findBookH2G2 корректен? Или вводить информацию в базу данных и тестировать комплексные запросы, возвращающие множественные значения? Такие интеграционные тесты потребовали бы реальной базы данных с реальной информацией, либо вы стали бы проводить модульное тестирование в изоляции, пытаясь симулировать запрос. Хорошее компромиссное решение — использовать базу данных в оперативной памяти и JPA-транзакции. CRUD-операции и JPQL-запросы могут быть протестированы с применением очень легковесной базы данных, которая не потребует запуска отдельного процесса (понадобится лишь добавить файл с расширением. jar, используя путь к соответствующему классу). Рассмотрим, как придется задействовать наш класс BookIT во встроенном режиме Derby.
Maven использует два разных каталога, один из которых применяется для размещения кода главного приложения, а другой — для тестовых классов. Класс BookIT, показанный в листинге 4.9, располагается в каталоге src/test/java и осуществляет тестирование на предмет того, может ли менеджер сущностей обеспечить постоянство сущности Book и извлекать ее из базы данных, а также удостоверяется в том, что применяются ограничения Bean Validation.
public class BookIT {
··private static EntityManagerFactory emf =
·················Persistence.createEntityManagerFactory("chapter04TestPU");
··private EntityManager em;
··private EntityTransaction tx;
··@Before
··public void initEntityManager() throws Exception {
····em = emf.createEntityManager();
····tx = em.getTransaction();
··}
··@After
··public void closeEntityManager() throws Exception {
····if (em!= null) em.close();
··}
··@Test
··public void shouldFindjavaee7Book() throws Exception {
····Book book = em.find(Book.class, 1001L);
····assertEquals("Изучаем Java EE 7", book.getTitle());
··}
··@Test
··public void shouldCreateH2G2Book() throws Exception {
····// Создает экземпляр Book
····Book book = new Book("H2G2", "Автостопом по Галактике",
····12.5F, "1-84023-742-2", 354, false);
····// Обеспечивает постоянство Book в базе данных
····tx.begin();
····em.persist(book);
····tx.commit();
····assertNotNull("ID не может быть пустым", book.getId());
····// Извлекает информацию обо всех соответствующих книгах из базы данных
····book = em.createNamedQuery("findBookH2G2", Book.class). getSingleResult();
····assertEquals("Автостопом по Галактике", book.getDescription());
··}
··@Test(expected = ConstraintViolationException.class)
··public void shouldRaiseConstraintViolationCauseNullTitle() {
····Book book = new Book(null, "Пустое название, ошибка", 12.5F,
····"1-84023-742-2", 354, false);
····em.persist(book);
··}
}