Saving envers audit entry causing Lazy Initialization exception for uninitialized Lazy ManyToOne relationship

Description

Updating a legacy Hibernate 4 to latest 5.4.15 version resulted in an odd exception when saving the audit record for a record. Turning up the debugging reveals that the actual save of the record appears to proceed correctly, and then when envers begins to save it's audit entry, the Lazy initialization exception occurs. If the lazy “Owner” field is changed to be @NotAudited , the save works.

Save RelatedToTaskEntity cascades to save TaskEntity, which then moves onto the Owner entity where the exception occurs. I looked at but toggling the proxy compliance mode didn't seem to effect it. Hibernate 5.4.1 and 5.4.10 work, it appears to have broken in 5.4.11. Looking through the release notes, maybe is related?

RelatedToTaskEntity

@Table(name = "RELATED_TO_TASK")
@Audited
@Entity
public class RelatedToTaskEntity extends BaseDO<Integer> {

@javax.persistence.Column(name = "RELATED_TO_TASK_ID")
@Id
private Integer relatedToTaskId;

@Audited(targetAuditMode = RelationTargetAuditMode.NOT_AUDITED)
@ManyToOne
@JoinColumn(name = "TASK_CD")
private TaskEntity task;

TaskEntity

@Table(name = "TASK")
@Audited
@Entity
@Inheritance(strategy = InheritanceType.JOINED)
public class TaskEntity extends BaseDO<Long> {

@Column(name = "TASK_ID")
@Id
private Long id;

@Audited(targetAuditMode = RelationTargetAuditMode.NOT_AUDITED)
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "OWNER_CD", referencedColumnName = "USER_ID", updatable = false, insertable = false)
private UserInfoEntity owner;

UserInfoEntity

@Audited
@Table(name = "USER_INFO")
@Entity
@Immutable
public class UserInfoEntity extends BaseDO<Integer>

@Column(name = "USER_ID")
@Id
private Integer userId;

Activity

Show:

Details

Assignee

Reporter

Worked in

Components

Priority

Created May 6, 2020 at 6:56 PM
Updated May 12, 2020 at 1:32 PM