/* * JBoss, Home of Professional Open Source * Copyright 2014, 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.context.enterprise.staticMethod; import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertTrue; import static org.testng.Assert.fail; import javax.annotation.security.DeclareRoles; import javax.ejb.EJBContext; import javax.ejb.Stateless; import javax.enterprise.event.Observes; import javax.enterprise.event.TransactionPhase; import javax.naming.InitialContext; import javax.transaction.TransactionSynchronizationRegistry; import org.jboss.cdi.tck.util.ActionSequence; @Stateless @DeclareRoles({ "student", "printer" }) public class FooObserver { private static TransactionSynchronizationRegistry tsr; private static EJBContext ejbContext; private static Toner toner; private static Printer printer; public static void observeInProgress(@Observes(during = TransactionPhase.IN_PROGRESS) Foo foo) throws Exception { // this observer method is called first -> it is sufficient to lookup the needed resources just once if (tsr == null) { init(); } assertEquals(tsr.getTransactionKey(), Printer.getKey(), "Non-transactional observer method was NOT called in the same transaction context as the invocation of Event.fire()"); assertClientSecurityContext(TransactionPhase.IN_PROGRESS); } private static void init() throws Exception { tsr = (TransactionSynchronizationRegistry) InitialContext.doLookup("java:comp/TransactionSynchronizationRegistry"); ejbContext = (EJBContext) InitialContext.doLookup("java:comp/EJBContext"); toner = (Toner) InitialContext.doLookup("java:comp/Toner"); printer = (Printer) InitialContext.doLookup("java:comp/Printer"); } public static void observeBeforeCompletion(@Observes(during = TransactionPhase.BEFORE_COMPLETION) Foo foo) throws Exception { assertEquals(tsr.getTransactionKey(), Printer.getKey(), "Before completion transactional observer method was NOT called within the context of the transaction that was about to complete."); assertClientSecurityContext(TransactionPhase.BEFORE_COMPLETION); } public static void observeAfterCompletion(@Observes(during = TransactionPhase.AFTER_COMPLETION) Foo foo) throws Exception { assertClientSecurityContext(TransactionPhase.AFTER_COMPLETION); } public static void observeAfterFailure(@Observes(during = TransactionPhase.AFTER_FAILURE) Foo foo) throws Exception { assertClientSecurityContext(TransactionPhase.AFTER_FAILURE); } public static void observeAfterSuccess(@Observes(during = TransactionPhase.AFTER_SUCCESS) Foo foo) throws Exception { assertClientSecurityContext(TransactionPhase.AFTER_SUCCESS); } private static void assertClientSecurityContext(TransactionPhase phase) { assertTrue(ejbContext.isCallerInRole("student")); assertTrue(!ejbContext.isCallerInRole("printer")); toner.spill(); try { printer.tryAccess(); fail("Transactional observer method was NOT called within the same client security context."); } catch (javax.ejb.EJBAccessException expected) { // OK } ActionSequence.addAction(phase.toString()); } }