2
Я пытаюсь реализовать интеграционный тест litte с использованием Arquillian и Wildfly 8.2.
Сохранение и поиск через диспетчер объектов работает, но с помощью запросов любого типа ничего не найдено.Запросы любого вида не обнаружены.
Мой тестовый класс:
@RunWith(Arquillian.class)
public class VoteServiceTest {
@Inject
private EntityManager entityManager;
@Before
public void createEntityManager() {
entityManager.persist(user);
entityManager.persist(vote);
}
@Test
public void justATest() {
Assert.assertTrue(entityManager.find(User.class, 1L) != null); // Works
Assert.assertTrue(entityManager.find(Vote.class, 4L) != null); // Works
Assert.assertTrue(entityManager.createQuery("SELECT c FROM Vote c", Vote.class).getResultList() == 1); // Fails
}
@Deployment
public static JavaArchive createDeployment() {
return ShrinkWrap.create(JavaArchive.class).addPackages(true, "de/...")
.addAsResource("META-INF/persistence.xml", "META-INF/persistence.xml")
.addAsManifestResource(EmptyAsset.INSTANCE, "beans.xml");
}
}
persistence.xml:
<persistence ...>
<persistence-unit name="test" transaction-type="RESOURCE_LOCAL">
<class>de....Vote</class>
<class>de....User</class>
<properties>
<property name="hibernate.hbm2ddl.auto" value="create"/>
<property name="hibernate.dialect" value="org.hibernate.dialect.HSQLDialect"/>
<property name="hibernate.connection.driver_class" value="org.hsqldb.jdbcDriver"/>
<property name="hibernate.connection.url" value="jdbc:hsqldb:mem:test"/>
<property name="hibernate.show_sql" value="true"/>
</properties>
</persistence-unit>
</persistence>
Что я пропустил?
Определить, «что отсутствует сущность». Что происходит * точно *? –
'voteRepository.findAll()' должен возвращать список, содержащий 1 элемент, но он пуст. – CSchulz