[
https://issues.apache.org/jira/browse/GEODE-1024?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Kirk Lund updated GEODE-1024:
-----------------------------
Description:
While running Geode with LDAP security, I hit a couple instances of
java.io.NotSerializableException.
Attached unit test reproduces this failure with a mock java.security.Principal.
{noformat}
org.apache.commons.lang.SerializationException:
java.io.NotSerializableException:
$java.security.Principal$$EnhancerByMockitoWithCGLIB$$f6f0ec86
at
org.apache.commons.lang.SerializationUtils.serialize(SerializationUtils.java:111)
at
org.apache.commons.lang.SerializationUtils.serialize(SerializationUtils.java:133)
at
org.apache.commons.lang.SerializationUtils.clone(SerializationUtils.java:80)
at
com.gemstone.gemfire.security.NotAuthorizedExceptionTest.canBeSerializedWithPrincipal(NotAuthorizedExceptionTest.java:55)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at
org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
at
org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at
org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
at
org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
at
org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
at
org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
at
com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:69)
at
com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:234)
at
com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:74)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at com.intellij.rt.execution.application.AppMain.main(AppMain.java:144)
Caused by: java.io.NotSerializableException:
$java.security.Principal$$EnhancerByMockitoWithCGLIB$$f6f0ec86
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1184)
at
java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1548)
at
java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1509)
at
java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1432)
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1178)
at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:348)
at
org.apache.commons.lang.SerializationUtils.serialize(SerializationUtils.java:108)
... 29 more
{noformat}
was:
While running Geode with LDAP security, I hit this failure:
{noformat}
7420-2: [warning 2016/02/25 19:24:34.134 PST bridgegemfire1_latvia_7420
<ServerConnection on port 26419 Thread 19> tid=0xa5] Server connection from
[identity(latvia(invalidgemfire1_latvia_7480:7480:loner):49923:843f9b1b:invalidgemfire1_latvia_7480,connection=1;
port=49924]: Unexpected Exception
com.gemstone.gemfire.SerializationException: failed serializing object
at
com.gemstone.gemfire.internal.cache.tier.sockets.Message.serializeAndAddPart(Message.java:371)
at
com.gemstone.gemfire.internal.cache.tier.sockets.Message.addObjPart(Message.java:302)
at
com.gemstone.gemfire.internal.cache.tier.sockets.Message.addObjPart(Message.java:285)
at
com.gemstone.gemfire.internal.cache.tier.sockets.BaseCommand.writeException(BaseCommand.java:636)
at
com.gemstone.gemfire.internal.cache.tier.sockets.BaseCommand.writeException(BaseCommand.java:620)
at
com.gemstone.gemfire.internal.cache.tier.sockets.command.PutUserCredentials.cmdExecute(PutUserCredentials.java:61)
at
com.gemstone.gemfire.internal.cache.tier.sockets.BaseCommand.execute(BaseCommand.java:175)
at
com.gemstone.gemfire.internal.cache.tier.sockets.ServerConnection.doNormalMsg(ServerConnection.java:796)
at
com.gemstone.gemfire.internal.cache.tier.sockets.ServerConnection.doOneMessage(ServerConnection.java:923)
at
com.gemstone.gemfire.internal.cache.tier.sockets.ServerConnection.run(ServerConnection.java:1168)
at
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at
com.gemstone.gemfire.internal.cache.tier.sockets.AcceptorImpl$1$1.run(AcceptorImpl.java:561)
at java.lang.Thread.run(Thread.java:745)
Caused by: java.io.NotSerializableException: com.sun.jndi.ldap.LdapCtx
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1184)
at
java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1548)
at
java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1509)
at
java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1432)
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1178)
at
java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1548)
at
java.io.ObjectOutputStream.defaultWriteObject(ObjectOutputStream.java:441)
at java.lang.Throwable.writeObject(Throwable.java:985)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at
java.io.ObjectStreamClass.invokeWriteObject(ObjectStreamClass.java:1028)
at
java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1496)
at
java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1432)
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1178)
at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:348)
at
com.gemstone.gemfire.internal.InternalDataSerializer.writeSerializableObject(InternalDataSerializer.java:2364)
at
com.gemstone.gemfire.internal.InternalDataSerializer.basicWriteObject(InternalDataSerializer.java:2229)
at
com.gemstone.gemfire.DataSerializer.writeObject(DataSerializer.java:3241)
at
com.gemstone.gemfire.internal.util.BlobHelper.serializeTo(BlobHelper.java:76)
at
com.gemstone.gemfire.internal.cache.tier.sockets.Message.serializeAndAddPart(Message.java:369)
... 13 more
{noformat}
While troubleshooting, I found that NotAuthroizedException has a
non-serializable member field of type java.security.Principal.
> NotAuthorizedException fails serialization because Principal member field is
> not serializable
> ---------------------------------------------------------------------------------------------
>
> Key: GEODE-1024
> URL: https://issues.apache.org/jira/browse/GEODE-1024
> Project: Geode
> Issue Type: Bug
> Components: management
> Affects Versions: 1.0.0-incubating.M2
> Reporter: Kirk Lund
> Attachments: NotAuthorizedExceptionTest.java
>
>
> While running Geode with LDAP security, I hit a couple instances of
> java.io.NotSerializableException.
> Attached unit test reproduces this failure with a mock
> java.security.Principal.
> {noformat}
> org.apache.commons.lang.SerializationException:
> java.io.NotSerializableException:
> $java.security.Principal$$EnhancerByMockitoWithCGLIB$$f6f0ec86
> at
> org.apache.commons.lang.SerializationUtils.serialize(SerializationUtils.java:111)
> at
> org.apache.commons.lang.SerializationUtils.serialize(SerializationUtils.java:133)
> at
> org.apache.commons.lang.SerializationUtils.clone(SerializationUtils.java:80)
> at
> com.gemstone.gemfire.security.NotAuthorizedExceptionTest.canBeSerializedWithPrincipal(NotAuthorizedExceptionTest.java:55)
> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
> at
> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
> at
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
> at java.lang.reflect.Method.invoke(Method.java:497)
> at
> org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
> at
> org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
> at
> org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
> at
> org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
> at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
> at
> org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
> at
> org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
> at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
> at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
> at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
> at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
> at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
> at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
> at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
> at
> com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:69)
> at
> com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:234)
> at
> com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:74)
> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
> at
> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
> at
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
> at java.lang.reflect.Method.invoke(Method.java:497)
> at com.intellij.rt.execution.application.AppMain.main(AppMain.java:144)
> Caused by: java.io.NotSerializableException:
> $java.security.Principal$$EnhancerByMockitoWithCGLIB$$f6f0ec86
> at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1184)
> at
> java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1548)
> at
> java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1509)
> at
> java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1432)
> at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1178)
> at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:348)
> at
> org.apache.commons.lang.SerializationUtils.serialize(SerializationUtils.java:108)
> ... 29 more
> {noformat}
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)