Hibernate / JPA - прослушиватель сущности не вызывается должным образом
Я пытаюсь использовать объекты EntityListener и методы обратного вызова в моем приложении Seam / Hibernate / JPA. Я использую управляемый Seam 2.2 контекст персистентности на JBoss 5.1 с PostgreSQL 9.1 на бэкэнде. У меня есть следующая заявленная сущность:
@Entity(name = "TestEntity")
@EntityListeners(TestCallback.class)
@Table(name = "tbl_test")
public class TestEntity implements Serializable {
private static final long serialVersionUID = 2016897066783042092L;
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "xxx")
@SequenceGenerator(name = "xxx", sequenceName = "xxx")
@Index(name = "xxx")
@DocumentId
private Long id = null;
@Column
private String test = null;
...
}
вместе со следующим классом обратного вызова EntityListener:
public class TestCallback {
/**
* Logger for this class
*/
private Log logger = null;
public TestCallback() {
logger = Logging.getLog(TestCallback.class);
}
@PrePersist
public void prePersist(TestEntity e) {
logger.debug("prePersist(TestEntity) - start"); //$NON-NLS-1$
logger.debug("prePersist(TestEntity) - end"); //$NON-NLS-1$
}
@PostPersist
public void postPersist(TestEntity e) {
logger.debug("postPersist(TestEntity) - start"); //$NON-NLS-1$
logger.debug("postPersist(TestEntity) - end"); //$NON-NLS-1$
}
@PostLoad
public void postLoad(TestEntity e) {
logger.debug("postLoad(TestEntity) - start"); //$NON-NLS-1$
logger.debug("postLoad(TestEntity) - end"); //$NON-NLS-1$
}
@PreUpdate
public void preUpdate(TestEntity e) {
logger.debug("preUpdate(TestEntity) - start"); //$NON-NLS-1$
logger.debug("preUpdate(TestEntity) - end"); //$NON-NLS-1$
}
@PostUpdate
public void postUpdate(TestEntity e) {
logger.debug("postUpdate(TestEntity) - start"); //$NON-NL,S-1$
logger.debug("postUpdate(TestEntity) - end"); //$NON-NLS-1$
}
@PreRemove
public void preRemove(TestEntity e) {
logger.debug("preRemove(TestEntity) - start"); //$NON-NLS-1$
logger.debug("preRemove(TestEntity) - end"); //$NON-NLS-1$
}
@PostRemove
public void postRemove(TestEntity e) {
logger.debug("postRemove(TestEntity) - start"); //$NON-NLS-1$
logger.debug("postRemove(TestEntity) - end"); //$NON-NLS-1$
}
}
Однако, когда я запускаю свой тест, я не вижу, чтобы все мои методы обратного вызова вызывались так, как я ожидал. Я провел тесты следующих сценариев:
Сохранение нового предметаОбновление существующего элементаЗагрузка предметаУдаление предметаТем не менее, единственные обратные вызовы, которые я вижу при вызове:
@PrePersist
@PreRemove
@PostLoad
@PreUpdate
Остальные обратные вызовы выполняются не так, как ожидалось. Это нормальное поведение? Я просто неправильно это понимаю? Это как-то связано с тем, как Seam управляет транзакциями? Или я просто что-то не так делаю?
Буду признателен за любую помощь, которую вы можете оказать.
РЕДАКТИРОВАТЬ: Как и требовалось, вот точный код, который я вызываю, и вывод, который я получаю:
Тест 1:
public void runTest() {
logger.debug("runTest() - start"); //$NON-NLS-1$
TestEntity e = new TestEntity();
e.setTest("XXX");
this.entityManager.persist(e);
this.entityManager.flush();
this.entityManager.clear();
logger.debug("runTest() - end"); //$NON-NLS-1$
}
Выход 1:
12:27:56,307 INFO [STDOUT] 29735 DEBUG myapp.test.web.actions.test.TestAction - - runTest() - start
12:27:56,312 INFO [STDOUT] 29740 DEBUG myapp.test.entities.TestCallback - - prePersist(TestEntity) - start
12:27:56,312 INFO [STDOUT] 29740 DEBUG myapp.test.entities.TestCallback - - prePersist(TestEntity) - end
12:27:56,347 INFO [STDOUT] 29775 DEBUG myapp.test.web.actions.test.TestAction - - runTest() - end
Тест 2:
public void runTest2() {
logger.debug("runTest2() - start"); //$NON-NLS-1$
String sql = "SELECT DISTINCT t FROM TestEntity t";
Query q = this.entityManager.createQuery(sql);
List<TestEntity> l = q.getResultList();
for (int i = 0; i < l.size(); i++) {
String x = l.get(i).getTest();
logger.debug("runTest2() - String x=" + x); //$NON-NLS-1$
}
logger.debug("runTest2() - end"); //$NON-NLS-1$
}
Выход 2:
12:28:36,964 INFO [STDOUT] 70392 DEBUG myapp.test.web.actions.test.TestAction - - runTest2() - start
12:28:36,982 INFO [STDOUT] 70410 DEBUG myapp.test.entities.TestCallback - - postLoad(TestEntity) - start
12:28:36,982 INFO [STDOUT] 70410 DEBUG myapp.test.entities.TestCallback - - postLoad(TestEntity) - end
12:28:36,982 INFO [STDOUT] 70410 DEBUG myapp.test.web.actions.test.TestAction - - runTest2() - String x=XXX
12:28:36,983 INFO [STDOUT] 70411 DEBUG myapp.test.web.actions.test.TestAction - - runTest2() - end
Тест 3:
public void runTest3() {
logger.debug("runTest3() - start"); //$NON-NLS-1$
String sql = "SELECT DISTINCT t FROM TestEntity t";
Query q = this.entityManager.createQuery(sql);
List<TestEntity> l = q.getResultList();
for (int i = 0; i < l.size(); i++) {
l.get(i).setTest("YYY" + System.currentTimeMillis());
this.entityManager.persist(l.get(i));
}
this.entityManager.flush();
this.entityManager.clear();
Random rand = new SecureRandom();
q = this.entityManager.createQuery(sql);
l = q.getResultList();
for (int i = 0; i < l.size(); i++) {
this.entityManager.remove(l.get(i));
}
this.entityManager.flush();
this.entityManager.clear();
logger.debug("runTest3() - end"); //$NON-NLS-1$
}
Выход 3:
12:30:00,404 INFO [STDOUT] 153832 DEBUG myapp.test.web.actions.test.TestAction - - runTest3() - start
12:30:00,407 INFO [STDOUT] 153835 DEBUG myapp.test.entities.TestCallback - - postLoad(TestEntity) - start
12:30:00,407 INFO [STDOUT] 153835 DEBUG myapp.test.entities.TestCallback - - postLoad(TestEntity) - end
12:30:00,408 INFO [STDOUT] 153836 DEBUG myapp.test.entities.TestCallback - - preUpdate(TestEntity) - start
12:30:00,408 INFO [STDOUT] 153836 DEBUG myapp.test.entities.TestCallback - - preUpdate(TestEntity) - end
12:30:00,410 INFO [STDOUT] 153838 DEBUG myapp.test.entities.TestCallback - - postLoad(TestEntity) - start
12:30:00,411 INFO [STDOUT] 153839 DEBUG myapp.test.entities.TestCallback - - postLoad(TestEntity) - end
12:30:00,414 INFO [STDOUT] 153842 DEBUG myapp.test.entities.TestCallback - - preRemove(TestEntity) - start
12:30:00,414 INFO [STDOUT] 153842 DEBUG myapp.test.entities.TestCallback - - preRemove(TestEntity) - end
12:30:00,453 INFO [STDOUT] 153881 DEBUG myapp.test.web.actions.test.TestAction - - runTest3() - end