408281 - Inconsistent start/stop handling in ContainerLifeCycle

added stop(LifeCycle)
stop removed managed beans
always use start(LifeCycle)
This commit is contained in:
Greg Wilkins 2013-05-17 09:56:09 +10:00
parent d56ee96219
commit 52444486d1
1 changed files with 32 additions and 4 deletions

View File

@ -108,6 +108,17 @@ public class ContainerLifeCycle extends AbstractLifeCycle implements Container,
l.start();
}
/**
* Stops the given lifecycle.
*
* @param l
* @throws Exception
*/
protected void stop(LifeCycle l) throws Exception
{
l.stop();
}
/**
* Stops the managed lifecycle beans in the reverse order they were added.
*/
@ -124,7 +135,7 @@ public class ContainerLifeCycle extends AbstractLifeCycle implements Container,
{
LifeCycle l = (LifeCycle)b._bean;
if (l.isRunning())
l.stop();
stop(l);
}
}
}
@ -261,7 +272,7 @@ public class ContainerLifeCycle extends AbstractLifeCycle implements Container,
{
LifeCycle l = (LifeCycle)o;
if (!l.isRunning())
l.start();
start(l);
}
break;
@ -276,7 +287,7 @@ public class ContainerLifeCycle extends AbstractLifeCycle implements Container,
else
{
manage(new_bean);
l.start();
start(l);
}
}
else
@ -452,6 +463,7 @@ public class ContainerLifeCycle extends AbstractLifeCycle implements Container,
{
if (_beans.remove(bean))
{
unmanage(bean);
for (Container.Listener l:_listeners)
@ -473,6 +485,22 @@ public class ContainerLifeCycle extends AbstractLifeCycle implements Container,
}
}
// stop managed beans
if (bean._managed==Managed.MANAGED && bean._bean instanceof LifeCycle)
{
try
{
stop((LifeCycle)bean._bean);
}
catch(RuntimeException | Error e)
{
throw e;
}
catch (Exception e)
{
throw new RuntimeException(e);
}
}
return true;
}
return false;