/* * 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.cdi.tck.tests.extensions.beanManager.bootstrap.unavailable.methods; 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.*; import javax.enterprise.util.AnnotationLiteral; 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 static org.testng.Assert.fail; public class WrongExtension implements Extension { private Bean<Foo> fooBean; private InjectionPoint injectionPoint; public void observeBeforeBeanDiscovery(@Observes BeforeBeanDiscovery event, BeanManager beanManager) { testUnavailableMethodsBeforeABD(beanManager); testUnavailableMethodsBeforeADV(beanManager); } public void observeProcessAnnotatedType(@Observes ProcessAnnotatedType<?> event, BeanManager beanManager) { testUnavailableMethodsBeforeABD(beanManager); testUnavailableMethodsBeforeADV(beanManager); } public void observeAfterTypeDiscovery(@Observes AfterTypeDiscovery event, BeanManager beanManager) { testUnavailableMethodsBeforeABD(beanManager); testUnavailableMethodsBeforeADV(beanManager); } public void observeProcessInjectionTarget(@Observes ProcessInjectionTarget<Foo> event, BeanManager beanManager) { testUnavailableMethodsBeforeABD(beanManager); testUnavailableMethodsBeforeADV(beanManager); } public void observeInjectionPoint(@Observes ProcessInjectionPoint<Foo, ?> event, BeanManager beanManager) { if (injectionPoint == null) { // simply store some IP which we'll try to validate later injectionPoint = event.getInjectionPoint(); } testUnavailableMethodsBeforeABD(beanManager); testUnavailableMethodsBeforeADV(beanManager); } public void observerProcessBeanAttributes(@Observes ProcessBeanAttributes<Foo> event, BeanManager beanManager) { testUnavailableMethodsBeforeABD(beanManager); } public void observeProcessBean(@Observes ProcessBean<Foo> event, BeanManager beanManager) { this.fooBean = event.getBean(); testUnavailableMethodsBeforeABD(beanManager); testUnavailableMethodsBeforeADV(beanManager); } public void observerProcessObserverMethod(@Observes ProcessObserverMethod<Integer, Foo> event, BeanManager beanManager) { testUnavailableMethodsBeforeABD(beanManager); testUnavailableMethodsBeforeADV(beanManager); } public void observeAfterBeanDiscovery(@Observes AfterBeanDiscovery event, BeanManager beanManager) { testAvailableMethodsInABD(beanManager); testUnavailableMethodsBeforeADV(beanManager); } public void observerAfterDeploymentValidation(@Observes AfterDeploymentValidation event, BeanManager manager) { testAvailableMethodsInABD(manager); testAvailableMethodsInADV(manager); } @SuppressWarnings({ "serial", "unchecked" }) private void testUnavailableMethodsBeforeABD(final BeanManager beanManager) { new Invocation() { void execute() { beanManager.getBeans("foo"); } }.run(); new Invocation() { void execute() { beanManager.getBeans(Foo.class); } }.run(); new Invocation() { void execute() { beanManager.resolve(null); } }.run(); new Invocation() { void execute() { beanManager.resolveObserverMethods(new Foo()); } }.run(); new Invocation() { void execute() { beanManager.resolveInterceptors(InterceptionType.AROUND_INVOKE, new AnnotationLiteral<Transactional>() { }); } }.run(); new Invocation() { void execute() { beanManager.resolveDecorators(new HashSet<Type>(Arrays.asList(Foo.class))); } }.run(); new Invocation() { void execute() { beanManager.validate(injectionPoint); } }.run(); new Invocation() { void execute() { beanManager.getPassivationCapableBean("foo"); } }.run(); } @SuppressWarnings({ "serial", "unchecked" }) private void testUnavailableMethodsBeforeADV(final BeanManager beanManager) { final CreationalContext<Foo> creationalContext = beanManager.createCreationalContext(fooBean); new Invocation() { void execute() { beanManager.getReference(fooBean, Foo.class, creationalContext); } }.run(); new Invocation() { void execute() { beanManager.getInjectableReference( beanManager.createInjectionPoint(beanManager.createAnnotatedType(Foo.class).getFields().iterator().next()), creationalContext); } }.run(); new Invocation() { void execute() { beanManager.createInstance().select(Foo.class); } }.run(); } @SuppressWarnings({ "unchecked", "serial" }) private void testAvailableMethodsInABD(BeanManager beanManager) { beanManager.getBeans("foo"); beanManager.getBeans(Foo.class); beanManager.resolve(null); beanManager.resolveObserverMethods(new Foo()); beanManager.resolveInterceptors(InterceptionType.AROUND_INVOKE, new AnnotationLiteral<Transactional>() { }); beanManager.resolveDecorators(new HashSet<Type>(Arrays.asList(Foo.class))); beanManager.validate(injectionPoint); beanManager.getPassivationCapableBean("foo"); } private void testAvailableMethodsInADV(BeanManager beanManager) { beanManager.getReference(new FooBean(), Foo.class, beanManager.createCreationalContext(null)); beanManager.getInjectableReference( beanManager.createInjectionPoint(beanManager.createAnnotatedType(Foo.class).getFields().iterator().next()), beanManager.createCreationalContext(null)); } 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; } } private static abstract class Invocation { void run() { try { execute(); fail("Expected exception not thrown"); } catch (IllegalStateException expected) { } } abstract void execute(); } }