/*
* JBoss, Home of Professional Open Source.
* Copyright (c) 2016, Red Hat, Inc., and individual contributors
* as indicated by the @author tags. See the copyright.txt file in the
* distribution for a full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.as.test.integration.jca.tracer;
import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.ADD;
import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.REMOVE;
import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.OP;
import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.OP_ADDR;
import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.SUBSYSTEM;
import java.io.File;
import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.FILE;
import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.LOGGER;
import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.FILE_HANDLER;
import org.jboss.as.arquillian.api.ServerSetupTask;
import org.jboss.as.arquillian.container.ManagementClient;
import org.jboss.as.test.integration.management.ManagementOperations;
import org.jboss.dmr.ModelNode;
/**
* Adding new log file handler wich is then bound to a logger with specific category.
*
* @author Ondra Chaloupka <ochaloup@redhat.com>
*/
public class LogHandlerCreationSetup implements ServerSetupTask {
public static String JCA_LOG_FILE_PARAM = "jca-server.log";
public static final String SERVER_LOG_DIR_PARAM = "jboss.server.log.dir";
public static String SERVER_LOG_DIR_VALUE;
private static final String HANDLER_NAME = "jca-log-handler";
private static final String LOGGER_CATEGORY_VALUE = "org.jboss.jca.core.tracer";
private static final ModelNode LOGGING_ADDRESS = new ModelNode()
.add(SUBSYSTEM, "logging");
private static final ModelNode FILE_HANDLER_ADDRESS = new ModelNode()
.set(LOGGING_ADDRESS)
.add(FILE_HANDLER, HANDLER_NAME);
private static final ModelNode LOGGER_ADDRESS = new ModelNode()
.set(LOGGING_ADDRESS)
.add(LOGGER, LOGGER_CATEGORY_VALUE);
static {
LOGGING_ADDRESS.protect();
FILE_HANDLER_ADDRESS.protect();
LOGGER_ADDRESS.protect();
}
@Override
public void setup(ManagementClient managementClient, String containerId) throws Exception {
// /subsystem=logging/file-handler=jca-log-handler:add(append=false, file={relative-to=jboss.server.log.dir, path=jca-server.log})
ModelNode fileHandler = new ModelNode();
fileHandler.get(OP).set(ADD);
fileHandler.get(OP_ADDR).set(FILE_HANDLER_ADDRESS);
ModelNode file = new ModelNode();
file.get("relative-to").set(SERVER_LOG_DIR_PARAM);
file.get("path").set(JCA_LOG_FILE_PARAM);
fileHandler.get(FILE).set(file);
fileHandler.get("append").set("false");
ManagementOperations.executeOperation(managementClient.getControllerClient(), fileHandler);
// /subsystem=logging/logger=org.jboss.jca.core.tracer:add(category=org.jboss.jca.core.tracer, level=TRACE, handlers=[jca-log-handler])
ModelNode logger = new ModelNode();
logger.get(OP).set(ADD);
logger.get(OP_ADDR).set(LOGGER_ADDRESS);
logger.get("category").set(LOGGER_CATEGORY_VALUE);
logger.get("level").set("TRACE");
ModelNode handlers = new ModelNode()
.add(HANDLER_NAME);
logger.get("handlers").set(handlers);
ManagementOperations.executeOperation(managementClient.getControllerClient(), logger);
ModelNode getLogDir = new ModelNode();
getLogDir.get(OP).set("resolve-expression");
getLogDir.get("expression").set("${" + SERVER_LOG_DIR_PARAM + "}");
SERVER_LOG_DIR_VALUE = ManagementOperations
.executeOperation(managementClient.getControllerClient(), getLogDir).asString();
}
@Override
public void tearDown(ManagementClient managementClient, String containerId) throws Exception {
ModelNode logger = new ModelNode();
logger.get(OP).set(REMOVE);
logger.get(OP_ADDR).set(LOGGER_ADDRESS);
ManagementOperations.executeOperation(managementClient.getControllerClient(), logger);
ModelNode fileHandler = new ModelNode();
fileHandler.get(OP).set(REMOVE);
fileHandler.get(OP_ADDR).set(FILE_HANDLER_ADDRESS);
ManagementOperations.executeOperation(managementClient.getControllerClient(), fileHandler);
new File(SERVER_LOG_DIR_VALUE, JCA_LOG_FILE_PARAM).delete();
}
}