Uploaded image for project: 'Jenkins'
  1. Jenkins
  2. JENKINS-20416

Publish over FTP main configuration data after jenkins server reboot

    • Icon: Bug Bug
    • Resolution: Fixed
    • Icon: Critical Critical
    • Jenkins server is running on Ubuntu 12.04 LTS. Jenkins build agent running on Ubuntu 12.04 LTS.

      Jenkins Version: 1.509.4
      Publish Over FTP Version 1.9

      After jenkins server reboot, configuration is lost on main options menu. Build jobs save publish-over-ftp configuraions correctly.

      Jenkins Log:

      Nov 4, 2013 1:26:37 PM hudson.model.Descriptor load
      WARNING: Failed to load /var/lib/jenkins/jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin.xml
      hudson.util.IOException2: Unable to read /var/lib/jenkins/jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin.xml
      at hudson.XmlFile.unmarshal(XmlFile.java:170)
      at hudson.model.Descriptor.load(Descriptor.java:806)
      at jenkins.plugins.publish_over_ftp.descriptor.BapFtpPublisherPluginDescriptor.<init>(BapFtpPublisherPluginDescriptor.java:63)
      at jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor.<init>(BapFtpPublisherPlugin.java:82)
      at jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor$$FastClassByGuice$$cbb8a5f6.newInstance(<generated>)
      at com.google.inject.internal.cglib.reflect.$FastConstructor.newInstance(FastConstructor.java:40)
      at com.google.inject.internal.DefaultConstructionProxyFactory$1.newInstance(DefaultConstructionProxyFactory.java:61)
      at com.google.inject.internal.ConstructorInjector.provision(ConstructorInjector.java:108)
      at com.google.inject.internal.ConstructorInjector.construct(ConstructorInjector.java:87)
      at com.google.inject.internal.ConstructorBindingImpl$Factory.get(ConstructorBindingImpl.java:259)
      at com.google.inject.internal.ProviderToInternalFactoryAdapter$1.call(ProviderToInternalFactoryAdapter.java:46)
      at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1018)
      at com.google.inject.internal.ProviderToInternalFactoryAdapter.get(ProviderToInternalFactoryAdapter.java:40)
      at com.google.inject.Scopes$1$1.get(Scopes.java:59)
      at hudson.ExtensionFinder$GuiceFinder$4$1.get(ExtensionFinder.java:422)
      at com.google.inject.internal.InternalFactoryToProviderAdapter.get(InternalFactoryToProviderAdapter.java:41)
      at com.google.inject.internal.InjectorImpl$3$1.call(InjectorImpl.java:965)
      at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1011)
      at com.google.inject.internal.InjectorImpl$3.get(InjectorImpl.java:961)
      at hudson.ExtensionFinder$GuiceFinder._find(ExtensionFinder.java:391)
      at hudson.ExtensionFinder$GuiceFinder.find(ExtensionFinder.java:382)
      at hudson.ExtensionFinder._find(ExtensionFinder.java:151)
      at hudson.ClassicPluginStrategy.findComponents(ClassicPluginStrategy.java:318)
      at hudson.ExtensionList.load(ExtensionList.java:295)
      at hudson.ExtensionList.ensureLoaded(ExtensionList.java:248)
      at hudson.ExtensionList.iterator(ExtensionList.java:138)
      at jenkins.model.Jenkins.getDescriptorByType(Jenkins.java:1176)
      at hudson.plugins.copyartifact.BuildSelectorParameter.initAliases(BuildSelectorParameter.java:99)
      at hudson.plugins.copyartifact.CopyArtifactPlugin.postInitialize(CopyArtifactPlugin.java:35)
      at hudson.PluginManager$2$1$2.run(PluginManager.java:353)
      at org.jvnet.hudson.reactor.TaskGraphBuilder$TaskImpl.run(TaskGraphBuilder.java:146)
      at org.jvnet.hudson.reactor.Reactor.runTask(Reactor.java:259)
      at jenkins.model.Jenkins$7.runTask(Jenkins.java:888)
      at org.jvnet.hudson.reactor.Reactor$2.run(Reactor.java:187)
      at org.jvnet.hudson.reactor.Reactor$Node.run(Reactor.java:94)
      at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1146)
      at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
      at java.lang.Thread.run(Thread.java:679)
      Caused by: com.thoughtworks.xstream.converters.ConversionException: object is not an instance of declaring class : object is not an instance of declaring class
      ---- Debugging information ----
      message : object is not an instance of declaring class
      cause-exception : java.lang.IllegalArgumentException
      cause-message : object is not an instance of declaring class
      class : jenkins.plugins.publish_over_ftp.BapFtpHostConfiguration
      required-type : jenkins.plugins.publish_over_ftp.BapFtpHostConfiguration
      converter-type : hudson.util.RobustReflectionConverter
      path : /jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor/hostConfigurations/jenkins.plugins.publish_over_ftp.BapFtpHostConfiguration
      line number : 14
      class[1] : hudson.util.CopyOnWriteList
      converter-type[1] : hudson.util.XStream2$AssociatedConverterImpl
      class[2] : jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor
      version : null
      -------------------------------
      at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:79)
      at com.thoughtworks.xstream.core.AbstractReferenceUnmarshaller.convert(AbstractReferenceUnmarshaller.java:65)
      at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:66)
      at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:50)
      at com.thoughtworks.xstream.converters.collections.AbstractCollectionConverter.readItem(AbstractCollectionConverter.java:71)
      at hudson.util.CopyOnWriteList$ConverterImpl.unmarshal(CopyOnWriteList.java:193)
      at hudson.util.CopyOnWriteList$ConverterImpl.unmarshal(CopyOnWriteList.java:172)
      at hudson.util.XStream2$AssociatedConverterImpl.unmarshal(XStream2.java:337)
      at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:72)
      at com.thoughtworks.xstream.core.AbstractReferenceUnmarshaller.convert(AbstractReferenceUnmarshaller.java:65)
      at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:66)
      at hudson.util.RobustReflectionConverter.unmarshalField(RobustReflectionConverter.java:333)
      at hudson.util.RobustReflectionConverter.doUnmarshal(RobustReflectionConverter.java:275)
      at hudson.util.RobustReflectionConverter.unmarshal(RobustReflectionConverter.java:222)
      at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:72)
      at com.thoughtworks.xstream.core.AbstractReferenceUnmarshaller.convert(AbstractReferenceUnmarshaller.java:65)
      at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:66)
      at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:50)
      at com.thoughtworks.xstream.core.TreeUnmarshaller.start(TreeUnmarshaller.java:134)
      at com.thoughtworks.xstream.core.AbstractTreeMarshallingStrategy.unmarshal(AbstractTreeMarshallingStrategy.java:32)
      at com.thoughtworks.xstream.XStream.unmarshal(XStream.java:1061)
      at hudson.util.XStream2.unmarshal(XStream2.java:109)
      at com.thoughtworks.xstream.XStream.unmarshal(XStream.java:1045)
      at hudson.XmlFile.unmarshal(XmlFile.java:166)
      ... 37 more
      Caused by: java.lang.IllegalArgumentException: object is not an instance of declaring class
      at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
      at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
      at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
      at java.lang.reflect.Method.invoke(Method.java:616)
      at com.thoughtworks.xstream.converters.reflection.SerializationMethodInvoker.callReadResolve(SerializationMethodInvoker.java:66)
      at hudson.util.RobustReflectionConverter.unmarshal(RobustReflectionConverter.java:223)
      at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:72)
      ... 60 more

          [JENKINS-20416] Publish over FTP main configuration data after jenkins server reboot

          Jonathan Kirkham created issue -
          Jonathan Kirkham made changes -
          Link New: This issue is related to JENKINS-18019 [ JENKINS-18019 ]
          Jonathan Kirkham made changes -
          Link New: This issue duplicates JENKINS-17058 [ JENKINS-17058 ]
          Jonathan Kirkham made changes -
          Component/s New: publish-over-ftp [ 15791 ]
          Component/s Original: publish-over-cifs [ 15850 ]
          Component/s Original: publish-over-ssh [ 15792 ]
          Description Original: After jenkins server reboot, configuration is lost on main options menu. Build jobs save publish-over-ssh configuaions correctly.

          A screenshot shows a configurating window after reboot.
          New: After jenkins server reboot, configuration is lost on main options menu. Build jobs save publish-over-ssh configuraions correctly.

          Jenkins Log:

          Nov 4, 2013 1:26:37 PM hudson.model.Descriptor load
          WARNING: Failed to load /var/lib/jenkins/jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin.xml
          hudson.util.IOException2: Unable to read /var/lib/jenkins/jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin.xml
                  at hudson.XmlFile.unmarshal(XmlFile.java:170)
                  at hudson.model.Descriptor.load(Descriptor.java:806)
                  at jenkins.plugins.publish_over_ftp.descriptor.BapFtpPublisherPluginDescriptor.<init>(BapFtpPublisherPluginDescriptor.java:63)
                  at jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor.<init>(BapFtpPublisherPlugin.java:82)
                  at jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor$$FastClassByGuice$$cbb8a5f6.newInstance(<generated>)
                  at com.google.inject.internal.cglib.reflect.$FastConstructor.newInstance(FastConstructor.java:40)
                  at com.google.inject.internal.DefaultConstructionProxyFactory$1.newInstance(DefaultConstructionProxyFactory.java:61)
                  at com.google.inject.internal.ConstructorInjector.provision(ConstructorInjector.java:108)
                  at com.google.inject.internal.ConstructorInjector.construct(ConstructorInjector.java:87)
                  at com.google.inject.internal.ConstructorBindingImpl$Factory.get(ConstructorBindingImpl.java:259)
                  at com.google.inject.internal.ProviderToInternalFactoryAdapter$1.call(ProviderToInternalFactoryAdapter.java:46)
                  at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1018)
                  at com.google.inject.internal.ProviderToInternalFactoryAdapter.get(ProviderToInternalFactoryAdapter.java:40)
                  at com.google.inject.Scopes$1$1.get(Scopes.java:59)
                  at hudson.ExtensionFinder$GuiceFinder$4$1.get(ExtensionFinder.java:422)
                  at com.google.inject.internal.InternalFactoryToProviderAdapter.get(InternalFactoryToProviderAdapter.java:41)
                  at com.google.inject.internal.InjectorImpl$3$1.call(InjectorImpl.java:965)
                  at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1011)
                  at com.google.inject.internal.InjectorImpl$3.get(InjectorImpl.java:961)
                  at hudson.ExtensionFinder$GuiceFinder._find(ExtensionFinder.java:391)
                  at hudson.ExtensionFinder$GuiceFinder.find(ExtensionFinder.java:382)
                  at hudson.ExtensionFinder._find(ExtensionFinder.java:151)
                  at hudson.ClassicPluginStrategy.findComponents(ClassicPluginStrategy.java:318)
                  at hudson.ExtensionList.load(ExtensionList.java:295)
                  at hudson.ExtensionList.ensureLoaded(ExtensionList.java:248)
                  at hudson.ExtensionList.iterator(ExtensionList.java:138)
                  at jenkins.model.Jenkins.getDescriptorByType(Jenkins.java:1176)
                  at hudson.plugins.copyartifact.BuildSelectorParameter.initAliases(BuildSelectorParameter.java:99)
                  at hudson.plugins.copyartifact.CopyArtifactPlugin.postInitialize(CopyArtifactPlugin.java:35)
                  at hudson.PluginManager$2$1$2.run(PluginManager.java:353)
                  at org.jvnet.hudson.reactor.TaskGraphBuilder$TaskImpl.run(TaskGraphBuilder.java:146)
                  at org.jvnet.hudson.reactor.Reactor.runTask(Reactor.java:259)
                  at jenkins.model.Jenkins$7.runTask(Jenkins.java:888)
                  at org.jvnet.hudson.reactor.Reactor$2.run(Reactor.java:187)
                  at org.jvnet.hudson.reactor.Reactor$Node.run(Reactor.java:94)
                  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1146)
                  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
                  at java.lang.Thread.run(Thread.java:679)
          Caused by: com.thoughtworks.xstream.converters.ConversionException: object is not an instance of declaring class : object is not an instance of declaring class
          ---- Debugging information ----
          message : object is not an instance of declaring class
          cause-exception : java.lang.IllegalArgumentException
          cause-message : object is not an instance of declaring class
          class : jenkins.plugins.publish_over_ftp.BapFtpHostConfiguration
          required-type : jenkins.plugins.publish_over_ftp.BapFtpHostConfiguration
          converter-type : hudson.util.RobustReflectionConverter
          path : /jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor/hostConfigurations/jenkins.plugins.publish_over_ftp.BapFtpHostConfiguration
          line number : 14
          class[1] : hudson.util.CopyOnWriteList
          converter-type[1] : hudson.util.XStream2$AssociatedConverterImpl
          class[2] : jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor
          version : null
          -------------------------------
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:79)
                  at com.thoughtworks.xstream.core.AbstractReferenceUnmarshaller.convert(AbstractReferenceUnmarshaller.java:65)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:66)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:50)
                  at com.thoughtworks.xstream.converters.collections.AbstractCollectionConverter.readItem(AbstractCollectionConverter.java:71)
                  at hudson.util.CopyOnWriteList$ConverterImpl.unmarshal(CopyOnWriteList.java:193)
                  at hudson.util.CopyOnWriteList$ConverterImpl.unmarshal(CopyOnWriteList.java:172)
                  at hudson.util.XStream2$AssociatedConverterImpl.unmarshal(XStream2.java:337)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:72)
                  at com.thoughtworks.xstream.core.AbstractReferenceUnmarshaller.convert(AbstractReferenceUnmarshaller.java:65)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:66)
                  at hudson.util.RobustReflectionConverter.unmarshalField(RobustReflectionConverter.java:333)
                  at hudson.util.RobustReflectionConverter.doUnmarshal(RobustReflectionConverter.java:275)
                  at hudson.util.RobustReflectionConverter.unmarshal(RobustReflectionConverter.java:222)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:72)
                  at com.thoughtworks.xstream.core.AbstractReferenceUnmarshaller.convert(AbstractReferenceUnmarshaller.java:65)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:66)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:50)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.start(TreeUnmarshaller.java:134)
                  at com.thoughtworks.xstream.core.AbstractTreeMarshallingStrategy.unmarshal(AbstractTreeMarshallingStrategy.java:32)
                  at com.thoughtworks.xstream.XStream.unmarshal(XStream.java:1061)
                  at hudson.util.XStream2.unmarshal(XStream2.java:109)
                  at com.thoughtworks.xstream.XStream.unmarshal(XStream.java:1045)
                  at hudson.XmlFile.unmarshal(XmlFile.java:166)
                  ... 37 more
          Caused by: java.lang.IllegalArgumentException: object is not an instance of declaring class
                  at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
                  at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
                  at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
                  at java.lang.reflect.Method.invoke(Method.java:616)
                  at com.thoughtworks.xstream.converters.reflection.SerializationMethodInvoker.callReadResolve(SerializationMethodInvoker.java:66)
                  at hudson.util.RobustReflectionConverter.unmarshal(RobustReflectionConverter.java:223)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:72)
                  ... 60 more

          Labels Original: LTS configuration jenkins plugin slave New: LTS configuration jenkins plugin
          Jonathan Kirkham made changes -
          Link Original: This issue duplicates JENKINS-17058 [ JENKINS-17058 ]
          Jonathan Kirkham made changes -
          Link New: This issue is related to JENKINS-17885 [ JENKINS-17885 ]
          Jonathan Kirkham made changes -
          Description Original: After jenkins server reboot, configuration is lost on main options menu. Build jobs save publish-over-ssh configuraions correctly.

          Jenkins Log:

          Nov 4, 2013 1:26:37 PM hudson.model.Descriptor load
          WARNING: Failed to load /var/lib/jenkins/jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin.xml
          hudson.util.IOException2: Unable to read /var/lib/jenkins/jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin.xml
                  at hudson.XmlFile.unmarshal(XmlFile.java:170)
                  at hudson.model.Descriptor.load(Descriptor.java:806)
                  at jenkins.plugins.publish_over_ftp.descriptor.BapFtpPublisherPluginDescriptor.<init>(BapFtpPublisherPluginDescriptor.java:63)
                  at jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor.<init>(BapFtpPublisherPlugin.java:82)
                  at jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor$$FastClassByGuice$$cbb8a5f6.newInstance(<generated>)
                  at com.google.inject.internal.cglib.reflect.$FastConstructor.newInstance(FastConstructor.java:40)
                  at com.google.inject.internal.DefaultConstructionProxyFactory$1.newInstance(DefaultConstructionProxyFactory.java:61)
                  at com.google.inject.internal.ConstructorInjector.provision(ConstructorInjector.java:108)
                  at com.google.inject.internal.ConstructorInjector.construct(ConstructorInjector.java:87)
                  at com.google.inject.internal.ConstructorBindingImpl$Factory.get(ConstructorBindingImpl.java:259)
                  at com.google.inject.internal.ProviderToInternalFactoryAdapter$1.call(ProviderToInternalFactoryAdapter.java:46)
                  at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1018)
                  at com.google.inject.internal.ProviderToInternalFactoryAdapter.get(ProviderToInternalFactoryAdapter.java:40)
                  at com.google.inject.Scopes$1$1.get(Scopes.java:59)
                  at hudson.ExtensionFinder$GuiceFinder$4$1.get(ExtensionFinder.java:422)
                  at com.google.inject.internal.InternalFactoryToProviderAdapter.get(InternalFactoryToProviderAdapter.java:41)
                  at com.google.inject.internal.InjectorImpl$3$1.call(InjectorImpl.java:965)
                  at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1011)
                  at com.google.inject.internal.InjectorImpl$3.get(InjectorImpl.java:961)
                  at hudson.ExtensionFinder$GuiceFinder._find(ExtensionFinder.java:391)
                  at hudson.ExtensionFinder$GuiceFinder.find(ExtensionFinder.java:382)
                  at hudson.ExtensionFinder._find(ExtensionFinder.java:151)
                  at hudson.ClassicPluginStrategy.findComponents(ClassicPluginStrategy.java:318)
                  at hudson.ExtensionList.load(ExtensionList.java:295)
                  at hudson.ExtensionList.ensureLoaded(ExtensionList.java:248)
                  at hudson.ExtensionList.iterator(ExtensionList.java:138)
                  at jenkins.model.Jenkins.getDescriptorByType(Jenkins.java:1176)
                  at hudson.plugins.copyartifact.BuildSelectorParameter.initAliases(BuildSelectorParameter.java:99)
                  at hudson.plugins.copyartifact.CopyArtifactPlugin.postInitialize(CopyArtifactPlugin.java:35)
                  at hudson.PluginManager$2$1$2.run(PluginManager.java:353)
                  at org.jvnet.hudson.reactor.TaskGraphBuilder$TaskImpl.run(TaskGraphBuilder.java:146)
                  at org.jvnet.hudson.reactor.Reactor.runTask(Reactor.java:259)
                  at jenkins.model.Jenkins$7.runTask(Jenkins.java:888)
                  at org.jvnet.hudson.reactor.Reactor$2.run(Reactor.java:187)
                  at org.jvnet.hudson.reactor.Reactor$Node.run(Reactor.java:94)
                  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1146)
                  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
                  at java.lang.Thread.run(Thread.java:679)
          Caused by: com.thoughtworks.xstream.converters.ConversionException: object is not an instance of declaring class : object is not an instance of declaring class
          ---- Debugging information ----
          message : object is not an instance of declaring class
          cause-exception : java.lang.IllegalArgumentException
          cause-message : object is not an instance of declaring class
          class : jenkins.plugins.publish_over_ftp.BapFtpHostConfiguration
          required-type : jenkins.plugins.publish_over_ftp.BapFtpHostConfiguration
          converter-type : hudson.util.RobustReflectionConverter
          path : /jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor/hostConfigurations/jenkins.plugins.publish_over_ftp.BapFtpHostConfiguration
          line number : 14
          class[1] : hudson.util.CopyOnWriteList
          converter-type[1] : hudson.util.XStream2$AssociatedConverterImpl
          class[2] : jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor
          version : null
          -------------------------------
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:79)
                  at com.thoughtworks.xstream.core.AbstractReferenceUnmarshaller.convert(AbstractReferenceUnmarshaller.java:65)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:66)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:50)
                  at com.thoughtworks.xstream.converters.collections.AbstractCollectionConverter.readItem(AbstractCollectionConverter.java:71)
                  at hudson.util.CopyOnWriteList$ConverterImpl.unmarshal(CopyOnWriteList.java:193)
                  at hudson.util.CopyOnWriteList$ConverterImpl.unmarshal(CopyOnWriteList.java:172)
                  at hudson.util.XStream2$AssociatedConverterImpl.unmarshal(XStream2.java:337)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:72)
                  at com.thoughtworks.xstream.core.AbstractReferenceUnmarshaller.convert(AbstractReferenceUnmarshaller.java:65)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:66)
                  at hudson.util.RobustReflectionConverter.unmarshalField(RobustReflectionConverter.java:333)
                  at hudson.util.RobustReflectionConverter.doUnmarshal(RobustReflectionConverter.java:275)
                  at hudson.util.RobustReflectionConverter.unmarshal(RobustReflectionConverter.java:222)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:72)
                  at com.thoughtworks.xstream.core.AbstractReferenceUnmarshaller.convert(AbstractReferenceUnmarshaller.java:65)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:66)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:50)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.start(TreeUnmarshaller.java:134)
                  at com.thoughtworks.xstream.core.AbstractTreeMarshallingStrategy.unmarshal(AbstractTreeMarshallingStrategy.java:32)
                  at com.thoughtworks.xstream.XStream.unmarshal(XStream.java:1061)
                  at hudson.util.XStream2.unmarshal(XStream2.java:109)
                  at com.thoughtworks.xstream.XStream.unmarshal(XStream.java:1045)
                  at hudson.XmlFile.unmarshal(XmlFile.java:166)
                  ... 37 more
          Caused by: java.lang.IllegalArgumentException: object is not an instance of declaring class
                  at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
                  at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
                  at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
                  at java.lang.reflect.Method.invoke(Method.java:616)
                  at com.thoughtworks.xstream.converters.reflection.SerializationMethodInvoker.callReadResolve(SerializationMethodInvoker.java:66)
                  at hudson.util.RobustReflectionConverter.unmarshal(RobustReflectionConverter.java:223)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:72)
                  ... 60 more

          New: After jenkins server reboot, configuration is lost on main options menu. Build jobs save publish-over-ftp configuraions correctly.

          Jenkins Log:

          Nov 4, 2013 1:26:37 PM hudson.model.Descriptor load
          WARNING: Failed to load /var/lib/jenkins/jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin.xml
          hudson.util.IOException2: Unable to read /var/lib/jenkins/jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin.xml
                  at hudson.XmlFile.unmarshal(XmlFile.java:170)
                  at hudson.model.Descriptor.load(Descriptor.java:806)
                  at jenkins.plugins.publish_over_ftp.descriptor.BapFtpPublisherPluginDescriptor.<init>(BapFtpPublisherPluginDescriptor.java:63)
                  at jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor.<init>(BapFtpPublisherPlugin.java:82)
                  at jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor$$FastClassByGuice$$cbb8a5f6.newInstance(<generated>)
                  at com.google.inject.internal.cglib.reflect.$FastConstructor.newInstance(FastConstructor.java:40)
                  at com.google.inject.internal.DefaultConstructionProxyFactory$1.newInstance(DefaultConstructionProxyFactory.java:61)
                  at com.google.inject.internal.ConstructorInjector.provision(ConstructorInjector.java:108)
                  at com.google.inject.internal.ConstructorInjector.construct(ConstructorInjector.java:87)
                  at com.google.inject.internal.ConstructorBindingImpl$Factory.get(ConstructorBindingImpl.java:259)
                  at com.google.inject.internal.ProviderToInternalFactoryAdapter$1.call(ProviderToInternalFactoryAdapter.java:46)
                  at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1018)
                  at com.google.inject.internal.ProviderToInternalFactoryAdapter.get(ProviderToInternalFactoryAdapter.java:40)
                  at com.google.inject.Scopes$1$1.get(Scopes.java:59)
                  at hudson.ExtensionFinder$GuiceFinder$4$1.get(ExtensionFinder.java:422)
                  at com.google.inject.internal.InternalFactoryToProviderAdapter.get(InternalFactoryToProviderAdapter.java:41)
                  at com.google.inject.internal.InjectorImpl$3$1.call(InjectorImpl.java:965)
                  at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1011)
                  at com.google.inject.internal.InjectorImpl$3.get(InjectorImpl.java:961)
                  at hudson.ExtensionFinder$GuiceFinder._find(ExtensionFinder.java:391)
                  at hudson.ExtensionFinder$GuiceFinder.find(ExtensionFinder.java:382)
                  at hudson.ExtensionFinder._find(ExtensionFinder.java:151)
                  at hudson.ClassicPluginStrategy.findComponents(ClassicPluginStrategy.java:318)
                  at hudson.ExtensionList.load(ExtensionList.java:295)
                  at hudson.ExtensionList.ensureLoaded(ExtensionList.java:248)
                  at hudson.ExtensionList.iterator(ExtensionList.java:138)
                  at jenkins.model.Jenkins.getDescriptorByType(Jenkins.java:1176)
                  at hudson.plugins.copyartifact.BuildSelectorParameter.initAliases(BuildSelectorParameter.java:99)
                  at hudson.plugins.copyartifact.CopyArtifactPlugin.postInitialize(CopyArtifactPlugin.java:35)
                  at hudson.PluginManager$2$1$2.run(PluginManager.java:353)
                  at org.jvnet.hudson.reactor.TaskGraphBuilder$TaskImpl.run(TaskGraphBuilder.java:146)
                  at org.jvnet.hudson.reactor.Reactor.runTask(Reactor.java:259)
                  at jenkins.model.Jenkins$7.runTask(Jenkins.java:888)
                  at org.jvnet.hudson.reactor.Reactor$2.run(Reactor.java:187)
                  at org.jvnet.hudson.reactor.Reactor$Node.run(Reactor.java:94)
                  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1146)
                  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
                  at java.lang.Thread.run(Thread.java:679)
          Caused by: com.thoughtworks.xstream.converters.ConversionException: object is not an instance of declaring class : object is not an instance of declaring class
          ---- Debugging information ----
          message : object is not an instance of declaring class
          cause-exception : java.lang.IllegalArgumentException
          cause-message : object is not an instance of declaring class
          class : jenkins.plugins.publish_over_ftp.BapFtpHostConfiguration
          required-type : jenkins.plugins.publish_over_ftp.BapFtpHostConfiguration
          converter-type : hudson.util.RobustReflectionConverter
          path : /jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor/hostConfigurations/jenkins.plugins.publish_over_ftp.BapFtpHostConfiguration
          line number : 14
          class[1] : hudson.util.CopyOnWriteList
          converter-type[1] : hudson.util.XStream2$AssociatedConverterImpl
          class[2] : jenkins.plugins.publish_over_ftp.BapFtpPublisherPlugin$Descriptor
          version : null
          -------------------------------
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:79)
                  at com.thoughtworks.xstream.core.AbstractReferenceUnmarshaller.convert(AbstractReferenceUnmarshaller.java:65)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:66)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:50)
                  at com.thoughtworks.xstream.converters.collections.AbstractCollectionConverter.readItem(AbstractCollectionConverter.java:71)
                  at hudson.util.CopyOnWriteList$ConverterImpl.unmarshal(CopyOnWriteList.java:193)
                  at hudson.util.CopyOnWriteList$ConverterImpl.unmarshal(CopyOnWriteList.java:172)
                  at hudson.util.XStream2$AssociatedConverterImpl.unmarshal(XStream2.java:337)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:72)
                  at com.thoughtworks.xstream.core.AbstractReferenceUnmarshaller.convert(AbstractReferenceUnmarshaller.java:65)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:66)
                  at hudson.util.RobustReflectionConverter.unmarshalField(RobustReflectionConverter.java:333)
                  at hudson.util.RobustReflectionConverter.doUnmarshal(RobustReflectionConverter.java:275)
                  at hudson.util.RobustReflectionConverter.unmarshal(RobustReflectionConverter.java:222)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:72)
                  at com.thoughtworks.xstream.core.AbstractReferenceUnmarshaller.convert(AbstractReferenceUnmarshaller.java:65)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:66)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convertAnother(TreeUnmarshaller.java:50)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.start(TreeUnmarshaller.java:134)
                  at com.thoughtworks.xstream.core.AbstractTreeMarshallingStrategy.unmarshal(AbstractTreeMarshallingStrategy.java:32)
                  at com.thoughtworks.xstream.XStream.unmarshal(XStream.java:1061)
                  at hudson.util.XStream2.unmarshal(XStream2.java:109)
                  at com.thoughtworks.xstream.XStream.unmarshal(XStream.java:1045)
                  at hudson.XmlFile.unmarshal(XmlFile.java:166)
                  ... 37 more
          Caused by: java.lang.IllegalArgumentException: object is not an instance of declaring class
                  at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
                  at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
                  at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
                  at java.lang.reflect.Method.invoke(Method.java:616)
                  at com.thoughtworks.xstream.converters.reflection.SerializationMethodInvoker.callReadResolve(SerializationMethodInvoker.java:66)
                  at hudson.util.RobustReflectionConverter.unmarshal(RobustReflectionConverter.java:223)
                  at com.thoughtworks.xstream.core.TreeUnmarshaller.convert(TreeUnmarshaller.java:72)
                  ... 60 more

          Environment Original: Jenkins server is running on Windows Server 2008. Jenkins build agent running on Ubuntu 12.04 LTS. New: Jenkins server is running on Ubuntu 12.04 LTS. Jenkins build agent running on Ubuntu 12.04 LTS.
          Jonathan Kirkham made changes -
          Environment Original: Jenkins server is running on Ubuntu 12.04 LTS. Jenkins build agent running on Ubuntu 12.04 LTS. New: Jenkins server is running on Ubuntu 12.04 LTS. Jenkins build agent running on Ubuntu 12.04 LTS.

          Jenkins Version: 1.509.4
          Publish Over FTP Version 1.9
          R. Tyler Croy made changes -
          Workflow Original: JNJira [ 151940 ] New: JNJira + In-Review [ 178122 ]
          Alex Earl made changes -
          Assignee Original: bap [ bap ] New: Alex Earl [ slide_o_mix ]
          Alex Earl made changes -
          Resolution New: Fixed [ 1 ]
          Status Original: Open [ 1 ] New: Resolved [ 5 ]

            slide_o_mix Alex Earl
            jonkirkham Jonathan Kirkham
            Votes:
            0 Vote for this issue
            Watchers:
            3 Start watching this issue

              Created:
              Updated:
              Resolved: