Commit 5808540381a02319a260d80e1eff2dc0a684fe5a
1 parent
d9a64def
Exists in
master
Melhoria na implementação do StartupBootstrap e do ShutdownBootstrap
Showing
17 changed files
with
806 additions
and
759 deletions
Show diff stats
impl/core/src/main/java/br/gov/frameworkdemoiselle/annotation/Priority.java
0 → 100644
| ... | ... | @@ -0,0 +1,66 @@ |
| 1 | +/* | |
| 2 | + * Demoiselle Framework | |
| 3 | + * Copyright (C) 2010 SERPRO | |
| 4 | + * ---------------------------------------------------------------------------- | |
| 5 | + * This file is part of Demoiselle Framework. | |
| 6 | + * | |
| 7 | + * Demoiselle Framework is free software; you can redistribute it and/or | |
| 8 | + * modify it under the terms of the GNU Lesser General Public License version 3 | |
| 9 | + * as published by the Free Software Foundation. | |
| 10 | + * | |
| 11 | + * This program is distributed in the hope that it will be useful, | |
| 12 | + * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 13 | + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 14 | + * GNU General Public License for more details. | |
| 15 | + * | |
| 16 | + * You should have received a copy of the GNU Lesser General Public License version 3 | |
| 17 | + * along with this program; if not, see <http://www.gnu.org/licenses/> | |
| 18 | + * or write to the Free Software Foundation, Inc., 51 Franklin Street, | |
| 19 | + * Fifth Floor, Boston, MA 02110-1301, USA. | |
| 20 | + * ---------------------------------------------------------------------------- | |
| 21 | + * Este arquivo é parte do Framework Demoiselle. | |
| 22 | + * | |
| 23 | + * O Framework Demoiselle é um software livre; você pode redistribuí-lo e/ou | |
| 24 | + * modificá-lo dentro dos termos da GNU LGPL versão 3 como publicada pela Fundação | |
| 25 | + * do Software Livre (FSF). | |
| 26 | + * | |
| 27 | + * Este programa é distribuído na esperança que possa ser útil, mas SEM NENHUMA | |
| 28 | + * GARANTIA; sem uma garantia implícita de ADEQUAÇÃO a qualquer MERCADO ou | |
| 29 | + * APLICAÇÃO EM PARTICULAR. Veja a Licença Pública Geral GNU/LGPL em português | |
| 30 | + * para maiores detalhes. | |
| 31 | + * | |
| 32 | + * Você deve ter recebido uma cópia da GNU LGPL versão 3, sob o título | |
| 33 | + * "LICENCA.txt", junto com esse programa. Se não, acesse <http://www.gnu.org/licenses/> | |
| 34 | + * ou escreva para a Fundação do Software Livre (FSF) Inc., | |
| 35 | + * 51 Franklin St, Fifth Floor, Boston, MA 02111-1301, USA. | |
| 36 | + */ | |
| 37 | +package br.gov.frameworkdemoiselle.annotation; | |
| 38 | + | |
| 39 | +import static java.lang.annotation.ElementType.METHOD; | |
| 40 | +import static java.lang.annotation.RetentionPolicy.RUNTIME; | |
| 41 | + | |
| 42 | +import java.lang.annotation.Retention; | |
| 43 | +import java.lang.annotation.Target; | |
| 44 | + | |
| 45 | +/** | |
| 46 | + * @author SERPRO | |
| 47 | + */ | |
| 48 | +@Target(METHOD) | |
| 49 | +@Retention(RUNTIME) | |
| 50 | +public @interface Priority { | |
| 51 | + | |
| 52 | + /** | |
| 53 | + * Most important priority value. | |
| 54 | + */ | |
| 55 | + public static int MAX_PRIORITY = Integer.MIN_VALUE; | |
| 56 | + | |
| 57 | + /** | |
| 58 | + * Less important priority value. | |
| 59 | + */ | |
| 60 | + public static int MIN_PRIORITY = Integer.MAX_VALUE; | |
| 61 | + | |
| 62 | + /** | |
| 63 | + * An integer value defines the priority order. | |
| 64 | + */ | |
| 65 | + int value(); | |
| 66 | +} | ... | ... |
impl/core/src/main/java/br/gov/frameworkdemoiselle/annotation/Shutdown.java
| ... | ... | @@ -52,7 +52,8 @@ import java.lang.annotation.Target; |
| 52 | 52 | * <pre> |
| 53 | 53 | * public class Finalizer { |
| 54 | 54 | * |
| 55 | - * @Shutdown(priority = 5) | |
| 55 | + * @Shutdown | |
| 56 | + * @Priority(5) | |
| 56 | 57 | * public void finalize() { |
| 57 | 58 | * ... |
| 58 | 59 | * } |
| ... | ... | @@ -60,6 +61,7 @@ import java.lang.annotation.Target; |
| 60 | 61 | * |
| 61 | 62 | * |
| 62 | 63 | * |
| 64 | + * | |
| 63 | 65 | * </pre> |
| 64 | 66 | * |
| 65 | 67 | * </blockquote> |
| ... | ... | @@ -75,17 +77,29 @@ public @interface Shutdown { |
| 75 | 77 | |
| 76 | 78 | /** |
| 77 | 79 | * Most important priority value. |
| 80 | + * | |
| 81 | + * @deprecated | |
| 82 | + * @see Priority | |
| 78 | 83 | */ |
| 84 | + @Deprecated | |
| 79 | 85 | public static int MAX_PRIORITY = Integer.MIN_VALUE; |
| 80 | 86 | |
| 81 | 87 | /** |
| 82 | 88 | * Less important priority value. |
| 89 | + * | |
| 90 | + * @deprecated | |
| 91 | + * @see Priority | |
| 83 | 92 | */ |
| 93 | + @Deprecated | |
| 84 | 94 | public static int MIN_PRIORITY = Integer.MAX_VALUE; |
| 85 | 95 | |
| 86 | 96 | /** |
| 87 | 97 | * An integer value defines method execution order (i.e., priority). |
| 98 | + * | |
| 99 | + * @deprecated | |
| 100 | + * @see Priority | |
| 88 | 101 | */ |
| 102 | + @Deprecated | |
| 89 | 103 | int priority() default MIN_PRIORITY; |
| 90 | 104 | |
| 91 | 105 | } | ... | ... |
impl/core/src/main/java/br/gov/frameworkdemoiselle/annotation/Startup.java
| ... | ... | @@ -52,13 +52,16 @@ import java.lang.annotation.Target; |
| 52 | 52 | * <pre> |
| 53 | 53 | * public class Initializer { |
| 54 | 54 | * |
| 55 | - * @Startup(priority = 1) | |
| 55 | + * @Startup | |
| 56 | + * @Priority(1) | |
| 56 | 57 | * public void initialize() { |
| 57 | 58 | * ... |
| 58 | 59 | * } |
| 59 | 60 | * } |
| 60 | 61 | * |
| 61 | 62 | * |
| 63 | + * | |
| 64 | + * | |
| 62 | 65 | * </pre> |
| 63 | 66 | * |
| 64 | 67 | * </blockquote> |
| ... | ... | @@ -74,17 +77,29 @@ public @interface Startup { |
| 74 | 77 | |
| 75 | 78 | /** |
| 76 | 79 | * Most important priority value. |
| 80 | + * | |
| 81 | + * @deprecated | |
| 82 | + * @see Priority | |
| 77 | 83 | */ |
| 84 | + @Deprecated | |
| 78 | 85 | public static int MAX_PRIORITY = Integer.MIN_VALUE; |
| 79 | 86 | |
| 80 | 87 | /** |
| 81 | 88 | * Less important priority value. |
| 89 | + * | |
| 90 | + * @deprecated | |
| 91 | + * @see Priority | |
| 82 | 92 | */ |
| 93 | + @Deprecated | |
| 83 | 94 | public static int MIN_PRIORITY = Integer.MAX_VALUE; |
| 84 | 95 | |
| 85 | 96 | /** |
| 86 | 97 | * An integer value defines method execution order (i.e., priority). |
| 98 | + * | |
| 99 | + * @deprecated | |
| 100 | + * @see Priority | |
| 87 | 101 | */ |
| 102 | + @Deprecated | |
| 88 | 103 | int priority() default MIN_PRIORITY; |
| 89 | 104 | |
| 90 | 105 | } | ... | ... |
impl/core/src/main/java/br/gov/frameworkdemoiselle/internal/bootstrap/ApplicationLifecycleEvent.java
0 → 100644
impl/core/src/main/java/br/gov/frameworkdemoiselle/internal/bootstrap/AsbratctLifecycleBootstrap.java
0 → 100644
| ... | ... | @@ -0,0 +1,158 @@ |
| 1 | +/* | |
| 2 | + * Demoiselle Framework | |
| 3 | + * Copyright (C) 2010 SERPRO | |
| 4 | + * ---------------------------------------------------------------------------- | |
| 5 | + * This file is part of Demoiselle Framework. | |
| 6 | + * | |
| 7 | + * Demoiselle Framework is free software; you can redistribute it and/or | |
| 8 | + * modify it under the terms of the GNU Lesser General Public License version 3 | |
| 9 | + * as published by the Free Software Foundation. | |
| 10 | + * | |
| 11 | + * This program is distributed in the hope that it will be useful, | |
| 12 | + * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 13 | + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 14 | + * GNU General Public License for more details. | |
| 15 | + * | |
| 16 | + * You should have received a copy of the GNU Lesser General Public License version 3 | |
| 17 | + * along with this program; if not, see <http://www.gnu.org/licenses/> | |
| 18 | + * or write to the Free Software Foundation, Inc., 51 Franklin Street, | |
| 19 | + * Fifth Floor, Boston, MA 02110-1301, USA. | |
| 20 | + * ---------------------------------------------------------------------------- | |
| 21 | + * Este arquivo é parte do Framework Demoiselle. | |
| 22 | + * | |
| 23 | + * O Framework Demoiselle é um software livre; você pode redistribuí-lo e/ou | |
| 24 | + * modificá-lo dentro dos termos da GNU LGPL versão 3 como publicada pela Fundação | |
| 25 | + * do Software Livre (FSF). | |
| 26 | + * | |
| 27 | + * Este programa é distribuído na esperança que possa ser útil, mas SEM NENHUMA | |
| 28 | + * GARANTIA; sem uma garantia implícita de ADEQUAÇÃO a qualquer MERCADO ou | |
| 29 | + * APLICAÇÃO EM PARTICULAR. Veja a Licença Pública Geral GNU/LGPL em português | |
| 30 | + * para maiores detalhes. | |
| 31 | + * | |
| 32 | + * Você deve ter recebido uma cópia da GNU LGPL versão 3, sob o título | |
| 33 | + * "LICENCA.txt", junto com esse programa. Se não, acesse <http://www.gnu.org/licenses/> | |
| 34 | + * ou escreva para a Fundação do Software Livre (FSF) Inc., | |
| 35 | + * 51 Franklin St, Fifth Floor, Boston, MA 02111-1301, USA. | |
| 36 | + */ | |
| 37 | +package br.gov.frameworkdemoiselle.internal.bootstrap; | |
| 38 | + | |
| 39 | +import java.lang.annotation.Annotation; | |
| 40 | +import java.util.ArrayList; | |
| 41 | +import java.util.Collections; | |
| 42 | +import java.util.Iterator; | |
| 43 | +import java.util.List; | |
| 44 | + | |
| 45 | +import javax.enterprise.context.ConversationScoped; | |
| 46 | +import javax.enterprise.context.RequestScoped; | |
| 47 | +import javax.enterprise.context.SessionScoped; | |
| 48 | +import javax.enterprise.event.Observes; | |
| 49 | +import javax.enterprise.inject.spi.AfterBeanDiscovery; | |
| 50 | +import javax.enterprise.inject.spi.AnnotatedMethod; | |
| 51 | +import javax.enterprise.inject.spi.AnnotatedType; | |
| 52 | +import javax.enterprise.inject.spi.BeanManager; | |
| 53 | +import javax.enterprise.inject.spi.ProcessAnnotatedType; | |
| 54 | + | |
| 55 | +import br.gov.frameworkdemoiselle.DemoiselleException; | |
| 56 | +import br.gov.frameworkdemoiselle.annotation.ViewScoped; | |
| 57 | +import br.gov.frameworkdemoiselle.internal.configuration.ConfigurationLoader; | |
| 58 | +import br.gov.frameworkdemoiselle.internal.context.CustomContext; | |
| 59 | +import br.gov.frameworkdemoiselle.internal.context.ThreadLocalContext; | |
| 60 | +import br.gov.frameworkdemoiselle.internal.processor.AnnotatedMethodProcessor; | |
| 61 | +import br.gov.frameworkdemoiselle.util.Reflections; | |
| 62 | + | |
| 63 | +public abstract class AsbratctLifecycleBootstrap<A extends Annotation> extends AbstractBootstrap { | |
| 64 | + | |
| 65 | + private Class<A> annotationClass; | |
| 66 | + | |
| 67 | + private final List<AnnotatedMethodProcessor<?>> processors = Collections | |
| 68 | + .synchronizedList(new ArrayList<AnnotatedMethodProcessor<?>>()); | |
| 69 | + | |
| 70 | + private final List<CustomContext> tempContexts = new ArrayList<CustomContext>(); | |
| 71 | + | |
| 72 | + private AfterBeanDiscovery afterBeanDiscoveryEvent; | |
| 73 | + | |
| 74 | + protected abstract <T> AnnotatedMethodProcessor<T> newProcessorInstance(AnnotatedMethod<T> annotatedMethod, | |
| 75 | + BeanManager beanManager); | |
| 76 | + | |
| 77 | + protected Class<A> getAnnotationClass() { | |
| 78 | + if (this.annotationClass == null) { | |
| 79 | + this.annotationClass = Reflections.getGenericTypeArgument(this.getClass(), 0); | |
| 80 | + } | |
| 81 | + | |
| 82 | + return this.annotationClass; | |
| 83 | + } | |
| 84 | + | |
| 85 | + public <T> void processAnnotatedType(@Observes final ProcessAnnotatedType<T> event, final BeanManager beanManager) { | |
| 86 | + final AnnotatedType<T> annotatedType = event.getAnnotatedType(); | |
| 87 | + | |
| 88 | + for (AnnotatedMethod<?> am : annotatedType.getMethods()) { | |
| 89 | + if (am.isAnnotationPresent(getAnnotationClass())) { | |
| 90 | + @SuppressWarnings("unchecked") | |
| 91 | + AnnotatedMethod<T> annotatedMethod = (AnnotatedMethod<T>) am; | |
| 92 | + processors.add(newProcessorInstance(annotatedMethod, beanManager)); | |
| 93 | + } | |
| 94 | + } | |
| 95 | + } | |
| 96 | + | |
| 97 | + public void loadTempContexts(@Observes final AfterBeanDiscovery event) { | |
| 98 | + // Não registrar o contexto de aplicação pq ele já é registrado pela implementação do CDI | |
| 99 | + tempContexts.add(new ThreadLocalContext(ViewScoped.class)); | |
| 100 | + tempContexts.add(new ThreadLocalContext(SessionScoped.class)); | |
| 101 | + tempContexts.add(new ThreadLocalContext(ConversationScoped.class)); | |
| 102 | + tempContexts.add(new ThreadLocalContext(RequestScoped.class)); | |
| 103 | + | |
| 104 | + afterBeanDiscoveryEvent = event; | |
| 105 | + } | |
| 106 | + | |
| 107 | + private static boolean x = true; | |
| 108 | + | |
| 109 | + protected synchronized void proccessEvent(final ApplicationLifecycleEvent event) { | |
| 110 | + getLogger().debug( | |
| 111 | + getBundle("demoiselle-core-bundle").getString("executing-all", annotationClass.getSimpleName())); | |
| 112 | + | |
| 113 | + Collections.sort(processors); | |
| 114 | + Throwable failure = null; | |
| 115 | + | |
| 116 | + if (x) { | |
| 117 | + for (CustomContext tempContext : tempContexts) { | |
| 118 | + addContext(tempContext, afterBeanDiscoveryEvent); | |
| 119 | + } | |
| 120 | + | |
| 121 | + x = false; | |
| 122 | + } | |
| 123 | + | |
| 124 | + for (Iterator<AnnotatedMethodProcessor<?>> iter = processors.iterator(); iter.hasNext();) { | |
| 125 | + AnnotatedMethodProcessor<?> processor = iter.next(); | |
| 126 | + | |
| 127 | + try { | |
| 128 | + ClassLoader classLoader = ConfigurationLoader.getClassLoaderForClass(processor.getAnnotatedMethod() | |
| 129 | + .getDeclaringType().getJavaClass().getCanonicalName()); | |
| 130 | + | |
| 131 | + if (Thread.currentThread().getContextClassLoader().equals(classLoader)) { | |
| 132 | + processor.process(); | |
| 133 | + | |
| 134 | + if (event.removeProcessors()) { | |
| 135 | + iter.remove(); | |
| 136 | + } | |
| 137 | + } | |
| 138 | + | |
| 139 | + } catch (Throwable cause) { | |
| 140 | + failure = cause; | |
| 141 | + } | |
| 142 | + } | |
| 143 | + | |
| 144 | + if (processors.isEmpty()) { | |
| 145 | + unloadTempContexts(); | |
| 146 | + } | |
| 147 | + | |
| 148 | + if (failure != null) { | |
| 149 | + throw new DemoiselleException(failure); | |
| 150 | + } | |
| 151 | + } | |
| 152 | + | |
| 153 | + private void unloadTempContexts() { | |
| 154 | + for (CustomContext tempContext : tempContexts) { | |
| 155 | + disableContext(tempContext); | |
| 156 | + } | |
| 157 | + } | |
| 158 | +} | ... | ... |
impl/core/src/main/java/br/gov/frameworkdemoiselle/internal/bootstrap/BeforeApplicationFinalization.java
0 → 100644
impl/core/src/main/java/br/gov/frameworkdemoiselle/internal/bootstrap/BeforeApplicationInitialization.java
0 → 100644
impl/core/src/main/java/br/gov/frameworkdemoiselle/internal/bootstrap/ShutdownBootstrap.java
| ... | ... | @@ -36,134 +36,26 @@ |
| 36 | 36 | */ |
| 37 | 37 | package br.gov.frameworkdemoiselle.internal.bootstrap; |
| 38 | 38 | |
| 39 | -import java.lang.annotation.Annotation; | |
| 40 | -import java.util.ArrayList; | |
| 41 | -import java.util.Collections; | |
| 42 | -import java.util.Iterator; | |
| 43 | -import java.util.List; | |
| 44 | - | |
| 45 | -import javax.enterprise.context.ConversationScoped; | |
| 46 | -import javax.enterprise.context.RequestScoped; | |
| 47 | -import javax.enterprise.context.SessionScoped; | |
| 48 | 39 | import javax.enterprise.event.Observes; |
| 49 | -import javax.enterprise.inject.spi.AfterBeanDiscovery; | |
| 50 | 40 | import javax.enterprise.inject.spi.AnnotatedMethod; |
| 51 | -import javax.enterprise.inject.spi.AnnotatedType; | |
| 52 | 41 | import javax.enterprise.inject.spi.BeanManager; |
| 53 | -import javax.enterprise.inject.spi.ProcessAnnotatedType; | |
| 54 | 42 | |
| 55 | -import br.gov.frameworkdemoiselle.DemoiselleException; | |
| 56 | 43 | import br.gov.frameworkdemoiselle.annotation.Shutdown; |
| 57 | -import br.gov.frameworkdemoiselle.annotation.ViewScoped; | |
| 58 | -import br.gov.frameworkdemoiselle.internal.configuration.ConfigurationLoader; | |
| 59 | -import br.gov.frameworkdemoiselle.internal.context.CustomContext; | |
| 60 | -import br.gov.frameworkdemoiselle.internal.context.ThreadLocalContext; | |
| 44 | +import br.gov.frameworkdemoiselle.internal.processor.AnnotatedMethodProcessor; | |
| 61 | 45 | import br.gov.frameworkdemoiselle.internal.processor.ShutdownProcessor; |
| 62 | 46 | |
| 63 | 47 | /** |
| 64 | 48 | * This class run at application shutdown |
| 65 | 49 | */ |
| 66 | -public class ShutdownBootstrap extends AbstractBootstrap { | |
| 67 | - | |
| 68 | - private static final Class<? extends Annotation> annotationClass = Shutdown.class; | |
| 69 | - | |
| 70 | - private static final List<CustomContext> tempContexts = new ArrayList<CustomContext>(); | |
| 71 | - | |
| 72 | - private static AfterBeanDiscovery abdEvent; | |
| 73 | - | |
| 74 | - @SuppressWarnings("rawtypes") | |
| 75 | - private static final List<ShutdownProcessor> processors = Collections | |
| 76 | - .synchronizedList(new ArrayList<ShutdownProcessor>()); | |
| 77 | - | |
| 78 | - /** | |
| 79 | - * Observes all methods annotated with @Shutdown and create an instance of ShutdownProcessor for them | |
| 80 | - * | |
| 81 | - * @param <T> | |
| 82 | - * @param event | |
| 83 | - * @param beanManager | |
| 84 | - */ | |
| 85 | - public <T> void processAnnotatedType(@Observes final ProcessAnnotatedType<T> event, final BeanManager beanManager) { | |
| 86 | - final AnnotatedType<T> annotatedType = event.getAnnotatedType(); | |
| 87 | - for (AnnotatedMethod<?> am : annotatedType.getMethods()) { | |
| 88 | - if (am.isAnnotationPresent(annotationClass)) { | |
| 89 | - @SuppressWarnings("unchecked") | |
| 90 | - AnnotatedMethod<T> annotatedMethod = (AnnotatedMethod<T>) am; | |
| 91 | - processors.add(new ShutdownProcessor<T>(annotatedMethod, beanManager)); | |
| 92 | - } | |
| 93 | - } | |
| 94 | - } | |
| 95 | - | |
| 96 | - public static void loadTempContexts(@Observes final AfterBeanDiscovery event) { | |
| 97 | - // Não registrar o contexto de aplicação pq ele já é registrado pela | |
| 98 | - // implementação do CDI | |
| 99 | - tempContexts.add(new ThreadLocalContext(ViewScoped.class)); | |
| 100 | - tempContexts.add(new ThreadLocalContext(SessionScoped.class, false)); | |
| 101 | - tempContexts.add(new ThreadLocalContext(ConversationScoped.class)); | |
| 102 | - tempContexts.add(new ThreadLocalContext(RequestScoped.class)); | |
| 103 | - abdEvent = event; | |
| 104 | - } | |
| 105 | - | |
| 106 | - /** | |
| 107 | - * Before Shutdown it execute the methods annotateds with @Shutdown considering the priority order; | |
| 108 | - */ | |
| 109 | - public synchronized static void shutdown() { | |
| 110 | - shutdown(true); | |
| 111 | - } | |
| 112 | - | |
| 113 | - private static boolean x = true; | |
| 114 | - | |
| 115 | - /** | |
| 116 | - * Before Shutdown it execute the methods annotateds with @Shutdown considering the priority order; | |
| 117 | - */ | |
| 118 | - @SuppressWarnings({ "unchecked", "rawtypes" }) | |
| 119 | - public synchronized static void shutdown(boolean remove) { | |
| 120 | - getLogger().debug( | |
| 121 | - getBundle("demoiselle-core-bundle").getString("executing-all", annotationClass.getSimpleName())); | |
| 122 | - | |
| 123 | - Collections.sort(processors); | |
| 124 | - Throwable failure = null; | |
| 125 | - | |
| 126 | - if (x) { | |
| 127 | - for (CustomContext tempContext : tempContexts) { | |
| 128 | - addContext(tempContext, abdEvent); | |
| 129 | - } | |
| 130 | - | |
| 131 | - x = false; | |
| 132 | - } | |
| 133 | - | |
| 134 | - for (Iterator<ShutdownProcessor> iter = processors.iterator(); iter.hasNext();) { | |
| 135 | - ShutdownProcessor processor = iter.next(); | |
| 136 | - | |
| 137 | - try { | |
| 138 | - ClassLoader classLoader = ConfigurationLoader.getClassLoaderForClass(processor.getAnnotatedMethod() | |
| 139 | - .getDeclaringType().getJavaClass().getCanonicalName()); | |
| 140 | - | |
| 141 | - if (Thread.currentThread().getContextClassLoader().equals(classLoader)) { | |
| 142 | - | |
| 143 | - processor.process(); | |
| 144 | - | |
| 145 | - if (remove) { | |
| 146 | - iter.remove(); | |
| 147 | - } | |
| 148 | - } | |
| 149 | - | |
| 150 | - } catch (Throwable cause) { | |
| 151 | - failure = cause; | |
| 152 | - } | |
| 153 | - } | |
| 154 | - | |
| 155 | - if (processors.isEmpty()) { | |
| 156 | - unloadTempContexts(); | |
| 157 | - } | |
| 50 | +public class ShutdownBootstrap extends AsbratctLifecycleBootstrap<Shutdown> { | |
| 158 | 51 | |
| 159 | - if (failure != null) { | |
| 160 | - throw new DemoiselleException(failure); | |
| 161 | - } | |
| 52 | + @Override | |
| 53 | + protected <T> AnnotatedMethodProcessor<T> newProcessorInstance(AnnotatedMethod<T> annotatedMethod, | |
| 54 | + BeanManager beanManager) { | |
| 55 | + return new ShutdownProcessor<T>(annotatedMethod, beanManager); | |
| 162 | 56 | } |
| 163 | 57 | |
| 164 | - private static void unloadTempContexts() { | |
| 165 | - for (CustomContext tempContext : tempContexts) { | |
| 166 | - disableContext(tempContext); | |
| 167 | - } | |
| 58 | + public void shutdown(@Observes BeforeApplicationFinalization event) { | |
| 59 | + proccessEvent(event); | |
| 168 | 60 | } |
| 169 | 61 | } | ... | ... |
impl/core/src/main/java/br/gov/frameworkdemoiselle/internal/bootstrap/StartupBootstrap.java
| ... | ... | @@ -36,132 +36,26 @@ |
| 36 | 36 | */ |
| 37 | 37 | package br.gov.frameworkdemoiselle.internal.bootstrap; |
| 38 | 38 | |
| 39 | -import java.lang.annotation.Annotation; | |
| 40 | -import java.util.ArrayList; | |
| 41 | -import java.util.Collections; | |
| 42 | -import java.util.Iterator; | |
| 43 | -import java.util.List; | |
| 44 | - | |
| 45 | -import javax.enterprise.context.ConversationScoped; | |
| 46 | -import javax.enterprise.context.RequestScoped; | |
| 47 | -import javax.enterprise.context.SessionScoped; | |
| 48 | 39 | import javax.enterprise.event.Observes; |
| 49 | -import javax.enterprise.inject.spi.AfterBeanDiscovery; | |
| 50 | 40 | import javax.enterprise.inject.spi.AnnotatedMethod; |
| 51 | -import javax.enterprise.inject.spi.AnnotatedType; | |
| 52 | 41 | import javax.enterprise.inject.spi.BeanManager; |
| 53 | -import javax.enterprise.inject.spi.ProcessAnnotatedType; | |
| 54 | 42 | |
| 55 | -import br.gov.frameworkdemoiselle.DemoiselleException; | |
| 56 | 43 | import br.gov.frameworkdemoiselle.annotation.Startup; |
| 57 | -import br.gov.frameworkdemoiselle.annotation.ViewScoped; | |
| 58 | -import br.gov.frameworkdemoiselle.internal.configuration.ConfigurationLoader; | |
| 59 | -import br.gov.frameworkdemoiselle.internal.context.CustomContext; | |
| 60 | -import br.gov.frameworkdemoiselle.internal.context.ThreadLocalContext; | |
| 44 | +import br.gov.frameworkdemoiselle.internal.processor.AnnotatedMethodProcessor; | |
| 61 | 45 | import br.gov.frameworkdemoiselle.internal.processor.StartupProcessor; |
| 62 | 46 | |
| 63 | 47 | /** |
| 64 | 48 | * This class is the bootstrap to execute the processes at load time. |
| 65 | 49 | */ |
| 66 | -public class StartupBootstrap extends AbstractBootstrap { | |
| 67 | - | |
| 68 | - private static final Class<? extends Annotation> annotationClass = Startup.class; | |
| 69 | - | |
| 70 | - private static final List<CustomContext> tempContexts = new ArrayList<CustomContext>(); | |
| 71 | - | |
| 72 | - @SuppressWarnings("rawtypes") | |
| 73 | - private static final List<StartupProcessor> processors = Collections | |
| 74 | - .synchronizedList(new ArrayList<StartupProcessor>()); | |
| 75 | - | |
| 76 | - private static AfterBeanDiscovery abdEvent; | |
| 77 | - | |
| 78 | - /** | |
| 79 | - * Observes all methods annotated with @Startup and create an instance of StartupAction for them | |
| 80 | - * | |
| 81 | - * @param <T> | |
| 82 | - * @param event | |
| 83 | - * @param beanManager | |
| 84 | - */ | |
| 85 | - public <T> void processAnnotatedType(@Observes final ProcessAnnotatedType<T> event, final BeanManager beanManager) { | |
| 86 | - final AnnotatedType<T> annotatedType = event.getAnnotatedType(); | |
| 87 | - for (AnnotatedMethod<?> am : annotatedType.getMethods()) { | |
| 88 | - if (am.isAnnotationPresent(annotationClass)) { | |
| 89 | - @SuppressWarnings("unchecked") | |
| 90 | - AnnotatedMethod<T> annotatedMethod = (AnnotatedMethod<T>) am; | |
| 91 | - processors.add(new StartupProcessor<T>(annotatedMethod, beanManager)); | |
| 92 | - } | |
| 93 | - } | |
| 94 | - } | |
| 95 | - | |
| 96 | - public void loadTempContexts(@Observes final AfterBeanDiscovery event) { | |
| 97 | - // Não registrar o contexto de aplicação pq ele já é registrado pela implementação do CDI | |
| 98 | - tempContexts.add(new ThreadLocalContext(ViewScoped.class)); | |
| 99 | - tempContexts.add(new ThreadLocalContext(SessionScoped.class)); | |
| 100 | - tempContexts.add(new ThreadLocalContext(ConversationScoped.class)); | |
| 101 | - tempContexts.add(new ThreadLocalContext(RequestScoped.class)); | |
| 102 | - abdEvent = event; | |
| 103 | - } | |
| 104 | - | |
| 105 | - /** | |
| 106 | - * After the deployment validation it execute the methods annotateds with @Startup considering the priority order; | |
| 107 | - */ | |
| 108 | - public synchronized static void startup() { | |
| 109 | - startup(true); | |
| 110 | - } | |
| 111 | - | |
| 112 | - private static boolean x = true; | |
| 113 | - | |
| 114 | - /** | |
| 115 | - * After the deployment validation it execute the methods annotateds with @Startup considering the priority order; | |
| 116 | - */ | |
| 117 | - @SuppressWarnings({ "unchecked", "rawtypes" }) | |
| 118 | - public synchronized static void startup(boolean remove) { | |
| 119 | - getLogger().debug( | |
| 120 | - getBundle("demoiselle-core-bundle").getString("executing-all", annotationClass.getSimpleName())); | |
| 121 | - | |
| 122 | - Collections.sort(processors); | |
| 123 | - Throwable failure = null; | |
| 124 | - | |
| 125 | - if (x) { | |
| 126 | - for (CustomContext tempContext : tempContexts) { | |
| 127 | - addContext(tempContext, abdEvent); | |
| 128 | - } | |
| 129 | - | |
| 130 | - x = false; | |
| 131 | - } | |
| 132 | - | |
| 133 | - for (Iterator<StartupProcessor> iter = processors.iterator(); iter.hasNext();) { | |
| 134 | - StartupProcessor processor = iter.next(); | |
| 135 | - | |
| 136 | - try { | |
| 137 | - ClassLoader classLoader = ConfigurationLoader.getClassLoaderForClass(processor.getAnnotatedMethod() | |
| 138 | - .getDeclaringType().getJavaClass().getCanonicalName()); | |
| 139 | - | |
| 140 | - if (Thread.currentThread().getContextClassLoader().equals(classLoader)) { | |
| 141 | - processor.process(); | |
| 142 | - | |
| 143 | - if (remove) { | |
| 144 | - iter.remove(); | |
| 145 | - } | |
| 146 | - } | |
| 147 | - | |
| 148 | - } catch (Throwable cause) { | |
| 149 | - failure = cause; | |
| 150 | - } | |
| 151 | - } | |
| 152 | - | |
| 153 | - if (processors.isEmpty()) { | |
| 154 | - unloadTempContexts(); | |
| 155 | - } | |
| 50 | +public class StartupBootstrap extends AsbratctLifecycleBootstrap<Startup> { | |
| 156 | 51 | |
| 157 | - if (failure != null) { | |
| 158 | - throw new DemoiselleException(failure); | |
| 159 | - } | |
| 52 | + @Override | |
| 53 | + protected <T> AnnotatedMethodProcessor<T> newProcessorInstance(AnnotatedMethod<T> annotatedMethod, | |
| 54 | + BeanManager beanManager) { | |
| 55 | + return new StartupProcessor<T>(annotatedMethod, beanManager); | |
| 160 | 56 | } |
| 161 | 57 | |
| 162 | - private static void unloadTempContexts() { | |
| 163 | - for (CustomContext tempContext : tempContexts) { | |
| 164 | - disableContext(tempContext); | |
| 165 | - } | |
| 58 | + public void startup(@Observes BeforeApplicationInitialization event) { | |
| 59 | + proccessEvent(event); | |
| 166 | 60 | } |
| 167 | 61 | } | ... | ... |
impl/core/src/main/java/br/gov/frameworkdemoiselle/internal/processor/AbstractProcessor.java
| ... | ... | @@ -51,14 +51,14 @@ import br.gov.frameworkdemoiselle.util.ResourceBundle; |
| 51 | 51 | /** |
| 52 | 52 | * It abstract the integration between Processor and the context; |
| 53 | 53 | * |
| 54 | - * @param <DC> | |
| 54 | + * @param <T> | |
| 55 | 55 | * the declaring class |
| 56 | 56 | */ |
| 57 | -public abstract class AbstractProcessor<DC> implements Processor { | |
| 57 | +public abstract class AbstractProcessor<T> implements Processor { | |
| 58 | 58 | |
| 59 | 59 | private BeanManager beanManager; |
| 60 | 60 | |
| 61 | - private AnnotatedCallable<DC> annotatedCallable; | |
| 61 | + private AnnotatedCallable<T> annotatedCallable; | |
| 62 | 62 | |
| 63 | 63 | private ResourceBundle bundle; |
| 64 | 64 | |
| ... | ... | @@ -68,12 +68,12 @@ public abstract class AbstractProcessor<DC> implements Processor { |
| 68 | 68 | this.beanManager = beanManager; |
| 69 | 69 | } |
| 70 | 70 | |
| 71 | - public AbstractProcessor(final AnnotatedCallable<DC> annotatedCallable, final BeanManager beanManager) { | |
| 71 | + public AbstractProcessor(final AnnotatedCallable<T> annotatedCallable, final BeanManager beanManager) { | |
| 72 | 72 | this.annotatedCallable = annotatedCallable; |
| 73 | 73 | this.beanManager = beanManager; |
| 74 | 74 | } |
| 75 | 75 | |
| 76 | - protected AnnotatedCallable<DC> getAnnotatedCallable() { | |
| 76 | + protected AnnotatedCallable<T> getAnnotatedCallable() { | |
| 77 | 77 | return this.annotatedCallable; |
| 78 | 78 | } |
| 79 | 79 | |
| ... | ... | @@ -90,15 +90,15 @@ public abstract class AbstractProcessor<DC> implements Processor { |
| 90 | 90 | * @return |
| 91 | 91 | */ |
| 92 | 92 | @SuppressWarnings("unchecked") |
| 93 | - protected DC getReferencedBean() { | |
| 94 | - Class<DC> classType = (Class<DC>) getAnnotatedCallable().getJavaMember().getDeclaringClass(); | |
| 93 | + protected T getReferencedBean() { | |
| 94 | + Class<T> classType = (Class<T>) getAnnotatedCallable().getJavaMember().getDeclaringClass(); | |
| 95 | 95 | return getReferencedBean(classType); |
| 96 | 96 | } |
| 97 | 97 | |
| 98 | 98 | @SuppressWarnings("unchecked") |
| 99 | - protected DC getReferencedBean(final Class<DC> type) { | |
| 100 | - Bean<DC> bean = (Bean<DC>) beanManager.getBeans(type).iterator().next(); | |
| 101 | - return (DC) beanManager.getReference(bean, type, beanManager.createCreationalContext(bean)); | |
| 99 | + protected T getReferencedBean(final Class<T> type) { | |
| 100 | + Bean<T> bean = (Bean<T>) beanManager.getBeans(type).iterator().next(); | |
| 101 | + return (T) beanManager.getReference(bean, type, beanManager.createCreationalContext(bean)); | |
| 102 | 102 | } |
| 103 | 103 | |
| 104 | 104 | protected ResourceBundle getBundle() { | ... | ... |
impl/core/src/main/java/br/gov/frameworkdemoiselle/internal/processor/AnnotatedMethodProcessor.java
| ... | ... | @@ -47,17 +47,27 @@ import br.gov.frameworkdemoiselle.message.SeverityType; |
| 47 | 47 | /** |
| 48 | 48 | * Represents an annotated method to be processed; |
| 49 | 49 | * |
| 50 | - * @param <DC> | |
| 50 | + * @param <T> | |
| 51 | 51 | * declaring class owner of the method |
| 52 | 52 | */ |
| 53 | -public class AnnotatedMethodProcessor<DC> extends AbstractProcessor<DC> { | |
| 53 | +public abstract class AnnotatedMethodProcessor<T> extends AbstractProcessor<T> implements | |
| 54 | + Comparable<AnnotatedMethodProcessor<T>> { | |
| 54 | 55 | |
| 55 | - public AnnotatedMethodProcessor(final AnnotatedMethod<DC> annotatedMethod, final BeanManager beanManager) { | |
| 56 | + public AnnotatedMethodProcessor(final AnnotatedMethod<T> annotatedMethod, final BeanManager beanManager) { | |
| 56 | 57 | super(annotatedMethod, beanManager); |
| 57 | 58 | } |
| 58 | 59 | |
| 59 | - public AnnotatedMethod<DC> getAnnotatedMethod() { | |
| 60 | - return (AnnotatedMethod<DC>) getAnnotatedCallable(); | |
| 60 | + public AnnotatedMethod<T> getAnnotatedMethod() { | |
| 61 | + return (AnnotatedMethod<T>) getAnnotatedCallable(); | |
| 62 | + } | |
| 63 | + | |
| 64 | + abstract protected Integer getPriority(AnnotatedMethod<T> annotatedMethod); | |
| 65 | + | |
| 66 | + public int compareTo(final AnnotatedMethodProcessor<T> other) { | |
| 67 | + Integer orderThis = getPriority(getAnnotatedMethod()); | |
| 68 | + Integer orderOther = getPriority(other.getAnnotatedMethod()); | |
| 69 | + | |
| 70 | + return orderThis.compareTo(orderOther); | |
| 61 | 71 | } |
| 62 | 72 | |
| 63 | 73 | public boolean process(Object... args) throws Throwable { | ... | ... |
impl/core/src/main/java/br/gov/frameworkdemoiselle/internal/processor/ShutdownProcessor.java
| ... | ... | @@ -41,23 +41,20 @@ import javax.enterprise.inject.spi.BeanManager; |
| 41 | 41 | |
| 42 | 42 | import br.gov.frameworkdemoiselle.annotation.Shutdown; |
| 43 | 43 | |
| 44 | -public class ShutdownProcessor<T> extends AnnotatedMethodProcessor<T> implements Comparable<ShutdownProcessor<T>> { | |
| 44 | +/** | |
| 45 | + * Processor for a {@code Shutdown} annotated method, making it comparable. | |
| 46 | + * | |
| 47 | + * @param <T> | |
| 48 | + */ | |
| 49 | +public class ShutdownProcessor<T> extends AnnotatedMethodProcessor<T> { | |
| 45 | 50 | |
| 46 | 51 | public ShutdownProcessor(AnnotatedMethod<T> annotatedMethod, BeanManager beanManager) { |
| 47 | 52 | super(annotatedMethod, beanManager); |
| 48 | 53 | } |
| 49 | 54 | |
| 50 | - @Override | |
| 51 | - public int compareTo(final ShutdownProcessor<T> other) { | |
| 52 | - int result = 0; | |
| 53 | - Shutdown annotationThis = getAnnotatedMethod().getAnnotation(Shutdown.class); | |
| 54 | - Shutdown annotationOther = other.getAnnotatedMethod().getAnnotation(Shutdown.class); | |
| 55 | - if (annotationThis != null && annotationThis != null) { | |
| 56 | - Integer orderThis = annotationThis.priority(); | |
| 57 | - Integer orderOther = annotationOther.priority(); | |
| 58 | - result = orderThis.compareTo(orderOther); | |
| 59 | - } | |
| 60 | - return result; | |
| 55 | + @SuppressWarnings("deprecation") | |
| 56 | + protected Integer getPriority(AnnotatedMethod<T> annotatedMethod) { | |
| 57 | + Shutdown annotation = annotatedMethod.getAnnotation(Shutdown.class); | |
| 58 | + return annotation.priority(); | |
| 61 | 59 | } |
| 62 | - | |
| 63 | 60 | } | ... | ... |
impl/core/src/main/java/br/gov/frameworkdemoiselle/internal/processor/StartupProcessor.java
| ... | ... | @@ -43,26 +43,18 @@ import br.gov.frameworkdemoiselle.annotation.Startup; |
| 43 | 43 | |
| 44 | 44 | /** |
| 45 | 45 | * Processor for a {@code @Startup} annotated method, making it comparable. |
| 46 | - * | |
| 46 | + * | |
| 47 | 47 | * @param <T> |
| 48 | 48 | */ |
| 49 | -public class StartupProcessor<T> extends AnnotatedMethodProcessor<T> implements Comparable<StartupProcessor<T>> { | |
| 49 | +public class StartupProcessor<T> extends AnnotatedMethodProcessor<T> { | |
| 50 | 50 | |
| 51 | 51 | public StartupProcessor(final AnnotatedMethod<T> annotatedMethod, final BeanManager beanManager) { |
| 52 | 52 | super(annotatedMethod, beanManager); |
| 53 | 53 | } |
| 54 | 54 | |
| 55 | - @Override | |
| 56 | - public int compareTo(final StartupProcessor<T> other) { | |
| 57 | - int result = 0; | |
| 58 | - Startup annotationThis = getAnnotatedMethod().getAnnotation(Startup.class); | |
| 59 | - Startup annotationOther = other.getAnnotatedMethod().getAnnotation(Startup.class); | |
| 60 | - if (annotationThis != null && annotationOther != null) { | |
| 61 | - Integer orderThis = annotationThis.priority(); | |
| 62 | - Integer orderOther = annotationOther.priority(); | |
| 63 | - result = orderThis.compareTo(orderOther); | |
| 64 | - } | |
| 65 | - return result; | |
| 55 | + @SuppressWarnings("deprecation") | |
| 56 | + protected Integer getPriority(AnnotatedMethod<T> annotatedMethod) { | |
| 57 | + Startup annotation = annotatedMethod.getAnnotation(Startup.class); | |
| 58 | + return annotation.priority(); | |
| 66 | 59 | } |
| 67 | - | |
| 68 | 60 | } | ... | ... |
impl/core/src/test/java/br/gov/frameworkdemoiselle/internal/bootstrap/ShutdownBootstrapTest.java
| 1 | -/* | |
| 2 | - * Demoiselle Framework | |
| 3 | - * Copyright (C) 2010 SERPRO | |
| 4 | - * ---------------------------------------------------------------------------- | |
| 5 | - * This file is part of Demoiselle Framework. | |
| 6 | - * | |
| 7 | - * Demoiselle Framework is free software; you can redistribute it and/or | |
| 8 | - * modify it under the terms of the GNU Lesser General Public License version 3 | |
| 9 | - * as published by the Free Software Foundation. | |
| 10 | - * | |
| 11 | - * This program is distributed in the hope that it will be useful, | |
| 12 | - * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 13 | - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 14 | - * GNU General Public License for more details. | |
| 15 | - * | |
| 16 | - * You should have received a copy of the GNU Lesser General Public License version 3 | |
| 17 | - * along with this program; if not, see <http://www.gnu.org/licenses/> | |
| 18 | - * or write to the Free Software Foundation, Inc., 51 Franklin Street, | |
| 19 | - * Fifth Floor, Boston, MA 02110-1301, USA. | |
| 20 | - * ---------------------------------------------------------------------------- | |
| 21 | - * Este arquivo é parte do Framework Demoiselle. | |
| 22 | - * | |
| 23 | - * O Framework Demoiselle é um software livre; você pode redistribuí-lo e/ou | |
| 24 | - * modificá-lo dentro dos termos da GNU LGPL versão 3 como publicada pela Fundação | |
| 25 | - * do Software Livre (FSF). | |
| 26 | - * | |
| 27 | - * Este programa é distribuído na esperança que possa ser útil, mas SEM NENHUMA | |
| 28 | - * GARANTIA; sem uma garantia implícita de ADEQUAÇÃO a qualquer MERCADO ou | |
| 29 | - * APLICAÇÃO EM PARTICULAR. Veja a Licença Pública Geral GNU/LGPL em português | |
| 30 | - * para maiores detalhes. | |
| 31 | - * | |
| 32 | - * Você deve ter recebido uma cópia da GNU LGPL versão 3, sob o título | |
| 33 | - * "LICENCA.txt", junto com esse programa. Se não, acesse <http://www.gnu.org/licenses/> | |
| 34 | - * ou escreva para a Fundação do Software Livre (FSF) Inc., | |
| 35 | - * 51 Franklin St, Fifth Floor, Boston, MA 02111-1301, USA. | |
| 36 | - */ | |
| 37 | -package br.gov.frameworkdemoiselle.internal.bootstrap; | |
| 38 | - | |
| 39 | -import static org.easymock.EasyMock.expect; | |
| 40 | -import static org.easymock.EasyMock.replay; | |
| 41 | -import static org.easymock.EasyMock.verify; | |
| 42 | -import static org.junit.Assert.assertFalse; | |
| 43 | -import static org.junit.Assert.assertNotNull; | |
| 44 | -import static org.junit.Assert.assertTrue; | |
| 45 | - | |
| 46 | -import java.lang.reflect.Field; | |
| 47 | -import java.util.ArrayList; | |
| 48 | -import java.util.HashSet; | |
| 49 | -import java.util.List; | |
| 50 | -import java.util.Locale; | |
| 51 | -import java.util.Set; | |
| 52 | - | |
| 53 | -import javax.enterprise.inject.spi.AfterBeanDiscovery; | |
| 54 | -import javax.enterprise.inject.spi.AnnotatedMethod; | |
| 55 | -import javax.enterprise.inject.spi.AnnotatedType; | |
| 56 | -import javax.enterprise.inject.spi.BeanManager; | |
| 57 | -import javax.enterprise.inject.spi.ProcessAnnotatedType; | |
| 58 | - | |
| 59 | -import org.easymock.EasyMock; | |
| 60 | -import org.junit.Before; | |
| 61 | -import org.junit.Ignore; | |
| 62 | -import org.junit.Test; | |
| 63 | -import org.junit.runner.RunWith; | |
| 64 | -import org.powermock.api.easymock.PowerMock; | |
| 65 | -import org.powermock.core.classloader.annotations.PrepareForTest; | |
| 66 | -import org.powermock.modules.junit4.PowerMockRunner; | |
| 67 | -import org.powermock.reflect.Whitebox; | |
| 68 | -import org.slf4j.Logger; | |
| 69 | - | |
| 70 | -import br.gov.frameworkdemoiselle.annotation.Shutdown; | |
| 71 | -import br.gov.frameworkdemoiselle.internal.context.Contexts; | |
| 72 | -import br.gov.frameworkdemoiselle.internal.context.ThreadLocalContext; | |
| 73 | -import br.gov.frameworkdemoiselle.internal.processor.ShutdownProcessor; | |
| 74 | -import br.gov.frameworkdemoiselle.internal.producer.LoggerProducer; | |
| 75 | -import br.gov.frameworkdemoiselle.internal.producer.ResourceBundleProducer; | |
| 76 | -import br.gov.frameworkdemoiselle.util.ResourceBundle; | |
| 77 | - | |
| 78 | -@Ignore | |
| 79 | -@RunWith(PowerMockRunner.class) | |
| 80 | -@PrepareForTest({ Contexts.class, LoggerProducer.class, ResourceBundle.class, ResourceBundleProducer.class }) | |
| 81 | -@SuppressWarnings("rawtypes") | |
| 82 | -public class ShutdownBootstrapTest { | |
| 83 | - | |
| 84 | - private ProcessAnnotatedType event; | |
| 85 | - | |
| 86 | - private BeanManager beanManager; | |
| 87 | - | |
| 88 | - private AnnotatedType annotatedType; | |
| 89 | - | |
| 90 | - @Before | |
| 91 | - public void before() { | |
| 92 | - event = EasyMock.createMock(ProcessAnnotatedType.class); | |
| 93 | - annotatedType = EasyMock.createMock(AnnotatedType.class); | |
| 94 | - beanManager = null; | |
| 95 | - } | |
| 96 | - | |
| 97 | - @SuppressWarnings("unchecked") | |
| 98 | - private List<ShutdownProcessor> getProcessors(ShutdownBootstrap bootstrap) throws IllegalArgumentException, | |
| 99 | - IllegalAccessException { | |
| 100 | - Set<Field> fields = Whitebox.getAllStaticFields(ShutdownBootstrap.class); | |
| 101 | - List<ShutdownProcessor> list = new ArrayList<ShutdownProcessor>(); | |
| 102 | - for (Field field : fields) { | |
| 103 | - if (field.getName().equals("processors")) { | |
| 104 | - list = (List<ShutdownProcessor>) field.get(bootstrap); | |
| 105 | - } | |
| 106 | - } | |
| 107 | - return list; | |
| 108 | - } | |
| 109 | - | |
| 110 | - @SuppressWarnings({ "unchecked" }) | |
| 111 | - @Test | |
| 112 | - public void processAnnotatedType() throws IllegalArgumentException, IllegalAccessException { | |
| 113 | - ShutdownBootstrap bootstrap = new ShutdownBootstrap(); | |
| 114 | - List<ShutdownProcessor> list = getProcessors(bootstrap); | |
| 115 | - | |
| 116 | - assertTrue(list.isEmpty()); | |
| 117 | - | |
| 118 | - AnnotatedMethod am1 = PowerMock.createMock(AnnotatedMethod.class); | |
| 119 | - AnnotatedMethod am2 = PowerMock.createMock(AnnotatedMethod.class); | |
| 120 | - AnnotatedMethod am3 = PowerMock.createMock(AnnotatedMethod.class); | |
| 121 | - | |
| 122 | - Set<AnnotatedMethod> set = new HashSet<AnnotatedMethod>(); | |
| 123 | - set.add(am1); | |
| 124 | - set.add(am2); | |
| 125 | - set.add(am3); | |
| 126 | - | |
| 127 | - expect(am1.isAnnotationPresent(Shutdown.class)).andReturn(true); | |
| 128 | - expect(am2.isAnnotationPresent(Shutdown.class)).andReturn(true); | |
| 129 | - expect(am3.isAnnotationPresent(Shutdown.class)).andReturn(false); | |
| 130 | - expect(event.getAnnotatedType()).andReturn(annotatedType); | |
| 131 | - expect(annotatedType.getMethods()).andReturn(set); | |
| 132 | - | |
| 133 | - replay(event, annotatedType, am1, am2, am3); | |
| 134 | - bootstrap.processAnnotatedType(event, beanManager); | |
| 135 | - verify(event, annotatedType); | |
| 136 | - | |
| 137 | - list = getProcessors(bootstrap); | |
| 138 | - assertNotNull(list); | |
| 139 | - assertFalse(list.isEmpty()); | |
| 140 | - assertTrue(list.size() == 2); | |
| 141 | - } | |
| 142 | - | |
| 143 | - @SuppressWarnings({ "unchecked", "static-access" }) | |
| 144 | - @Test | |
| 145 | - public void testShuttingDown() throws Throwable { | |
| 146 | - ShutdownBootstrap bootstrap = new ShutdownBootstrap(); | |
| 147 | - | |
| 148 | - PowerMock.mockStatic(Contexts.class); | |
| 149 | - PowerMock.mockStatic(LoggerProducer.class); | |
| 150 | - | |
| 151 | - Logger logger = PowerMock.createMock(Logger.class); | |
| 152 | - ResourceBundleProducer bundleFactory = PowerMock.createMock(ResourceBundleProducer.class); | |
| 153 | - ResourceBundle bundle = PowerMock.createMock(ResourceBundle.class); | |
| 154 | - | |
| 155 | - expect(LoggerProducer.create(EasyMock.anyObject(Class.class))).andReturn(logger).anyTimes(); | |
| 156 | - expect(bundleFactory.create(EasyMock.anyObject(String.class), EasyMock.anyObject(Locale.class))).andReturn( | |
| 157 | - bundle).anyTimes(); | |
| 158 | - expect(bundle.getString(EasyMock.anyObject(String.class), EasyMock.anyObject(String.class))).andReturn("") | |
| 159 | - .anyTimes(); | |
| 160 | - | |
| 161 | - logger.debug(EasyMock.anyObject(String.class)); | |
| 162 | - logger.trace(EasyMock.anyObject(String.class)); | |
| 163 | - EasyMock.expectLastCall().anyTimes(); | |
| 164 | - | |
| 165 | - Whitebox.setInternalState(AbstractBootstrap.class, ResourceBundleProducer.class, bundleFactory); | |
| 166 | - | |
| 167 | - List<ShutdownProcessor> list = getProcessors(bootstrap); | |
| 168 | - list.clear(); | |
| 169 | - | |
| 170 | - MyShuttingDownProcessor<?> processor = PowerMock.createMock(MyShuttingDownProcessor.class); | |
| 171 | - list.add(processor); | |
| 172 | - expect(processor.process()).andReturn(true).times(1); | |
| 173 | - | |
| 174 | - Contexts.add(EasyMock.anyObject(ThreadLocalContext.class), EasyMock.anyObject(AfterBeanDiscovery.class)); | |
| 175 | - EasyMock.expectLastCall().anyTimes(); | |
| 176 | - | |
| 177 | - Contexts.remove(EasyMock.anyObject(ThreadLocalContext.class)); | |
| 178 | - EasyMock.expectLastCall().anyTimes(); | |
| 179 | - | |
| 180 | - PowerMock.replayAll(); | |
| 181 | - ShutdownBootstrap.shutdown(); | |
| 182 | - | |
| 183 | - assertTrue(list.isEmpty()); | |
| 184 | - PowerMock.verifyAll(); | |
| 185 | - } | |
| 186 | -} | |
| 187 | - | |
| 188 | -@SuppressWarnings("rawtypes") | |
| 189 | -class MyShuttingDownProcessor<T> extends ShutdownProcessor<T> { | |
| 190 | - | |
| 191 | - @SuppressWarnings("unchecked") | |
| 192 | - public MyShuttingDownProcessor(AnnotatedMethod annotatedMethod, BeanManager beanManager) { | |
| 193 | - super(annotatedMethod, beanManager); | |
| 194 | - } | |
| 195 | - | |
| 196 | - @Override | |
| 197 | - public int compareTo(final ShutdownProcessor<T> other) { | |
| 198 | - return 1; | |
| 199 | - } | |
| 200 | -} | |
| 1 | +///* | |
| 2 | +// * Demoiselle Framework | |
| 3 | +// * Copyright (C) 2010 SERPRO | |
| 4 | +// * ---------------------------------------------------------------------------- | |
| 5 | +// * This file is part of Demoiselle Framework. | |
| 6 | +// * | |
| 7 | +// * Demoiselle Framework is free software; you can redistribute it and/or | |
| 8 | +// * modify it under the terms of the GNU Lesser General Public License version 3 | |
| 9 | +// * as published by the Free Software Foundation. | |
| 10 | +// * | |
| 11 | +// * This program is distributed in the hope that it will be useful, | |
| 12 | +// * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 13 | +// * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 14 | +// * GNU General Public License for more details. | |
| 15 | +// * | |
| 16 | +// * You should have received a copy of the GNU Lesser General Public License version 3 | |
| 17 | +// * along with this program; if not, see <http://www.gnu.org/licenses/> | |
| 18 | +// * or write to the Free Software Foundation, Inc., 51 Franklin Street, | |
| 19 | +// * Fifth Floor, Boston, MA 02110-1301, USA. | |
| 20 | +// * ---------------------------------------------------------------------------- | |
| 21 | +// * Este arquivo é parte do Framework Demoiselle. | |
| 22 | +// * | |
| 23 | +// * O Framework Demoiselle é um software livre; você pode redistribuí-lo e/ou | |
| 24 | +// * modificá-lo dentro dos termos da GNU LGPL versão 3 como publicada pela Fundação | |
| 25 | +// * do Software Livre (FSF). | |
| 26 | +// * | |
| 27 | +// * Este programa é distribuído na esperança que possa ser útil, mas SEM NENHUMA | |
| 28 | +// * GARANTIA; sem uma garantia implícita de ADEQUAÇÃO a qualquer MERCADO ou | |
| 29 | +// * APLICAÇÃO EM PARTICULAR. Veja a Licença Pública Geral GNU/LGPL em português | |
| 30 | +// * para maiores detalhes. | |
| 31 | +// * | |
| 32 | +// * Você deve ter recebido uma cópia da GNU LGPL versão 3, sob o título | |
| 33 | +// * "LICENCA.txt", junto com esse programa. Se não, acesse <http://www.gnu.org/licenses/> | |
| 34 | +// * ou escreva para a Fundação do Software Livre (FSF) Inc., | |
| 35 | +// * 51 Franklin St, Fifth Floor, Boston, MA 02111-1301, USA. | |
| 36 | +// */ | |
| 37 | +//package br.gov.frameworkdemoiselle.internal.bootstrap; | |
| 38 | +// | |
| 39 | +//import static org.easymock.EasyMock.expect; | |
| 40 | +//import static org.easymock.EasyMock.replay; | |
| 41 | +//import static org.easymock.EasyMock.verify; | |
| 42 | +//import static org.junit.Assert.assertFalse; | |
| 43 | +//import static org.junit.Assert.assertNotNull; | |
| 44 | +//import static org.junit.Assert.assertTrue; | |
| 45 | +// | |
| 46 | +//import java.lang.reflect.Field; | |
| 47 | +//import java.util.ArrayList; | |
| 48 | +//import java.util.HashSet; | |
| 49 | +//import java.util.List; | |
| 50 | +//import java.util.Locale; | |
| 51 | +//import java.util.Set; | |
| 52 | +// | |
| 53 | +//import javax.enterprise.inject.spi.AfterBeanDiscovery; | |
| 54 | +//import javax.enterprise.inject.spi.AnnotatedMethod; | |
| 55 | +//import javax.enterprise.inject.spi.AnnotatedType; | |
| 56 | +//import javax.enterprise.inject.spi.BeanManager; | |
| 57 | +//import javax.enterprise.inject.spi.ProcessAnnotatedType; | |
| 58 | +// | |
| 59 | +//import org.easymock.EasyMock; | |
| 60 | +//import org.junit.Before; | |
| 61 | +//import org.junit.Ignore; | |
| 62 | +//import org.junit.Test; | |
| 63 | +//import org.junit.runner.RunWith; | |
| 64 | +//import org.powermock.api.easymock.PowerMock; | |
| 65 | +//import org.powermock.core.classloader.annotations.PrepareForTest; | |
| 66 | +//import org.powermock.modules.junit4.PowerMockRunner; | |
| 67 | +//import org.powermock.reflect.Whitebox; | |
| 68 | +//import org.slf4j.Logger; | |
| 69 | +// | |
| 70 | +//import br.gov.frameworkdemoiselle.annotation.Shutdown; | |
| 71 | +//import br.gov.frameworkdemoiselle.internal.context.Contexts; | |
| 72 | +//import br.gov.frameworkdemoiselle.internal.context.ThreadLocalContext; | |
| 73 | +//import br.gov.frameworkdemoiselle.internal.processor.ShutdownProcessor; | |
| 74 | +//import br.gov.frameworkdemoiselle.internal.producer.LoggerProducer; | |
| 75 | +//import br.gov.frameworkdemoiselle.internal.producer.ResourceBundleProducer; | |
| 76 | +//import br.gov.frameworkdemoiselle.util.ResourceBundle; | |
| 77 | +// | |
| 78 | +//@Ignore | |
| 79 | +//@RunWith(PowerMockRunner.class) | |
| 80 | +//@PrepareForTest({ Contexts.class, LoggerProducer.class, ResourceBundle.class, ResourceBundleProducer.class }) | |
| 81 | +//@SuppressWarnings("rawtypes") | |
| 82 | +//public class ShutdownBootstrapTest { | |
| 83 | +// | |
| 84 | +// private ProcessAnnotatedType event; | |
| 85 | +// | |
| 86 | +// private BeanManager beanManager; | |
| 87 | +// | |
| 88 | +// private AnnotatedType annotatedType; | |
| 89 | +// | |
| 90 | +// @Before | |
| 91 | +// public void before() { | |
| 92 | +// event = EasyMock.createMock(ProcessAnnotatedType.class); | |
| 93 | +// annotatedType = EasyMock.createMock(AnnotatedType.class); | |
| 94 | +// beanManager = null; | |
| 95 | +// } | |
| 96 | +// | |
| 97 | +// @SuppressWarnings("unchecked") | |
| 98 | +// private List<ShutdownProcessor> getProcessors(ShutdownBootstrap bootstrap) throws IllegalArgumentException, | |
| 99 | +// IllegalAccessException { | |
| 100 | +// Set<Field> fields = Whitebox.getAllStaticFields(ShutdownBootstrap.class); | |
| 101 | +// List<ShutdownProcessor> list = new ArrayList<ShutdownProcessor>(); | |
| 102 | +// for (Field field : fields) { | |
| 103 | +// if (field.getName().equals("processors")) { | |
| 104 | +// list = (List<ShutdownProcessor>) field.get(bootstrap); | |
| 105 | +// } | |
| 106 | +// } | |
| 107 | +// return list; | |
| 108 | +// } | |
| 109 | +// | |
| 110 | +// @SuppressWarnings({ "unchecked" }) | |
| 111 | +// @Test | |
| 112 | +// public void processAnnotatedType() throws IllegalArgumentException, IllegalAccessException { | |
| 113 | +// ShutdownBootstrap bootstrap = new ShutdownBootstrap(); | |
| 114 | +// List<ShutdownProcessor> list = getProcessors(bootstrap); | |
| 115 | +// | |
| 116 | +// assertTrue(list.isEmpty()); | |
| 117 | +// | |
| 118 | +// AnnotatedMethod am1 = PowerMock.createMock(AnnotatedMethod.class); | |
| 119 | +// AnnotatedMethod am2 = PowerMock.createMock(AnnotatedMethod.class); | |
| 120 | +// AnnotatedMethod am3 = PowerMock.createMock(AnnotatedMethod.class); | |
| 121 | +// | |
| 122 | +// Set<AnnotatedMethod> set = new HashSet<AnnotatedMethod>(); | |
| 123 | +// set.add(am1); | |
| 124 | +// set.add(am2); | |
| 125 | +// set.add(am3); | |
| 126 | +// | |
| 127 | +// expect(am1.isAnnotationPresent(Shutdown.class)).andReturn(true); | |
| 128 | +// expect(am2.isAnnotationPresent(Shutdown.class)).andReturn(true); | |
| 129 | +// expect(am3.isAnnotationPresent(Shutdown.class)).andReturn(false); | |
| 130 | +// expect(event.getAnnotatedType()).andReturn(annotatedType); | |
| 131 | +// expect(annotatedType.getMethods()).andReturn(set); | |
| 132 | +// | |
| 133 | +// replay(event, annotatedType, am1, am2, am3); | |
| 134 | +// bootstrap.processAnnotatedType(event, beanManager); | |
| 135 | +// verify(event, annotatedType); | |
| 136 | +// | |
| 137 | +// list = getProcessors(bootstrap); | |
| 138 | +// assertNotNull(list); | |
| 139 | +// assertFalse(list.isEmpty()); | |
| 140 | +// assertTrue(list.size() == 2); | |
| 141 | +// } | |
| 142 | +// | |
| 143 | +// @SuppressWarnings({ "unchecked", "static-access" }) | |
| 144 | +// @Test | |
| 145 | +// public void testShuttingDown() throws Throwable { | |
| 146 | +// ShutdownBootstrap bootstrap = new ShutdownBootstrap(); | |
| 147 | +// | |
| 148 | +// PowerMock.mockStatic(Contexts.class); | |
| 149 | +// PowerMock.mockStatic(LoggerProducer.class); | |
| 150 | +// | |
| 151 | +// Logger logger = PowerMock.createMock(Logger.class); | |
| 152 | +// ResourceBundleProducer bundleFactory = PowerMock.createMock(ResourceBundleProducer.class); | |
| 153 | +// ResourceBundle bundle = PowerMock.createMock(ResourceBundle.class); | |
| 154 | +// | |
| 155 | +// expect(LoggerProducer.create(EasyMock.anyObject(Class.class))).andReturn(logger).anyTimes(); | |
| 156 | +// expect(bundleFactory.create(EasyMock.anyObject(String.class), EasyMock.anyObject(Locale.class))).andReturn( | |
| 157 | +// bundle).anyTimes(); | |
| 158 | +// expect(bundle.getString(EasyMock.anyObject(String.class), EasyMock.anyObject(String.class))).andReturn("") | |
| 159 | +// .anyTimes(); | |
| 160 | +// | |
| 161 | +// logger.debug(EasyMock.anyObject(String.class)); | |
| 162 | +// logger.trace(EasyMock.anyObject(String.class)); | |
| 163 | +// EasyMock.expectLastCall().anyTimes(); | |
| 164 | +// | |
| 165 | +// Whitebox.setInternalState(AbstractBootstrap.class, ResourceBundleProducer.class, bundleFactory); | |
| 166 | +// | |
| 167 | +// List<ShutdownProcessor> list = getProcessors(bootstrap); | |
| 168 | +// list.clear(); | |
| 169 | +// | |
| 170 | +// MyShuttingDownProcessor<?> processor = PowerMock.createMock(MyShuttingDownProcessor.class); | |
| 171 | +// list.add(processor); | |
| 172 | +// expect(processor.process()).andReturn(true).times(1); | |
| 173 | +// | |
| 174 | +// Contexts.add(EasyMock.anyObject(ThreadLocalContext.class), EasyMock.anyObject(AfterBeanDiscovery.class)); | |
| 175 | +// EasyMock.expectLastCall().anyTimes(); | |
| 176 | +// | |
| 177 | +// Contexts.remove(EasyMock.anyObject(ThreadLocalContext.class)); | |
| 178 | +// EasyMock.expectLastCall().anyTimes(); | |
| 179 | +// | |
| 180 | +// PowerMock.replayAll(); | |
| 181 | +// ShutdownBootstrap.shutdown(); | |
| 182 | +// | |
| 183 | +// assertTrue(list.isEmpty()); | |
| 184 | +// PowerMock.verifyAll(); | |
| 185 | +// } | |
| 186 | +//} | |
| 187 | +// | |
| 188 | +//@SuppressWarnings("rawtypes") | |
| 189 | +//class MyShuttingDownProcessor<T> extends ShutdownProcessor<T> { | |
| 190 | +// | |
| 191 | +// @SuppressWarnings("unchecked") | |
| 192 | +// public MyShuttingDownProcessor(AnnotatedMethod annotatedMethod, BeanManager beanManager) { | |
| 193 | +// super(annotatedMethod, beanManager); | |
| 194 | +// } | |
| 195 | +// | |
| 196 | +// @Override | |
| 197 | +// public int compareTo(final ShutdownProcessor<T> other) { | |
| 198 | +// return 1; | |
| 199 | +// } | |
| 200 | +//} | ... | ... |
impl/core/src/test/java/br/gov/frameworkdemoiselle/internal/bootstrap/StartupBootstrapTest.java
| 1 | -/* | |
| 2 | - * Demoiselle Framework | |
| 3 | - * Copyright (C) 2010 SERPRO | |
| 4 | - * ---------------------------------------------------------------------------- | |
| 5 | - * This file is part of Demoiselle Framework. | |
| 6 | - * | |
| 7 | - * Demoiselle Framework is free software; you can redistribute it and/or | |
| 8 | - * modify it under the terms of the GNU Lesser General Public License version 3 | |
| 9 | - * as published by the Free Software Foundation. | |
| 10 | - * | |
| 11 | - * This program is distributed in the hope that it will be useful, | |
| 12 | - * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 13 | - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 14 | - * GNU General Public License for more details. | |
| 15 | - * | |
| 16 | - * You should have received a copy of the GNU Lesser General Public License version 3 | |
| 17 | - * along with this program; if not, see <http://www.gnu.org/licenses/> | |
| 18 | - * or write to the Free Software Foundation, Inc., 51 Franklin Street, | |
| 19 | - * Fifth Floor, Boston, MA 02110-1301, USA. | |
| 20 | - * ---------------------------------------------------------------------------- | |
| 21 | - * Este arquivo é parte do Framework Demoiselle. | |
| 22 | - * | |
| 23 | - * O Framework Demoiselle é um software livre; você pode redistribuí-lo e/ou | |
| 24 | - * modificá-lo dentro dos termos da GNU LGPL versão 3 como publicada pela Fundação | |
| 25 | - * do Software Livre (FSF). | |
| 26 | - * | |
| 27 | - * Este programa é distribuído na esperança que possa ser útil, mas SEM NENHUMA | |
| 28 | - * GARANTIA; sem uma garantia implícita de ADEQUAÇÃO a qualquer MERCADO ou | |
| 29 | - * APLICAÇÃO EM PARTICULAR. Veja a Licença Pública Geral GNU/LGPL em português | |
| 30 | - * para maiores detalhes. | |
| 31 | - * | |
| 32 | - * Você deve ter recebido uma cópia da GNU LGPL versão 3, sob o título | |
| 33 | - * "LICENCA.txt", junto com esse programa. Se não, acesse <http://www.gnu.org/licenses/> | |
| 34 | - * ou escreva para a Fundação do Software Livre (FSF) Inc., | |
| 35 | - * 51 Franklin St, Fifth Floor, Boston, MA 02111-1301, USA. | |
| 36 | - */ | |
| 37 | -package br.gov.frameworkdemoiselle.internal.bootstrap; | |
| 38 | - | |
| 39 | -import static junit.framework.Assert.assertEquals; | |
| 40 | -import static org.easymock.EasyMock.expect; | |
| 41 | -import static org.easymock.EasyMock.replay; | |
| 42 | -import static org.easymock.EasyMock.verify; | |
| 43 | -import static org.junit.Assert.assertFalse; | |
| 44 | -import static org.junit.Assert.assertNotNull; | |
| 45 | -import static org.junit.Assert.assertTrue; | |
| 46 | -import static org.junit.Assert.fail; | |
| 47 | - | |
| 48 | -import java.lang.reflect.Field; | |
| 49 | -import java.util.HashSet; | |
| 50 | -import java.util.List; | |
| 51 | -import java.util.Locale; | |
| 52 | -import java.util.Set; | |
| 53 | - | |
| 54 | -import javax.enterprise.context.ConversationScoped; | |
| 55 | -import javax.enterprise.context.RequestScoped; | |
| 56 | -import javax.enterprise.context.SessionScoped; | |
| 57 | -import javax.enterprise.inject.spi.AfterBeanDiscovery; | |
| 58 | -import javax.enterprise.inject.spi.AnnotatedMethod; | |
| 59 | -import javax.enterprise.inject.spi.AnnotatedType; | |
| 60 | -import javax.enterprise.inject.spi.BeanManager; | |
| 61 | -import javax.enterprise.inject.spi.ProcessAnnotatedType; | |
| 62 | - | |
| 63 | -import junit.framework.Assert; | |
| 64 | - | |
| 65 | -import org.easymock.EasyMock; | |
| 66 | -import org.junit.Before; | |
| 67 | -import org.junit.Ignore; | |
| 68 | -import org.junit.Test; | |
| 69 | -import org.junit.runner.RunWith; | |
| 70 | -import org.powermock.api.easymock.PowerMock; | |
| 71 | -import org.powermock.core.classloader.annotations.PrepareForTest; | |
| 72 | -import org.powermock.modules.junit4.PowerMockRunner; | |
| 73 | -import org.powermock.reflect.Whitebox; | |
| 74 | -import org.slf4j.Logger; | |
| 75 | - | |
| 76 | -import br.gov.frameworkdemoiselle.annotation.Startup; | |
| 77 | -import br.gov.frameworkdemoiselle.annotation.ViewScoped; | |
| 78 | -import br.gov.frameworkdemoiselle.internal.context.Contexts; | |
| 79 | -import br.gov.frameworkdemoiselle.internal.context.ThreadLocalContext; | |
| 80 | -import br.gov.frameworkdemoiselle.internal.processor.StartupProcessor; | |
| 81 | -import br.gov.frameworkdemoiselle.internal.producer.LoggerProducer; | |
| 82 | -import br.gov.frameworkdemoiselle.internal.producer.ResourceBundleProducer; | |
| 83 | -import br.gov.frameworkdemoiselle.util.ResourceBundle; | |
| 84 | - | |
| 85 | -@Ignore | |
| 86 | -@RunWith(PowerMockRunner.class) | |
| 87 | -@PrepareForTest({ Contexts.class, LoggerProducer.class, ResourceBundle.class, ResourceBundleProducer.class }) | |
| 88 | -@SuppressWarnings({ "rawtypes", "unchecked" }) | |
| 89 | -public class StartupBootstrapTest { | |
| 90 | - | |
| 91 | - private ProcessAnnotatedType event; | |
| 92 | - | |
| 93 | - private BeanManager beanManager; | |
| 94 | - | |
| 95 | - private AnnotatedType annotatedType; | |
| 96 | - | |
| 97 | - @Before | |
| 98 | - public void before() { | |
| 99 | - event = EasyMock.createMock(ProcessAnnotatedType.class); | |
| 100 | - annotatedType = EasyMock.createMock(AnnotatedType.class); | |
| 101 | - beanManager = null; | |
| 102 | - } | |
| 103 | - | |
| 104 | - private List<StartupProcessor> getActions(StartupBootstrap bootstrap) throws IllegalArgumentException, | |
| 105 | - IllegalAccessException { | |
| 106 | - Set<Field> fields = Whitebox.getAllStaticFields(StartupBootstrap.class); | |
| 107 | - List<StartupProcessor> list = null; | |
| 108 | - for (Field field : fields) { | |
| 109 | - if (field.getName().equals("processors")) { | |
| 110 | - list = (List<StartupProcessor>) field.get(bootstrap); | |
| 111 | - } | |
| 112 | - } | |
| 113 | - return list; | |
| 114 | - } | |
| 115 | - | |
| 116 | - @Test | |
| 117 | - public void processAnnotatedType() throws IllegalArgumentException, IllegalAccessException { | |
| 118 | - StartupBootstrap bootstrap = new StartupBootstrap(); | |
| 119 | - List<StartupProcessor> list = getActions(bootstrap); | |
| 120 | - | |
| 121 | - assertNotNull(list); | |
| 122 | - assertTrue(list.isEmpty()); | |
| 123 | - | |
| 124 | - AnnotatedMethod am1 = PowerMock.createMock(AnnotatedMethod.class); | |
| 125 | - AnnotatedMethod am2 = PowerMock.createMock(AnnotatedMethod.class); | |
| 126 | - AnnotatedMethod am3 = PowerMock.createMock(AnnotatedMethod.class); | |
| 127 | - | |
| 128 | - Set<AnnotatedMethod> set = new HashSet<AnnotatedMethod>(); | |
| 129 | - set.add(am1); | |
| 130 | - set.add(am2); | |
| 131 | - set.add(am3); | |
| 132 | - | |
| 133 | - expect(am1.isAnnotationPresent(Startup.class)).andReturn(true); | |
| 134 | - expect(am2.isAnnotationPresent(Startup.class)).andReturn(true); | |
| 135 | - expect(am3.isAnnotationPresent(Startup.class)).andReturn(false); | |
| 136 | - expect(event.getAnnotatedType()).andReturn(annotatedType); | |
| 137 | - expect(annotatedType.getMethods()).andReturn(set); | |
| 138 | - | |
| 139 | - replay(event, annotatedType, am1, am2, am3); | |
| 140 | - bootstrap.processAnnotatedType(event, beanManager); | |
| 141 | - verify(event, annotatedType); | |
| 142 | - | |
| 143 | - list = getActions(bootstrap); | |
| 144 | - assertNotNull(list); | |
| 145 | - assertFalse(list.isEmpty()); | |
| 146 | - assertTrue(list.size() == 2); | |
| 147 | - } | |
| 148 | - | |
| 149 | - @SuppressWarnings("static-access") | |
| 150 | - @Test | |
| 151 | - public void testLoadTempContexts() { | |
| 152 | - StartupBootstrap bootstrap = new StartupBootstrap(); | |
| 153 | - | |
| 154 | - Logger logger = PowerMock.createMock(Logger.class); | |
| 155 | - ResourceBundleProducer bundleFactory = PowerMock.createMock(ResourceBundleProducer.class); | |
| 156 | - ResourceBundle bundle = PowerMock.createMock(ResourceBundle.class); | |
| 157 | - | |
| 158 | - PowerMock.mockStatic(Contexts.class); | |
| 159 | - PowerMock.mockStatic(LoggerProducer.class); | |
| 160 | - | |
| 161 | - List<ThreadLocalContext> tempContexts = Whitebox.getInternalState(bootstrap, "tempContexts"); | |
| 162 | - | |
| 163 | - assertNotNull(tempContexts); | |
| 164 | - assertTrue(tempContexts.isEmpty()); | |
| 165 | - | |
| 166 | - expect(LoggerProducer.create(EasyMock.anyObject(Class.class))).andReturn(logger).anyTimes(); | |
| 167 | - expect(bundleFactory.create(EasyMock.anyObject(String.class), EasyMock.anyObject(Locale.class))).andReturn( | |
| 168 | - bundle).anyTimes(); | |
| 169 | - expect(bundle.getString(EasyMock.anyObject(String.class), EasyMock.anyObject(String.class))).andReturn("") | |
| 170 | - .anyTimes(); | |
| 171 | - | |
| 172 | - logger.trace(EasyMock.anyObject(String.class)); | |
| 173 | - EasyMock.expectLastCall().anyTimes(); | |
| 174 | - | |
| 175 | - Contexts.add(EasyMock.anyObject(ThreadLocalContext.class), EasyMock.anyObject(AfterBeanDiscovery.class)); | |
| 176 | - EasyMock.expectLastCall().anyTimes(); | |
| 177 | - | |
| 178 | - Whitebox.setInternalState(AbstractBootstrap.class, ResourceBundleProducer.class, bundleFactory); | |
| 179 | - | |
| 180 | - PowerMock.replayAll(); | |
| 181 | - bootstrap.loadTempContexts(null); | |
| 182 | - PowerMock.verifyAll(); | |
| 183 | - | |
| 184 | - assertNotNull(tempContexts); | |
| 185 | - assertEquals(4, tempContexts.size()); | |
| 186 | - | |
| 187 | - for (ThreadLocalContext tlc : tempContexts) { | |
| 188 | - if (!tlc.getScope().equals(SessionScoped.class) && !tlc.getScope().equals(ConversationScoped.class) | |
| 189 | - && !tlc.getScope().equals(RequestScoped.class) && !tlc.getScope().equals(ViewScoped.class)) { | |
| 190 | - fail(); | |
| 191 | - } | |
| 192 | - } | |
| 193 | - } | |
| 194 | - | |
| 195 | - @SuppressWarnings("static-access") | |
| 196 | - @Test | |
| 197 | - public void testStartup() throws Throwable { | |
| 198 | - StartupBootstrap bootstrap = new StartupBootstrap(); | |
| 199 | - | |
| 200 | - PowerMock.mockStatic(Contexts.class); | |
| 201 | - PowerMock.mockStatic(LoggerProducer.class); | |
| 202 | - | |
| 203 | - Logger logger = PowerMock.createMock(Logger.class); | |
| 204 | - ResourceBundleProducer bundleFactory = PowerMock.createMock(ResourceBundleProducer.class); | |
| 205 | - ResourceBundle bundle = PowerMock.createMock(ResourceBundle.class); | |
| 206 | - | |
| 207 | - expect(LoggerProducer.create(EasyMock.anyObject(Class.class))).andReturn(logger).anyTimes(); | |
| 208 | - expect(bundleFactory.create(EasyMock.anyObject(String.class), EasyMock.anyObject(Locale.class))).andReturn( | |
| 209 | - bundle).anyTimes(); | |
| 210 | - expect(bundle.getString(EasyMock.anyObject(String.class), EasyMock.anyObject(String.class))).andReturn("") | |
| 211 | - .anyTimes(); | |
| 212 | - | |
| 213 | - logger.debug(EasyMock.anyObject(String.class)); | |
| 214 | - EasyMock.expectLastCall().anyTimes(); | |
| 215 | - | |
| 216 | - Whitebox.setInternalState(AbstractBootstrap.class, ResourceBundleProducer.class, bundleFactory); | |
| 217 | - | |
| 218 | - List<StartupProcessor> list = getActions(bootstrap); | |
| 219 | - list.clear(); | |
| 220 | - | |
| 221 | - MyProcessor<?> processor = PowerMock.createMock(MyProcessor.class); | |
| 222 | - list.add(processor); | |
| 223 | - expect(processor.process()).andReturn(true).times(1); | |
| 224 | - | |
| 225 | - PowerMock.replayAll(); | |
| 226 | - bootstrap.startup(); | |
| 227 | - | |
| 228 | - assertTrue(list.isEmpty()); | |
| 229 | - PowerMock.verifyAll(); | |
| 230 | - } | |
| 231 | - | |
| 232 | - @SuppressWarnings("static-access") | |
| 233 | - @Test | |
| 234 | - public void testLoadTempContextsAndStartup() { | |
| 235 | - | |
| 236 | - StartupBootstrap bootstrap = new StartupBootstrap(); | |
| 237 | - | |
| 238 | - bootstrap.loadTempContexts(null); | |
| 239 | - Assert.assertFalse(Contexts.getActiveContexts().isEmpty()); | |
| 240 | - | |
| 241 | - try { | |
| 242 | - bootstrap.startup(); | |
| 243 | - Assert.assertTrue(Contexts.getActiveContexts().isEmpty()); | |
| 244 | - } catch (Throwable e) { | |
| 245 | - fail(); | |
| 246 | - } | |
| 247 | - } | |
| 248 | -} | |
| 249 | - | |
| 250 | -@SuppressWarnings("rawtypes") | |
| 251 | -class MyProcessor<T> extends StartupProcessor<T> { | |
| 252 | - | |
| 253 | - @SuppressWarnings("unchecked") | |
| 254 | - public MyProcessor(AnnotatedMethod annotatedMethod, BeanManager beanManager) { | |
| 255 | - super(annotatedMethod, beanManager); | |
| 256 | - } | |
| 257 | - | |
| 258 | - @Override | |
| 259 | - public int compareTo(final StartupProcessor<T> other) { | |
| 260 | - return 1; | |
| 261 | - } | |
| 262 | -} | |
| 1 | +///* | |
| 2 | +// * Demoiselle Framework | |
| 3 | +// * Copyright (C) 2010 SERPRO | |
| 4 | +// * ---------------------------------------------------------------------------- | |
| 5 | +// * This file is part of Demoiselle Framework. | |
| 6 | +// * | |
| 7 | +// * Demoiselle Framework is free software; you can redistribute it and/or | |
| 8 | +// * modify it under the terms of the GNU Lesser General Public License version 3 | |
| 9 | +// * as published by the Free Software Foundation. | |
| 10 | +// * | |
| 11 | +// * This program is distributed in the hope that it will be useful, | |
| 12 | +// * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 13 | +// * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 14 | +// * GNU General Public License for more details. | |
| 15 | +// * | |
| 16 | +// * You should have received a copy of the GNU Lesser General Public License version 3 | |
| 17 | +// * along with this program; if not, see <http://www.gnu.org/licenses/> | |
| 18 | +// * or write to the Free Software Foundation, Inc., 51 Franklin Street, | |
| 19 | +// * Fifth Floor, Boston, MA 02110-1301, USA. | |
| 20 | +// * ---------------------------------------------------------------------------- | |
| 21 | +// * Este arquivo é parte do Framework Demoiselle. | |
| 22 | +// * | |
| 23 | +// * O Framework Demoiselle é um software livre; você pode redistribuí-lo e/ou | |
| 24 | +// * modificá-lo dentro dos termos da GNU LGPL versão 3 como publicada pela Fundação | |
| 25 | +// * do Software Livre (FSF). | |
| 26 | +// * | |
| 27 | +// * Este programa é distribuído na esperança que possa ser útil, mas SEM NENHUMA | |
| 28 | +// * GARANTIA; sem uma garantia implícita de ADEQUAÇÃO a qualquer MERCADO ou | |
| 29 | +// * APLICAÇÃO EM PARTICULAR. Veja a Licença Pública Geral GNU/LGPL em português | |
| 30 | +// * para maiores detalhes. | |
| 31 | +// * | |
| 32 | +// * Você deve ter recebido uma cópia da GNU LGPL versão 3, sob o título | |
| 33 | +// * "LICENCA.txt", junto com esse programa. Se não, acesse <http://www.gnu.org/licenses/> | |
| 34 | +// * ou escreva para a Fundação do Software Livre (FSF) Inc., | |
| 35 | +// * 51 Franklin St, Fifth Floor, Boston, MA 02111-1301, USA. | |
| 36 | +// */ | |
| 37 | +//package br.gov.frameworkdemoiselle.internal.bootstrap; | |
| 38 | +// | |
| 39 | +//import static junit.framework.Assert.assertEquals; | |
| 40 | +//import static org.easymock.EasyMock.expect; | |
| 41 | +//import static org.easymock.EasyMock.replay; | |
| 42 | +//import static org.easymock.EasyMock.verify; | |
| 43 | +//import static org.junit.Assert.assertFalse; | |
| 44 | +//import static org.junit.Assert.assertNotNull; | |
| 45 | +//import static org.junit.Assert.assertTrue; | |
| 46 | +//import static org.junit.Assert.fail; | |
| 47 | +// | |
| 48 | +//import java.lang.reflect.Field; | |
| 49 | +//import java.util.HashSet; | |
| 50 | +//import java.util.List; | |
| 51 | +//import java.util.Locale; | |
| 52 | +//import java.util.Set; | |
| 53 | +// | |
| 54 | +//import javax.enterprise.context.ConversationScoped; | |
| 55 | +//import javax.enterprise.context.RequestScoped; | |
| 56 | +//import javax.enterprise.context.SessionScoped; | |
| 57 | +//import javax.enterprise.inject.spi.AfterBeanDiscovery; | |
| 58 | +//import javax.enterprise.inject.spi.AnnotatedMethod; | |
| 59 | +//import javax.enterprise.inject.spi.AnnotatedType; | |
| 60 | +//import javax.enterprise.inject.spi.BeanManager; | |
| 61 | +//import javax.enterprise.inject.spi.ProcessAnnotatedType; | |
| 62 | +// | |
| 63 | +//import junit.framework.Assert; | |
| 64 | +// | |
| 65 | +//import org.easymock.EasyMock; | |
| 66 | +//import org.junit.Before; | |
| 67 | +//import org.junit.Ignore; | |
| 68 | +//import org.junit.Test; | |
| 69 | +//import org.junit.runner.RunWith; | |
| 70 | +//import org.powermock.api.easymock.PowerMock; | |
| 71 | +//import org.powermock.core.classloader.annotations.PrepareForTest; | |
| 72 | +//import org.powermock.modules.junit4.PowerMockRunner; | |
| 73 | +//import org.powermock.reflect.Whitebox; | |
| 74 | +//import org.slf4j.Logger; | |
| 75 | +// | |
| 76 | +//import br.gov.frameworkdemoiselle.annotation.Startup; | |
| 77 | +//import br.gov.frameworkdemoiselle.annotation.ViewScoped; | |
| 78 | +//import br.gov.frameworkdemoiselle.internal.context.Contexts; | |
| 79 | +//import br.gov.frameworkdemoiselle.internal.context.ThreadLocalContext; | |
| 80 | +//import br.gov.frameworkdemoiselle.internal.processor.StartupProcessor; | |
| 81 | +//import br.gov.frameworkdemoiselle.internal.producer.LoggerProducer; | |
| 82 | +//import br.gov.frameworkdemoiselle.internal.producer.ResourceBundleProducer; | |
| 83 | +//import br.gov.frameworkdemoiselle.util.ResourceBundle; | |
| 84 | +// | |
| 85 | +//@Ignore | |
| 86 | +//@RunWith(PowerMockRunner.class) | |
| 87 | +//@PrepareForTest({ Contexts.class, LoggerProducer.class, ResourceBundle.class, ResourceBundleProducer.class }) | |
| 88 | +//@SuppressWarnings({ "rawtypes", "unchecked" }) | |
| 89 | +//public class StartupBootstrapTest { | |
| 90 | +// | |
| 91 | +// private ProcessAnnotatedType event; | |
| 92 | +// | |
| 93 | +// private BeanManager beanManager; | |
| 94 | +// | |
| 95 | +// private AnnotatedType annotatedType; | |
| 96 | +// | |
| 97 | +// @Before | |
| 98 | +// public void before() { | |
| 99 | +// event = EasyMock.createMock(ProcessAnnotatedType.class); | |
| 100 | +// annotatedType = EasyMock.createMock(AnnotatedType.class); | |
| 101 | +// beanManager = null; | |
| 102 | +// } | |
| 103 | +// | |
| 104 | +// private List<StartupProcessor> getActions(StartupBootstrap bootstrap) throws IllegalArgumentException, | |
| 105 | +// IllegalAccessException { | |
| 106 | +// Set<Field> fields = Whitebox.getAllStaticFields(StartupBootstrap.class); | |
| 107 | +// List<StartupProcessor> list = null; | |
| 108 | +// for (Field field : fields) { | |
| 109 | +// if (field.getName().equals("processors")) { | |
| 110 | +// list = (List<StartupProcessor>) field.get(bootstrap); | |
| 111 | +// } | |
| 112 | +// } | |
| 113 | +// return list; | |
| 114 | +// } | |
| 115 | +// | |
| 116 | +// @Test | |
| 117 | +// public void processAnnotatedType() throws IllegalArgumentException, IllegalAccessException { | |
| 118 | +// StartupBootstrap bootstrap = new StartupBootstrap(); | |
| 119 | +// List<StartupProcessor> list = getActions(bootstrap); | |
| 120 | +// | |
| 121 | +// assertNotNull(list); | |
| 122 | +// assertTrue(list.isEmpty()); | |
| 123 | +// | |
| 124 | +// AnnotatedMethod am1 = PowerMock.createMock(AnnotatedMethod.class); | |
| 125 | +// AnnotatedMethod am2 = PowerMock.createMock(AnnotatedMethod.class); | |
| 126 | +// AnnotatedMethod am3 = PowerMock.createMock(AnnotatedMethod.class); | |
| 127 | +// | |
| 128 | +// Set<AnnotatedMethod> set = new HashSet<AnnotatedMethod>(); | |
| 129 | +// set.add(am1); | |
| 130 | +// set.add(am2); | |
| 131 | +// set.add(am3); | |
| 132 | +// | |
| 133 | +// expect(am1.isAnnotationPresent(Startup.class)).andReturn(true); | |
| 134 | +// expect(am2.isAnnotationPresent(Startup.class)).andReturn(true); | |
| 135 | +// expect(am3.isAnnotationPresent(Startup.class)).andReturn(false); | |
| 136 | +// expect(event.getAnnotatedType()).andReturn(annotatedType); | |
| 137 | +// expect(annotatedType.getMethods()).andReturn(set); | |
| 138 | +// | |
| 139 | +// replay(event, annotatedType, am1, am2, am3); | |
| 140 | +// bootstrap.processAnnotatedType(event, beanManager); | |
| 141 | +// verify(event, annotatedType); | |
| 142 | +// | |
| 143 | +// list = getActions(bootstrap); | |
| 144 | +// assertNotNull(list); | |
| 145 | +// assertFalse(list.isEmpty()); | |
| 146 | +// assertTrue(list.size() == 2); | |
| 147 | +// } | |
| 148 | +// | |
| 149 | +// @SuppressWarnings("static-access") | |
| 150 | +// @Test | |
| 151 | +// public void testLoadTempContexts() { | |
| 152 | +// StartupBootstrap bootstrap = new StartupBootstrap(); | |
| 153 | +// | |
| 154 | +// Logger logger = PowerMock.createMock(Logger.class); | |
| 155 | +// ResourceBundleProducer bundleFactory = PowerMock.createMock(ResourceBundleProducer.class); | |
| 156 | +// ResourceBundle bundle = PowerMock.createMock(ResourceBundle.class); | |
| 157 | +// | |
| 158 | +// PowerMock.mockStatic(Contexts.class); | |
| 159 | +// PowerMock.mockStatic(LoggerProducer.class); | |
| 160 | +// | |
| 161 | +// List<ThreadLocalContext> tempContexts = Whitebox.getInternalState(bootstrap, "tempContexts"); | |
| 162 | +// | |
| 163 | +// assertNotNull(tempContexts); | |
| 164 | +// assertTrue(tempContexts.isEmpty()); | |
| 165 | +// | |
| 166 | +// expect(LoggerProducer.create(EasyMock.anyObject(Class.class))).andReturn(logger).anyTimes(); | |
| 167 | +// expect(bundleFactory.create(EasyMock.anyObject(String.class), EasyMock.anyObject(Locale.class))).andReturn( | |
| 168 | +// bundle).anyTimes(); | |
| 169 | +// expect(bundle.getString(EasyMock.anyObject(String.class), EasyMock.anyObject(String.class))).andReturn("") | |
| 170 | +// .anyTimes(); | |
| 171 | +// | |
| 172 | +// logger.trace(EasyMock.anyObject(String.class)); | |
| 173 | +// EasyMock.expectLastCall().anyTimes(); | |
| 174 | +// | |
| 175 | +// Contexts.add(EasyMock.anyObject(ThreadLocalContext.class), EasyMock.anyObject(AfterBeanDiscovery.class)); | |
| 176 | +// EasyMock.expectLastCall().anyTimes(); | |
| 177 | +// | |
| 178 | +// Whitebox.setInternalState(AbstractBootstrap.class, ResourceBundleProducer.class, bundleFactory); | |
| 179 | +// | |
| 180 | +// PowerMock.replayAll(); | |
| 181 | +// bootstrap.loadTempContexts(null); | |
| 182 | +// PowerMock.verifyAll(); | |
| 183 | +// | |
| 184 | +// assertNotNull(tempContexts); | |
| 185 | +// assertEquals(4, tempContexts.size()); | |
| 186 | +// | |
| 187 | +// for (ThreadLocalContext tlc : tempContexts) { | |
| 188 | +// if (!tlc.getScope().equals(SessionScoped.class) && !tlc.getScope().equals(ConversationScoped.class) | |
| 189 | +// && !tlc.getScope().equals(RequestScoped.class) && !tlc.getScope().equals(ViewScoped.class)) { | |
| 190 | +// fail(); | |
| 191 | +// } | |
| 192 | +// } | |
| 193 | +// } | |
| 194 | +// | |
| 195 | +// @SuppressWarnings("static-access") | |
| 196 | +// @Test | |
| 197 | +// public void testStartup() throws Throwable { | |
| 198 | +// StartupBootstrap bootstrap = new StartupBootstrap(); | |
| 199 | +// | |
| 200 | +// PowerMock.mockStatic(Contexts.class); | |
| 201 | +// PowerMock.mockStatic(LoggerProducer.class); | |
| 202 | +// | |
| 203 | +// Logger logger = PowerMock.createMock(Logger.class); | |
| 204 | +// ResourceBundleProducer bundleFactory = PowerMock.createMock(ResourceBundleProducer.class); | |
| 205 | +// ResourceBundle bundle = PowerMock.createMock(ResourceBundle.class); | |
| 206 | +// | |
| 207 | +// expect(LoggerProducer.create(EasyMock.anyObject(Class.class))).andReturn(logger).anyTimes(); | |
| 208 | +// expect(bundleFactory.create(EasyMock.anyObject(String.class), EasyMock.anyObject(Locale.class))).andReturn( | |
| 209 | +// bundle).anyTimes(); | |
| 210 | +// expect(bundle.getString(EasyMock.anyObject(String.class), EasyMock.anyObject(String.class))).andReturn("") | |
| 211 | +// .anyTimes(); | |
| 212 | +// | |
| 213 | +// logger.debug(EasyMock.anyObject(String.class)); | |
| 214 | +// EasyMock.expectLastCall().anyTimes(); | |
| 215 | +// | |
| 216 | +// Whitebox.setInternalState(AbstractBootstrap.class, ResourceBundleProducer.class, bundleFactory); | |
| 217 | +// | |
| 218 | +// List<StartupProcessor> list = getActions(bootstrap); | |
| 219 | +// list.clear(); | |
| 220 | +// | |
| 221 | +// MyProcessor<?> processor = PowerMock.createMock(MyProcessor.class); | |
| 222 | +// list.add(processor); | |
| 223 | +// expect(processor.process()).andReturn(true).times(1); | |
| 224 | +// | |
| 225 | +// PowerMock.replayAll(); | |
| 226 | +// bootstrap.startup(); | |
| 227 | +// | |
| 228 | +// assertTrue(list.isEmpty()); | |
| 229 | +// PowerMock.verifyAll(); | |
| 230 | +// } | |
| 231 | +// | |
| 232 | +// @SuppressWarnings("static-access") | |
| 233 | +// @Test | |
| 234 | +// public void testLoadTempContextsAndStartup() { | |
| 235 | +// | |
| 236 | +// StartupBootstrap bootstrap = new StartupBootstrap(); | |
| 237 | +// | |
| 238 | +// bootstrap.loadTempContexts(null); | |
| 239 | +// Assert.assertFalse(Contexts.getActiveContexts().isEmpty()); | |
| 240 | +// | |
| 241 | +// try { | |
| 242 | +// bootstrap.startup(); | |
| 243 | +// Assert.assertTrue(Contexts.getActiveContexts().isEmpty()); | |
| 244 | +// } catch (Throwable e) { | |
| 245 | +// fail(); | |
| 246 | +// } | |
| 247 | +// } | |
| 248 | +//} | |
| 249 | +// | |
| 250 | +//@SuppressWarnings("rawtypes") | |
| 251 | +//class MyProcessor<T> extends StartupProcessor<T> { | |
| 252 | +// | |
| 253 | +// @SuppressWarnings("unchecked") | |
| 254 | +// public MyProcessor(AnnotatedMethod annotatedMethod, BeanManager beanManager) { | |
| 255 | +// super(annotatedMethod, beanManager); | |
| 256 | +// } | |
| 257 | +// | |
| 258 | +// @Override | |
| 259 | +// public int compareTo(final StartupProcessor<T> other) { | |
| 260 | +// return 1; | |
| 261 | +// } | |
| 262 | +// } | ... | ... |
impl/extension/jsf/src/main/java/br/gov/frameworkdemoiselle/util/ServletContextListener.java
| ... | ... | @@ -1,19 +0,0 @@ |
| 1 | -package br.gov.frameworkdemoiselle.util; | |
| 2 | - | |
| 3 | -import javax.servlet.ServletContextEvent; | |
| 4 | - | |
| 5 | -import br.gov.frameworkdemoiselle.internal.bootstrap.ShutdownBootstrap; | |
| 6 | -import br.gov.frameworkdemoiselle.internal.bootstrap.StartupBootstrap; | |
| 7 | - | |
| 8 | -public class ServletContextListener implements javax.servlet.ServletContextListener { | |
| 9 | - | |
| 10 | - @Override | |
| 11 | - public void contextInitialized(ServletContextEvent event) { | |
| 12 | - StartupBootstrap.startup(); | |
| 13 | - } | |
| 14 | - | |
| 15 | - @Override | |
| 16 | - public void contextDestroyed(ServletContextEvent event) { | |
| 17 | - ShutdownBootstrap.shutdown(); | |
| 18 | - } | |
| 19 | -} |
impl/extension/servlet/src/main/java/br/gov/frameworkdemoiselle/util/ServletListener.java
| ... | ... | @@ -38,18 +38,30 @@ package br.gov.frameworkdemoiselle.util; |
| 38 | 38 | |
| 39 | 39 | import javax.servlet.ServletContextEvent; |
| 40 | 40 | |
| 41 | -import br.gov.frameworkdemoiselle.internal.bootstrap.ShutdownBootstrap; | |
| 42 | -import br.gov.frameworkdemoiselle.internal.bootstrap.StartupBootstrap; | |
| 41 | +import br.gov.frameworkdemoiselle.internal.bootstrap.BeforeApplicationFinalization; | |
| 42 | +import br.gov.frameworkdemoiselle.internal.bootstrap.BeforeApplicationInitialization; | |
| 43 | 43 | |
| 44 | 44 | public class ServletListener implements javax.servlet.ServletContextListener { |
| 45 | 45 | |
| 46 | 46 | @Override |
| 47 | 47 | public void contextInitialized(ServletContextEvent event) { |
| 48 | - StartupBootstrap.startup(); | |
| 48 | + Beans.getBeanManager().fireEvent(new BeforeApplicationInitialization() { | |
| 49 | + | |
| 50 | + @Override | |
| 51 | + public boolean removeProcessors() { | |
| 52 | + return false; | |
| 53 | + } | |
| 54 | + }); | |
| 49 | 55 | } |
| 50 | 56 | |
| 51 | 57 | @Override |
| 52 | 58 | public void contextDestroyed(ServletContextEvent event) { |
| 53 | - ShutdownBootstrap.shutdown(); | |
| 59 | + Beans.getBeanManager().fireEvent(new BeforeApplicationFinalization() { | |
| 60 | + | |
| 61 | + @Override | |
| 62 | + public boolean removeProcessors() { | |
| 63 | + return false; | |
| 64 | + } | |
| 65 | + }); | |
| 54 | 66 | } |
| 55 | 67 | } | ... | ... |