mirror of
https://github.com/hibernate/hibernate-orm
synced 2025-02-08 20:24:46 +00:00
HHH-11294 - NPE in org.hibernate.jpa.internal.util.PersistenceUtilHelper.isInitialized(PersistentAttributeInterceptable)
This commit is contained in:
parent
f4f50aa5c8
commit
1a36ff0b3e
@ -94,7 +94,7 @@ else if ( reference instanceof PersistentCollection ) {
|
|||||||
@SuppressWarnings("SimplifiableIfStatement")
|
@SuppressWarnings("SimplifiableIfStatement")
|
||||||
private static boolean isInitialized(PersistentAttributeInterceptable interceptable) {
|
private static boolean isInitialized(PersistentAttributeInterceptable interceptable) {
|
||||||
final LazyAttributeLoadingInterceptor interceptor = extractInterceptor( interceptable );
|
final LazyAttributeLoadingInterceptor interceptor = extractInterceptor( interceptable );
|
||||||
return interceptable == null || !interceptor.hasAnyUninitializedAttributes();
|
return interceptable == null || interceptor == null || !interceptor.hasAnyUninitializedAttributes();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static LazyAttributeLoadingInterceptor extractInterceptor(PersistentAttributeInterceptable interceptable) {
|
private static LazyAttributeLoadingInterceptor extractInterceptor(PersistentAttributeInterceptable interceptable) {
|
||||||
|
@ -8,11 +8,14 @@
|
|||||||
|
|
||||||
import javax.persistence.spi.LoadState;
|
import javax.persistence.spi.LoadState;
|
||||||
|
|
||||||
import org.junit.Test;
|
import org.hibernate.engine.spi.PersistentAttributeInterceptable;
|
||||||
|
import org.hibernate.engine.spi.PersistentAttributeInterceptor;
|
||||||
import org.hibernate.jpa.internal.util.PersistenceUtilHelper;
|
import org.hibernate.jpa.internal.util.PersistenceUtilHelper;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests for HHH-5094 and HHH-5334
|
* Tests for HHH-5094 and HHH-5334
|
||||||
*
|
*
|
||||||
@ -50,51 +53,96 @@ public String getPublicAccessPropertyValue() {
|
|||||||
return publicAccessProperty;
|
return publicAccessProperty;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIsLoadedWithReferencePublicField() {
|
public void testIsLoadedWithReferencePublicField() {
|
||||||
assertEquals(
|
assertEquals(
|
||||||
LoadState.UNKNOWN,
|
LoadState.UNKNOWN,
|
||||||
PersistenceUtilHelper.isLoadedWithReference( new FieldAccessBean(), "publicAccessProperty", cache )
|
PersistenceUtilHelper.isLoadedWithReference(
|
||||||
|
new FieldAccessBean(),
|
||||||
|
"publicAccessProperty",
|
||||||
|
cache
|
||||||
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIsLoadedWithReferencePublicMethod() {
|
public void testIsLoadedWithReferencePublicMethod() {
|
||||||
assertEquals(
|
assertEquals(
|
||||||
LoadState.UNKNOWN,
|
LoadState.UNKNOWN,
|
||||||
PersistenceUtilHelper.isLoadedWithReference(
|
PersistenceUtilHelper.isLoadedWithReference(
|
||||||
new MethodAccessBean(), "publicAccessPropertyValue", cache
|
new MethodAccessBean(),
|
||||||
|
"publicAccessPropertyValue",
|
||||||
|
cache
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIsLoadedWithReferenceProtectedField() {
|
public void testIsLoadedWithReferenceProtectedField() {
|
||||||
assertEquals(
|
assertEquals(
|
||||||
LoadState.UNKNOWN,
|
LoadState.UNKNOWN,
|
||||||
PersistenceUtilHelper.isLoadedWithReference( new FieldAccessBean(), "protectedAccessProperty", cache )
|
PersistenceUtilHelper.isLoadedWithReference(
|
||||||
|
new FieldAccessBean(),
|
||||||
|
"protectedAccessProperty",
|
||||||
|
cache
|
||||||
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIsLoadedWithReferenceProtectedMethod() {
|
public void testIsLoadedWithReferenceProtectedMethod() {
|
||||||
assertEquals(
|
assertEquals(
|
||||||
LoadState.UNKNOWN,
|
LoadState.UNKNOWN,
|
||||||
PersistenceUtilHelper.isLoadedWithReference(
|
PersistenceUtilHelper.isLoadedWithReference(
|
||||||
new MethodAccessBean(), "protectedAccessPropertyValue", cache
|
new MethodAccessBean(),
|
||||||
|
"protectedAccessPropertyValue",
|
||||||
|
cache
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIsLoadedWithReferencePrivateField() {
|
public void testIsLoadedWithReferencePrivateField() {
|
||||||
assertEquals(
|
assertEquals(
|
||||||
LoadState.UNKNOWN,
|
LoadState.UNKNOWN,
|
||||||
PersistenceUtilHelper.isLoadedWithReference( new FieldAccessBean(), "privateAccessProperty", cache )
|
PersistenceUtilHelper.isLoadedWithReference(
|
||||||
|
new FieldAccessBean(),
|
||||||
|
"privateAccessProperty",
|
||||||
|
cache
|
||||||
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIsLoadedWithReferencePrivateMethod() {
|
public void testIsLoadedWithReferencePrivateMethod() {
|
||||||
assertEquals(
|
assertEquals(
|
||||||
LoadState.UNKNOWN,
|
LoadState.UNKNOWN,
|
||||||
PersistenceUtilHelper.isLoadedWithReference(
|
PersistenceUtilHelper.isLoadedWithReference(
|
||||||
new MethodAccessBean(), "privateAccessPropertyValue", cache
|
new MethodAccessBean(),
|
||||||
|
"privateAccessPropertyValue",
|
||||||
|
cache
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testIsLoadedWithNullInterceptor() {
|
||||||
|
assertEquals(
|
||||||
|
LoadState.LOADED,
|
||||||
|
PersistenceUtilHelper.isLoaded(
|
||||||
|
new PersistentAttributeInterceptable() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PersistentAttributeInterceptor $$_hibernate_getInterceptor() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void $$_hibernate_setInterceptor(PersistentAttributeInterceptor interceptor) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user