[ https://issues.apache.org/jira/browse/FELIX-5898?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=16569559#comment-16569559 ]
ASF GitHub Bot commented on FELIX-5898: --------------------------------------- GitHub user cvgaviao opened a pull request: https://github.com/apache/felix/pull/148 Fixing FELIX-5898 added java.io.Serializable to org.apache.felix.configurator.impl.json.OrderedDictionary You can merge this pull request into a Git repository by running: $ git pull https://github.com/cvgaviao/felix FELIX-5898 Alternatively you can review and apply these changes as the patch at: https://github.com/apache/felix/pull/148.patch To close this pull request, make a commit to your master/trunk branch with (at least) the following in the commit message: This closes #148 ---- commit cf774aa6d4622a4d235b63a1649ad82cbb669f2f Author: Cristiano Gavião <cvgaviao@...> Date: 2018-08-05T19:03:43Z Fixing FELIX-5898 added java.io.Serializable to org.apache.felix.configurator.impl.json.OrderedDictionary ---- > java.io.NotSerializableException: > org.apache.felix.configurator.impl.json.OrderedDictionary > ------------------------------------------------------------------------------------------- > > Key: FELIX-5898 > URL: https://issues.apache.org/jira/browse/FELIX-5898 > Project: Felix > Issue Type: Bug > Components: Configurator > Affects Versions: configurator-1.0.2 > Reporter: Cristiano Gavião > Priority: Blocker > > I'm using ubuntu 18.04 with Java 8. > I've created a simple example in order to test felix.configurator bundle. > When running the example inside a Eclipse PDE I received the exception below: > {code:java} > 14:32:53.253||ERROR|Unable to persist state to > state.ser|L.org.apache.felix.configurator||L.o.a.f.configurator@?[Apache > Felix Configurator Worker Thread] > java.io.NotSerializableException: > org.apache.felix.configurator.impl.json.OrderedDictionary > at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1184) > at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:348) > at > org.apache.felix.configurator.impl.model.Config.writeObject(Config.java:80) > 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:498) > at > java.io.ObjectStreamClass.invokeWriteObject(ObjectStreamClass.java:1140) > 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 java.util.ArrayList.writeObject(ArrayList.java:766) > 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:498) > at > java.io.ObjectStreamClass.invokeWriteObject(ObjectStreamClass.java:1140) > 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 > org.apache.felix.configurator.impl.model.ConfigList.writeObject(ConfigList.java:59) > 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:498) > at > java.io.ObjectStreamClass.invokeWriteObject(ObjectStreamClass.java:1140) > 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 java.util.TreeMap.writeObject(TreeMap.java:2438) > 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:498) > at > java.io.ObjectStreamClass.invokeWriteObject(ObjectStreamClass.java:1140) > 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 > org.apache.felix.configurator.impl.model.AbstractState.writeObject(AbstractState.java:49) > 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:498) > at > java.io.ObjectStreamClass.invokeWriteObject(ObjectStreamClass.java:1140) > 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 > org.apache.felix.configurator.impl.model.State.writeState(State.java:98) > at > org.apache.felix.configurator.impl.Configurator.process(Configurator.java:398) > at > org.apache.felix.configurator.impl.Configurator$1$1.run(Configurator.java:113) > at org.apache.felix.configurator.impl.WorkerQueue.run(WorkerQueue.java:76) > at java.lang.Thread.run(Thread.java:748) > {code} > I also did some investigations and discovered that the > _*org.apache.felix.configurator.impl.json.OrderedDictionary*_ is not > implementing _java.io.Serializable_ -- This message was sent by Atlassian JIRA (v7.6.3#76005)