/* * Copyright (C) 2015 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 library 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 library 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 library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, * MA 02110-1301 USA */ package org.jboss.as.test.manualmode.deployment; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.EXTENSION; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.FAILED; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.INCLUDE_RUNTIME; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.NAME; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.OUTCOME; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.READ_ATTRIBUTE_OPERATION; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.READ_RESOURCE_OPERATION; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.RECURSIVE; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.RESULT; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.SUBSYSTEM; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.SUCCESS; import static org.jboss.as.test.integration.management.util.ModelUtil.createOpNode; import static org.junit.Assert.assertEquals; import java.io.File; import java.io.IOException; import java.io.OutputStream; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.StandardOpenOption; import org.jboss.as.controller.PathAddress; import org.jboss.as.controller.PathElement; import org.jboss.as.controller.descriptions.ModelDescriptionConstants; import org.jboss.as.controller.operations.common.Util; import org.jboss.dmr.ModelNode; import org.jboss.shrinkwrap.api.ShrinkWrap; import org.jboss.shrinkwrap.api.asset.StringAsset; import org.jboss.shrinkwrap.api.exporter.ZipExporter; import org.jboss.shrinkwrap.api.spec.JavaArchive; /** * * @author <a href="mailto:ehugonne@redhat.com">Emmanuel Hugonnet</a> (c) 2015 Red Hat, inc. */ public abstract class AbstractDeploymentUnitTestCase { protected void addDeploymentScanner(int scanInterval) throws Exception { ModelNode addOp = Util.createAddOperation(PathAddress.pathAddress(PathElement.pathElement(EXTENSION, "org.jboss.as.deployment-scanner"))); ModelNode result = executeOperation(addOp); assertEquals("Unexpected outcome of adding the test deployment scanner extension: " + addOp, ModelDescriptionConstants.SUCCESS, result.get(OUTCOME).asString()); addOp = Util.createAddOperation(PathAddress.pathAddress(PathElement.pathElement(SUBSYSTEM, "deployment-scanner"))); result = executeOperation(addOp); assertEquals("Unexpected outcome of adding the test deployment scanner subsystem: " + addOp, ModelDescriptionConstants.SUCCESS, result.get(OUTCOME).asString()); // add deployment scanner final ModelNode op = getAddDeploymentScannerOp(scanInterval); result = executeOperation(op); assertEquals("Unexpected outcome of adding the test deployment scanner: " + op, ModelDescriptionConstants.SUCCESS, result.get(OUTCOME).asString()); } protected void removeDeploymentScanner() throws Exception { boolean ok = false; try { // remove deployment scanner final ModelNode op = getRemoveDeploymentScannerOp(); ModelNode result = executeOperation(op); assertEquals("Unexpected outcome of removing the test deployment scanner: " + op, ModelDescriptionConstants.SUCCESS, result.get("outcome").asString()); ok = true; } finally { try { boolean wasOK = ok; ok = false; ModelNode removeOp = Util.createRemoveOperation(PathAddress.pathAddress(PathElement.pathElement(SUBSYSTEM, "deployment-scanner"))); ModelNode result = executeOperation(removeOp); if (wasOK) { assertEquals("Unexpected outcome of removing the test deployment scanner subsystem: " + removeOp, ModelDescriptionConstants.SUCCESS, result.get("outcome").asString()); } // else don't override the previous assertion error in this finally block ok = wasOK; } finally { ModelNode removeOp = Util.createRemoveOperation(PathAddress.pathAddress(PathElement.pathElement(EXTENSION, "org.jboss.as.deployment-scanner"))); ModelNode result = executeOperation(removeOp); if (ok) { assertEquals("Unexpected outcome of removing the test deployment scanner extension: " + removeOp, ModelDescriptionConstants.SUCCESS, result.get("outcome").asString()); } // else don't override the previous assertion error in this finally block } } } protected abstract ModelNode executeOperation(ModelNode op) throws IOException; protected abstract File getDeployDir(); protected ModelNode getAddDeploymentScannerOp(int scanInterval) { final ModelNode op = Util.createAddOperation(getTestDeploymentScannerResourcePath()); op.get("scan-interval").set(scanInterval); op.get("path").set(getDeployDir().getAbsolutePath()); return op; } protected ModelNode getRemoveDeploymentScannerOp() { return createOpNode("subsystem=deployment-scanner/scanner=testScanner", "remove"); } protected PathAddress getTestDeploymentScannerResourcePath() { return PathAddress.pathAddress(PathElement.pathElement("subsystem", "deployment-scanner"), PathElement.pathElement("scanner", "testScanner")); } protected boolean exists(PathAddress address) throws IOException { final ModelNode operation = Util.createEmptyOperation(READ_RESOURCE_OPERATION, address); operation.get(INCLUDE_RUNTIME).set(true); operation.get(RECURSIVE).set(true); final ModelNode result = executeOperation(operation); return SUCCESS.equals(result.get(OUTCOME).asString()); } protected String deploymentState(final PathAddress address) throws IOException { final ModelNode operation = Util.createEmptyOperation(READ_ATTRIBUTE_OPERATION, address); operation.get(NAME).set("status"); final ModelNode result = executeOperation(operation); if (SUCCESS.equals(result.get(OUTCOME).asString())) { return result.get(RESULT).asString(); } return FAILED; } protected boolean isRunning() throws IOException { final ModelNode operation = Util.createEmptyOperation(READ_ATTRIBUTE_OPERATION, PathAddress.EMPTY_ADDRESS); operation.get(NAME).set("runtime-configuration-state"); final ModelNode result = executeOperation(operation); if (SUCCESS.equals(result.get(OUTCOME).asString())) { return "ok".equals(result.get(RESULT).asString()); } return false; } protected void createDeployment(final Path file, final String dependency) throws IOException { final JavaArchive archive = ShrinkWrap.create(JavaArchive.class); final String dependencies = "Dependencies: " + dependency; archive.add(new StringAsset(dependencies), "META-INF/MANIFEST.MF"); try (OutputStream out = Files.newOutputStream(file, StandardOpenOption.CREATE_NEW)) { archive.as(ZipExporter.class).exportTo(out); } } protected void createDeployment(final File file, final String dependency) throws IOException { final JavaArchive archive = ShrinkWrap.create(JavaArchive.class); final String dependencies = "Dependencies: " + dependency; archive.add(new StringAsset(dependencies), "META-INF/MANIFEST.MF"); archive.as(ZipExporter.class).exportTo(file); } }