/*
* JBoss, Home of Professional Open Source
* Copyright 2017, 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.weld.environment.se.test.shutdown.hook;
import java.lang.reflect.UndeclaredThrowableException;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.jboss.arquillian.container.se.api.ClassPath;
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.container.test.api.RunAsClient;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.arquillian.junit.InSequence;
import org.jboss.arquillian.protocol.jmx.JMXMethodExecutor;
import org.jboss.shrinkwrap.api.Archive;
import org.jboss.shrinkwrap.api.BeanArchive;
import org.jboss.shrinkwrap.api.ShrinkWrap;
import org.jboss.weld.environment.se.Weld;
import org.junit.Test;
import org.junit.runner.RunWith;
/**
* This test, while it passes, logs a series of expected errors, as Observer calls System.exit(). In order to prevent this, we
* SUSPEND logging for a short period of time right after first method, then we re-enable it in the beginning of the third.
*
* @author <a href="mailto:manovotn@redhat.com">Matej Novotny</a>
*/
@RunWith(Arquillian.class)
public class ShutdownHookRegisteredBeforeInitEventTest extends AbstractShutdownHookTest {
private Level originalLogLevel;
@Deployment(managed = false, name = DEPLOYMENT_NAME)
public static Archive<?> createTestArchive() {
return ClassPath.builder().add(ShrinkWrap.create(BeanArchive.class).addClasses(AbstractShutdownHookTest.class,
ShutdownHookRegisteredBeforeInitEventTest.class, Foo.class, Observer.class)).build();
}
@RunAsClient
@InSequence(1)
@Test
public void deploy() throws Exception {
try {
super.deploy();
} finally {
// additionally, disable log for following test to prevent flooding it with expected errors
Logger logger = Logger.getLogger(JMXMethodExecutor.class.getName());
originalLogLevel = logger.getLevel();
logger.setLevel(Level.OFF);
}
}
@Override
@InSequence(2)
@Test(expected = UndeclaredThrowableException.class)
public void testFooPing() {
// Initialize weld, Foo bean is used in observer
new Weld().initialize();
}
@RunAsClient
@InSequence(3)
@Test
public void undeploy() throws Exception {
// set the logging level back to what we had before
Logger.getLogger(JMXMethodExecutor.class.getName()).setLevel(originalLogLevel);
super.undeploy();
}
}