Thomas Watson created FELIX-6044: ------------------------------------ Summary: Component deactivation does not cause reference services to be ungotten Key: FELIX-6044 URL: https://issues.apache.org/jira/browse/FELIX-6044 Project: Felix Issue Type: Bug Components: Declarative Services (SCR) Affects Versions: scr-2.1.14 Reporter: Thomas Watson
The fix to FELIX-5276 has caused an issue for the default reference scope of bundle. When a component has a simple @Reference and that component is deactivated the services that it references will not be ungotten by SCR. This causes all kinds of issues for use counting of the consumed service. The issue is that org.apache.felix.scr.impl.manager.DependencyManager.close(ComponentContextImpl<S>, EdgeInfo) is calling RefPair.unsetServiceObject now for all RefPair types. The RefPair types MultiplePrototypeRefPair and SinglePrototypeRefPair were updated to have unsetServiceObject to also have that service be ungotten. But the default SingleRefPair type was not. This causes issues when ultimately the DependencyManagers are deactivated later which then closes the customizer for the dependency and org.apache.felix.scr.impl.manager.DependencyManager.AbstractCustomizer.ungetService(RefPair<S, T>) is called. By this time there will now be a null service and it will not be ungotten. -- This message was sent by Atlassian JIRA (v7.6.3#76005)