/*
* JBoss, Home of Professional Open Source
* Copyright 2010, 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.inheritance.specialization.simple;
import static org.jboss.cdi.tck.cdi.Sections.DIRECT_AND_INDIRECT_SPECIALIZATION;
import static org.jboss.cdi.tck.cdi.Sections.SPECIALIZATION;
import static org.jboss.cdi.tck.cdi.Sections.SPECIALIZE_MANAGED_BEAN;
import static org.testng.Assert.assertEquals;
import static org.testng.Assert.assertTrue;
import java.lang.annotation.Annotation;
import java.lang.reflect.Type;
import java.util.Set;
import javax.enterprise.inject.Any;
import javax.enterprise.inject.Default;
import javax.enterprise.inject.UnsatisfiedResolutionException;
import javax.enterprise.inject.spi.Bean;
import javax.enterprise.util.AnnotationLiteral;
import javax.inject.Named;
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.cdi.tck.AbstractTest;
import org.jboss.cdi.tck.shrinkwrap.WebArchiveBuilder;
import org.jboss.shrinkwrap.api.spec.WebArchive;
import org.jboss.test.audit.annotations.SpecAssertion;
import org.jboss.test.audit.annotations.SpecAssertions;
import org.jboss.test.audit.annotations.SpecVersion;
import org.testng.annotations.Test;
@SpecVersion(spec = "cdi", version = "2.0-PFD")
public class SimpleBeanSpecializationTest extends AbstractTest {
@SuppressWarnings("serial")
private static Annotation LANDOWNER_LITERAL = new AnnotationLiteral<Landowner>() {
};
@SuppressWarnings("serial")
private static Annotation LAZY_LITERAL = new AnnotationLiteral<Lazy>() {
};
@Deployment
public static WebArchive createTestArchive() {
return new WebArchiveBuilder().withTestClassPackage(SimpleBeanSpecializationTest.class).build();
}
@Test
@SpecAssertions({ @SpecAssertion(section = DIRECT_AND_INDIRECT_SPECIALIZATION, id = "ia"), @SpecAssertion(section = DIRECT_AND_INDIRECT_SPECIALIZATION, id = "ib") })
public void testIndirectSpecialization() {
// LazyFarmer specializes directly Farmer and indirectly Human
Set<Bean<Human>> humanBeans = getBeans(Human.class);
assertEquals(humanBeans.size(), 1);
Set<Bean<Farmer>> farmerBeans = getBeans(Farmer.class, LANDOWNER_LITERAL);
assertEquals(farmerBeans.size(), 1);
Bean<Farmer> lazyFarmerBean = farmerBeans.iterator().next();
assertEquals(lazyFarmerBean.getBeanClass(), humanBeans.iterator().next().getBeanClass());
// Types of specializing bean
Set<Type> lazyFarmerBeanTypes = lazyFarmerBean.getTypes();
assertEquals(lazyFarmerBeanTypes.size(), 4);
assertTrue(typeSetMatches(lazyFarmerBeanTypes, Object.class, Human.class, Farmer.class, LazyFarmer.class));
}
@Test(dataProvider = ARQUILLIAN_DATA_PROVIDER)
@SpecAssertions({ @SpecAssertion(section = DIRECT_AND_INDIRECT_SPECIALIZATION, id = "ia") })
public void testSpecializingBeanInjection(Farmer farmer) {
assertEquals(farmer.getClassName(), LazyFarmer.class.getName());
}
@SuppressWarnings("unchecked")
@Test
@SpecAssertions({ @SpecAssertion(section = DIRECT_AND_INDIRECT_SPECIALIZATION, id = "j"), @SpecAssertion(section = SPECIALIZE_MANAGED_BEAN, id = "aa") })
public void testSpecializingBeanHasQualifiersOfSpecializedAndSpecializingBean() {
Bean<LazyFarmer> lazyFarmerBean = getBeans(LazyFarmer.class, LAZY_LITERAL).iterator().next();
Set<Annotation> lazyFarmerBeanQualifiers = lazyFarmerBean.getQualifiers();
assertEquals(lazyFarmerBeanQualifiers.size(), 5);
// LazyFarmer inherits Default from Human; LandOwner and Named from Farmer
assertTrue(annotationSetMatches(lazyFarmerBean.getQualifiers(), Landowner.class, Lazy.class, Any.class, Named.class,
Default.class));
}
@Test
@SpecAssertions({ @SpecAssertion(section = DIRECT_AND_INDIRECT_SPECIALIZATION, id = "k"), @SpecAssertion(section = SPECIALIZE_MANAGED_BEAN, id = "ab") })
public void testSpecializingBeanHasNameOfSpecializedBean() {
String expectedName = "farmer";
Set<Bean<?>> beans = getCurrentManager().getBeans(expectedName);
assertEquals(beans.size(), 1);
Bean<?> farmerBean = beans.iterator().next();
assertEquals(farmerBean.getName(), expectedName);
assertEquals(farmerBean.getBeanClass(), LazyFarmer.class);
}
@Test(expectedExceptions = UnsatisfiedResolutionException.class)
@SpecAssertions({ @SpecAssertion(section = SPECIALIZATION, id = "cb") })
public void testProducerMethodOnSpecializedBeanNotCalled() {
assertEquals(getBeans(Waste.class).size(), 0);
// Throw UnsatisfiedResolutionException
getContextualReference(Waste.class);
}
}