/* * JBoss, Home of Professional Open Source * Copyright 2012, Red Hat, Inc., and individual contributors * by the @authors tag. See the copyright.txt in the distribution for a * full listing of individual contributors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * http://www.apache.org/licenses/LICENSE-2.0 * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.jboss.weld.tests.beanManager.bootstrap.unavailable.methods; import static org.junit.Assert.fail; import java.lang.annotation.Annotation; import java.lang.reflect.Member; import java.lang.reflect.Type; import java.util.Arrays; import java.util.Collections; import java.util.HashSet; import java.util.Set; import javax.enterprise.context.Dependent; import javax.enterprise.context.spi.CreationalContext; import javax.enterprise.event.Observes; import javax.enterprise.inject.Vetoed; import javax.enterprise.inject.spi.AfterBeanDiscovery; import javax.enterprise.inject.spi.AfterDeploymentValidation; import javax.enterprise.inject.spi.Annotated; import javax.enterprise.inject.spi.Bean; import javax.enterprise.inject.spi.BeanManager; import javax.enterprise.inject.spi.BeforeBeanDiscovery; import javax.enterprise.inject.spi.Extension; import javax.enterprise.inject.spi.InjectionPoint; import javax.enterprise.inject.spi.InterceptionType; import javax.enterprise.inject.spi.ProcessBean; import javax.enterprise.inject.spi.ProcessInjectionPoint; import javax.enterprise.util.AnnotationLiteral; public class WrongExtension implements Extension { private Bean<Foo> fooBean; private InjectionPoint injectionPoint; public void observeBeforeBeanDiscovery(@Observes BeforeBeanDiscovery event, BeanManager beanManager) { testAbdMethods(beanManager); } public void observeProcessBean(@Observes ProcessBean<Foo> event, BeanManager beanManager) { this.fooBean = event.getBean(); testAbdMethods(beanManager); } public void observeAfterBeanDiscovery(@Observes AfterBeanDiscovery event, BeanManager beanManager) { testAbvMethods(beanManager); } @SuppressWarnings({ "serial" }) private void testAbdMethods(BeanManager beanManager) { try { beanManager.getBeans("foo"); fail("getBeans() must not be available"); } catch (IllegalStateException e) { // Expected } try { beanManager.getBeans(Foo.class); fail("getBeans() must not be available"); } catch (IllegalStateException e) { // Expected } try { beanManager.resolve(null); fail("resolve() must not be available"); } catch (IllegalStateException e) { // Expected } try { beanManager.resolveObserverMethods(new Foo()); fail("resolveObserverMethods() must not be available"); } catch (IllegalStateException e) { // Expected } try { beanManager.resolveInterceptors(InterceptionType.AROUND_INVOKE, new AnnotationLiteral<Transactional>() { }); fail("resolveInterceptors() must not be available"); } catch (IllegalStateException e) { // Expected } try { beanManager.resolveDecorators(new HashSet<Type>(Collections.singletonList(Foo.class))); fail("resolveDecorators() must not be available"); } catch (IllegalStateException e) { // Expected } try { beanManager.validate(new FooInjectionPoint()); fail("validate() must not be available"); } catch (IllegalStateException e) { // Expected } try { beanManager.getPassivationCapableBean("foo"); fail("getPassivationCapableBean() must not be available"); } catch (IllegalStateException e) { // Expected } testAbvMethods(beanManager); } private void testAbvMethods(BeanManager beanManager) { if (fooBean != null) { try { beanManager.getReference(fooBean, Foo.class, null); fail("getReference() must not be available"); } catch (IllegalStateException e) { // Expected } } try { beanManager.getInjectableReference( beanManager.createInjectionPoint(beanManager.createAnnotatedType(Foo.class).getFields().iterator().next()), null); fail("getInjectableReference() must not be available"); } catch (IllegalStateException e) { // Expected } } void observeInjectionPoint(@Observes ProcessInjectionPoint<?, ?> event) { if (injectionPoint == null) { // simply store some IP which we'll try to validate later injectionPoint = event.getInjectionPoint(); } } void validate(@Observes AfterDeploymentValidation event, BeanManager manager) { testAvailableMethods(manager); } private void testAvailableMethods(BeanManager beanManager) { beanManager.getReference(new FooBean(), Foo.class, beanManager.createCreationalContext(null)); beanManager.getBeans("foo"); beanManager.getBeans(Foo.class); beanManager.getInjectableReference( beanManager.createInjectionPoint(beanManager.createAnnotatedType(Foo.class).getFields().iterator().next()), beanManager.createCreationalContext(null)); beanManager.resolve(null); beanManager.resolveObserverMethods(new Foo()); beanManager.resolveInterceptors(InterceptionType.AROUND_INVOKE, new AnnotationLiteral<Transactional>() { }); beanManager.resolveDecorators(new HashSet<Type>(Collections.singletonList(Foo.class))); beanManager.validate(injectionPoint); beanManager.getPassivationCapableBean("foo"); } private static class FooBean implements Bean<Foo> { @Override public Class<?> getBeanClass() { return Foo.class; } @Override public Set<InjectionPoint> getInjectionPoints() { return Collections.emptySet(); } @Override public boolean isNullable() { return false; } @Override public Set<Type> getTypes() { HashSet<Type> set = new HashSet<Type>(); set.add(Foo.class); return set; } @Override public Set<Annotation> getQualifiers() { return Collections.emptySet(); } @Override public Class<? extends Annotation> getScope() { return Dependent.class; } @Override public String getName() { return null; } @Override public Set<Class<? extends Annotation>> getStereotypes() { return Collections.emptySet(); } @Override public boolean isAlternative() { return false; } @Override public Foo create(CreationalContext<Foo> creationalContext) { return null; } @Override public void destroy(Foo instance, CreationalContext<Foo> creationalContext) { } } @Vetoed private static class FooInjectionPoint implements InjectionPoint { @Override public boolean isTransient() { return false; } @Override public boolean isDelegate() { return false; } @Override public Type getType() { return Foo.class; } @Override public Set<Annotation> getQualifiers() { return null; } @Override public Member getMember() { return null; } @Override public Bean<?> getBean() { return null; } @Override public Annotated getAnnotated() { return null; } } }