[ https://issues.apache.org/jira/browse/FELIX-1146?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Felix Meschberger closed FELIX-1146. ------------------------------------ Close all issues now this version has been released > ConfigAdmin can deliver updates to a managed service factory more than once > --------------------------------------------------------------------------- > > Key: FELIX-1146 > URL: https://issues.apache.org/jira/browse/FELIX-1146 > Project: Felix > Issue Type: Bug > Components: Configuration Admin > Affects Versions: configadmin-1.0.8 > Reporter: Angelo van der Sijpt > Assignee: Felix Meschberger > Priority: Minor > Fix For: configadmin-1.2.0 > > Attachments: Activator.java, ActivatorWithDependencyManager.java > > > When the update of a ManagedServiceFactoryConfiguration, and the registration > of that ManagedServiceFactory are close together or 'crossing', it is > possible that the update is delivered twice to the factory. > This seems to happen because of the following interleaving, with line numbers > from current trunk, rev 763614 > Some notes: > - I would have preferred to add some ascii art MSC, but unfortunately Jira > does not allow this > - Time order is top to bottom; I left out many methods for clarity > User thread: > - createFactoryConfiguration(user code) > - config.update(user code) > - factory.addPID(ConfigurationImpl.java:329) > (preempted) > Managed Service Factory Tracker thread: > - ManagedServiceFactoryTracker.addingService(ConfigurationManager.java:1505) > - cm.configure(ConfigurationManager.java:1512) > - updateThread.schedule(ConfigurationManager.java:622) (Schedules a > ManagedServiceFactoryUpdate task) > - schedule(UpdateThread.java:109) > Update thread: > - task.run(UpdateThread.java:89) > - ManagedServiceFactoryUpdate.run, > cfg.isDelivered()(ConfigurationManager:1096) (is false now) > - cfg.setDelivered( true )(ConfigurationManager:1129) > User thread: > - setDelivered( false )(ConfigurationImpl:338) > - updateThread.schedule(ConfigurationManager:482) > - schedule(UpdateThread.java:109) (Schedules a 'regular' UpdateTask) > Update thread: > - task.run(UpdateThread.java:89) > - UpdateConfiguration.run, config.isDelivered() (is false now, so the > configuration is delivered twice!) > In short, there is a possibility in which the ManagedServiceFactoryUpdate > task and ConfigurationImpl influence the setDelivered in such a way, that > they interfere with eachother. > I do not have a contained testcase at the moment, nor an easy fix. Sorry > about that... -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online.