From 27982d0c12bbdf7a77f69543ddf4ae62b5a37798 Mon Sep 17 00:00:00 2001 From: Chris Cranford Date: Tue, 22 Nov 2016 23:17:11 -0500 Subject: [PATCH] HHH-11215 - Fix NullPointerException when collection of embeddables reference an unaudited entity. (cherry picked from commit b1a9676146bb073cec07a44d634a1f20b763ccb7) --- .../entities/mapper/relation/ToOneIdMapper.java | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/hibernate-envers/src/main/java/org/hibernate/envers/internal/entities/mapper/relation/ToOneIdMapper.java b/hibernate-envers/src/main/java/org/hibernate/envers/internal/entities/mapper/relation/ToOneIdMapper.java index d1c6d0836b..d532cf7ac7 100644 --- a/hibernate-envers/src/main/java/org/hibernate/envers/internal/entities/mapper/relation/ToOneIdMapper.java +++ b/hibernate-envers/src/main/java/org/hibernate/envers/internal/entities/mapper/relation/ToOneIdMapper.java @@ -104,7 +104,15 @@ public class ToOneIdMapper extends AbstractToOneMapper { boolean ignoreNotFound = false; if ( !referencedEntity.isAudited() ) { final String referencingEntityName = enversService.getEntitiesConfigurations().getEntityNameForVersionsEntityName( (String) data.get( "$type$" ) ); - ignoreNotFound = enversService.getEntitiesConfigurations().getRelationDescription( referencingEntityName, getPropertyData().getName() ).isIgnoreNotFound(); + if ( referencingEntityName == null && primaryKey == null ) { + // HHH-11215 - Fix for NPE when Embeddable with ManyToOne inside ElementCollection + // an embeddable in an element-collection + // todo: perhaps the mapper should account for this instead? + ignoreNotFound = true; + } + else { + ignoreNotFound = enversService.getEntitiesConfigurations().getRelationDescription( referencingEntityName, getPropertyData().getName() ).isIgnoreNotFound(); + } } if ( ignoreNotFound ) { // Eagerly loading referenced entity to silence potential (in case of proxy)