[ 
https://issues.apache.org/jira/browse/ARIES-1350?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Guillaume Nodet resolved ARIES-1350.
------------------------------------
       Resolution: Fixed
    Fix Version/s: blueprint-core-1.4.4

Committing to https://svn.apache.org/repos/asf/aries/trunk ...
        M       
blueprint/blueprint-core/src/main/java/org/apache/aries/blueprint/namespace/NamespaceHandlerRegistryImpl.java
Committed r1690235


> Namespace handler can't be found even if it's registered correctly
> ------------------------------------------------------------------
>
>                 Key: ARIES-1350
>                 URL: https://issues.apache.org/jira/browse/ARIES-1350
>             Project: Aries
>          Issue Type: Bug
>          Components: Blueprint
>            Reporter: Grzegorz Grzybek
>            Assignee: Guillaume Nodet
>            Priority: Critical
>             Fix For: blueprint-core-1.4.4
>
>
> {{org.apache.aries.blueprint.namespace.NamespaceHandlerRegistryImpl.NamespaceHandlerSetImpl}}
>  class deals with namespace handlers for single BP container.
> During creation, it takes all already registered handlers from global NS 
> registry.
> After creation it is added to {{sets}} field in the registry to get notified 
> about newly registered NS handlers.
> But when NS handler is registered between the above two steps, BP stays in 
> GRACE_PERIOD state infinitely, because this "case" in BP container impl:
> {code:java}
> case WaitForNamespaceHandlers:
> {
>     List<String> missing = new ArrayList<String>();
>     List<URI> missingURIs = new ArrayList<URI>();
>     for (URI ns : namespaces) {
>         if (handlerSet.getNamespaceHandler(ns) == null) {
> {code}
> won't ever get namespace handler, because it looks in the handler set 
> obtained when {{NamespaceHandlerRegistryImpl.NamespaceHandlerSetImpl}} was 
> constructed.
> This:
> {noformat}
> 10:51 $ git diff
> diff --git 
> a/blueprint/blueprint-core/src/main/java/org/apache/aries/blueprint/namespace/NamespaceHandlerRegistryImpl.java
>  
> b/blueprint/blueprint-core/src/main/java/org/apache/aries/blueprint/namespace/NamespaceHandlerRegistryImpl.java
> index 7688924..d53ea5c 100644
> --- 
> a/blueprint/blueprint-core/src/main/java/org/apache/aries/blueprint/namespace/NamespaceHandlerRegistryImpl.java
> +++ 
> b/blueprint/blueprint-core/src/main/java/org/apache/aries/blueprint/namespace/NamespaceHandlerRegistryImpl.java
> @@ -535,6 +535,9 @@ public class NamespaceHandlerRegistryImpl implements 
> NamespaceHandlerRegistry, S
>          }
>  
>          public NamespaceHandler getNamespaceHandler(URI namespace) {
> +            if (!handlers.containsKey(namespace)) {
> +                findCompatibleNamespaceHandler(namespace);
> +            }
>              return handlers.get(namespace);
>          }
> {noformat}
> fixes the problem



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to