package biz.paluch.logging.gelf.wildfly;
import static org.assertj.core.api.AssertionsForInterfaceTypes.assertThat;
import java.io.File;
import org.apache.commons.io.FileUtils;
import org.apache.log4j.LogManager;
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.as.arquillian.api.ServerSetup;
import org.jboss.as.arquillian.api.ServerSetupTask;
import org.jboss.as.arquillian.container.ManagementClient;
import org.jboss.as.cli.CommandContext;
import org.jboss.as.cli.CommandContextFactory;
import org.jboss.shrinkwrap.api.Archive;
import org.jboss.shrinkwrap.api.ShrinkWrap;
import org.jboss.shrinkwrap.api.spec.WebArchive;
import org.jboss.shrinkwrap.resolver.api.maven.Maven;
import org.junit.Test;
import org.junit.runner.RunWith;
/**
* Test for the Formatter of the logstash-gelf module in WildFly.
*
* @author Mark Paluch
* @since 11.08.14 08:36
*/
@RunWith(Arquillian.class)
@ServerSetup({ WildFlyFormatterIntegrationTests.LoggerSetup.class })
public class WildFlyFormatterIntegrationTests {
static class LoggerSetup implements ServerSetupTask {
@Override
public void setup(ManagementClient managementClient, String containerId) throws Exception {
CommandContext commandContext = CommandContextFactory.getInstance().newCommandContext();
commandContext.bindClient(managementClient.getControllerClient());
commandContext
.handle("/subsystem=logging/custom-formatter=JsonFormatter/:add(module=biz.paluch.logging,class=biz.paluch.logging.gelf.wildfly.WildFlyJsonFormatter,properties={ \\\n"
+ "\t\t version=\"1.0\", \\\n" + "\t\t facility=\"java-test\", \\\n"
+ "\t\t extractStackTrace=true, \\\n" + "\t\t filterStackTrace=true, \\\n"
+ "\t\t mdcProfiling=true, \\\n"
+ "\t\t additionalFields=\"fieldName1=fieldValue1,fieldName2=fieldValue2\", \\\n"
+ "\t\t mdcFields=\"mdcField1,mdcField2\"})");
commandContext
.handle("/subsystem=logging/file-handler=JsonLog/:add(file={\"relative-to\"=>\"jboss.server.log.dir\" ,path=server.json}, \\\n"
+ " level=ALL,named-formatter=JsonFormatter)");
commandContext.handle(
"/subsystem=logging/root-logger=ROOT/:write-attribute(name=handlers,value=[\"FILE\",\"CONSOLE\",\"JsonLog\"])");
}
@Override
public void tearDown(ManagementClient managementClient, String containerId) throws Exception {
CommandContext commandContext = CommandContextFactory.getInstance().newCommandContext();
commandContext.bindClient(managementClient.getControllerClient());
commandContext
.handle("/subsystem=logging/root-logger=ROOT/:write-attribute(name=handlers,value=[\"FILE\",\"CONSOLE\"])");
commandContext.handle("/subsystem=logging/file-handler=JsonLog/:remove");
commandContext.handle("/subsystem=logging/custom-formatter=JsonFormatter/:remove");
}
}
@Deployment
public static Archive<?> createTestArchive() {
File[] files = Maven.resolver().loadPomFromFile("pom.xml")
.resolve("commons-io:commons-io:2.2", "org.assertj:assertj-core").withoutTransitivity().asFile();
return ShrinkWrap.create(WebArchive.class, "logstash-gelf.war").addAsLibraries(files);
}
@Test
public void testJsonLogging() throws Exception {
LogManager.getLogger(getClass()).info("some message");
File logDir = new File(System.getProperty("jboss.server.log.dir"));
File logFile = new File(logDir, "server.json");
assertThat(logFile.exists()).isTrue();
String fileContents = FileUtils.readFileToString(logFile);
assertThat(fileContents.contains("\"full_message\":\"some message\"")).isTrue();
}
}