/*
* 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.deployment.initialization;
import static org.jboss.cdi.tck.cdi.Sections.INITIALIZATION;
import static org.testng.Assert.assertEquals;
import java.util.ArrayList;
import java.util.List;
import javax.enterprise.inject.spi.AfterBeanDiscovery;
import javax.enterprise.inject.spi.AfterDeploymentValidation;
import javax.enterprise.inject.spi.AfterTypeDiscovery;
import javax.enterprise.inject.spi.BeforeBeanDiscovery;
import javax.enterprise.inject.spi.ProcessAnnotatedType;
import javax.inject.Inject;
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.cdi.tck.AbstractTest;
import org.jboss.cdi.tck.shrinkwrap.WebArchiveBuilder;
import org.jboss.cdi.tck.util.ActionSequence;
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;
/**
* Test application initialization lifecycle.
*
* @author Martin Kouba
*/
@SpecVersion(spec = "cdi", version = "2.0-PFD")
public class ApplicationInitializationLifecycleTest extends AbstractTest {
@Deployment
public static WebArchive createTestArchive() {
return new WebArchiveBuilder().withTestClassPackage(ApplicationInitializationLifecycleTest.class)
.withExtension(LifecycleMonitoringExtension.class).build();
}
@Inject
Foo foo;
@Test
@SpecAssertions({ @SpecAssertion(section = INITIALIZATION, id = "b"), @SpecAssertion(section = INITIALIZATION, id = "c"),
@SpecAssertion(section = INITIALIZATION, id = "ja"), @SpecAssertion(section = INITIALIZATION, id = "f"),
@SpecAssertion(section = INITIALIZATION, id = "g"), @SpecAssertion(section = INITIALIZATION, id = "h"),
@SpecAssertion(section = INITIALIZATION, id = "i"), @SpecAssertion(section = INITIALIZATION, id = "j") })
public void testInitialization() {
foo.ping();
// Test lifecycle phases sequence
List<String> correctSequenceData = new ArrayList<String>();
// Extension registration
correctSequenceData.add(LifecycleMonitoringExtension.class.getName());
// BeforeBeanDiscovery
correctSequenceData.add(BeforeBeanDiscovery.class.getName());
// Bean discovery
correctSequenceData.add(ProcessAnnotatedType.class.getName());
// AfterTypeDiscovery
correctSequenceData.add(AfterTypeDiscovery.class.getName());
// AfterBeanDiscovery
correctSequenceData.add(AfterBeanDiscovery.class.getName());
// Validating bean dependencies and specialization - currently no portable way how to test
// AfterDeploymentValidation
correctSequenceData.add(AfterDeploymentValidation.class.getName());
// Processing requests
correctSequenceData.add(Foo.class.getName());
assertEquals(ActionSequence.getSequenceData(), correctSequenceData);
}
}