/* * 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.event.observer.transactional.custom; import static org.jboss.cdi.tck.TestGroups.INTEGRATION; import static org.jboss.cdi.tck.TestGroups.PERSISTENCE; import static org.jboss.cdi.tck.cdi.Sections.OBSERVER_NOTIFICATION; import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertNotNull; import static org.testng.Assert.assertTrue; import javax.enterprise.event.TransactionPhase; 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; /** * @author Martin Kouba */ @SpecVersion(spec = "cdi", version = "2.0-PFD") public class CustomTransactionalObserverTest extends AbstractTest { @Deployment public static WebArchive createTestArchive() { return new WebArchiveBuilder().withTestClassPackage(CustomTransactionalObserverTest.class) .withExtension(ObserverExtension.class).withDefaultPersistenceXml().build(); } @Inject private GiraffeService giraffeService; @Inject private ObserverExtension extension; @Test(groups = { INTEGRATION, PERSISTENCE }) @SpecAssertions({ @SpecAssertion(section = OBSERVER_NOTIFICATION, id = "fa"), @SpecAssertion(section = OBSERVER_NOTIFICATION, id = "fb") }) public void testCustomTransactionalObserver() throws Exception { ActionSequence.reset(); // GiraffeObserver 2x, GiraffeCustomObserver 1x assertEquals(getCurrentManager().resolveObserverMethods(new Giraffe()).size(), 3); // Transactional invocation giraffeService.feed(); // Test ObserverMethod.notify() was called assertNotNull(extension.getAnyGiraffeObserver().getReceivedPayload()); assertEquals(Giraffe.class, extension.getAnyGiraffeObserver().getReceivedPayload().getEvent().getClass()); assertNotNull(extension.getAnyGiraffeObserver().getReceivedPayload().getMetadata()); // Test ObserverMethod.getTransactionPhase() was called assertTrue(extension.getAnyGiraffeObserver().isTransactionPhaseCalled()); // Test custom observer received notification during the after completion phase (after succesfull commit) // BEFORE_COMPLETION must be fired at the beginning of the commit (after checkpoint) // AFTER_SUCCESS and AFTER_COMPLETION must be fired after BEFORE_COMPLETION // AFTER_FAILURE is not fired ActionSequence.getSequence().beginsWith("checkpoint", TransactionPhase.BEFORE_COMPLETION.toString()); ActionSequence.getSequence().assertDataContainsAll(TransactionPhase.AFTER_SUCCESS.toString(), TransactionPhase.AFTER_COMPLETION.toString()); } }