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

Neil Griffin closed PLUTO-770.
------------------------------
    Resolution: Fixed

Fixed in commit 
[4c63c29ad58bf633ffb761c4ae07c00aa4b94bab|https://github.com/apache/portals-pluto/commit/4c63c29ad58bf633ffb761c4ae07c00aa4b94bab]

> PortletSessionScopedBeanMap.remove() does not remove bean instances from the 
> underlying map
> -------------------------------------------------------------------------------------------
>
>                 Key: PLUTO-770
>                 URL: https://issues.apache.org/jira/browse/PLUTO-770
>             Project: Pluto
>          Issue Type: Task
>          Components: portlet container
>    Affects Versions: 3.0.0, 3.0.1
>            Reporter: Neil Griffin
>            Assignee: Neil Griffin
>            Priority: Major
>             Fix For: 3.0.2
>
>
> The {{PortletSessionScopedBeanMap.remove()}} method contains the following 
> code:
> {code:java|title=PortletSessionScopedBeanMap.java}
> if (bi != null) {
>     beans.remove(bean);
>     bi.crco.release();
>     bean.destroy((T)bi.instance, (CreationalContext<T>)bi.crco);
> }
> {code}
> The problem is that the {{beans}} variable is a {{java.util.Map}} whose keys 
> are of type {{String}} (the windowId of the portlet) and not of type 
> {{javax.enterprise.inject.spi.Bean}}. Therefore the call to 
> {{beans.remove(bean)}} is incorrect and does not actually remove the bean 
> from the underlying map.
> The fix would be to pass the windowId instead:
> {code:java|title=PortletSessionScopedBeanMap.java}
> if (bi != null) {
>     beans.remove(id);
>     bi.crco.release();
>     bean.destroy((T)bi.instance, (CreationalContext<T>)bi.crco);
> }
> {code}
> The reason why this was not discovered earlier is because the 
> {{PortletSessionScopedBeanMap.remove()}} method was only called by the 
> {{valueUnbound(HttpSessionBindingEvent evt)}} method which includes a call to 
> {{beans.clear()}} after iterating through all the beans.



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to