/* * JBoss, Home of Professional Open Source. * Copyright 2014, 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.domain.autoignore; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.BLOCKING; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.CHILD_TYPE; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.COMPOSITE; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.DOMAIN_CONTROLLER; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.EXTENSION; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.GROUP; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.HOST; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.HOST_STATE; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.IGNORE_UNUSED_CONFIG; 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.PROFILE; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.READ_CHILDREN_NAMES_OPERATION; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.RELOAD_REQUIRED; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.REMOTE; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.RESTART; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.SERVER; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.SERVER_CONFIG; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.SERVER_GROUP; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.SOCKET_BINDING_GROUP; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.STEPS; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.SYSTEM_PROPERTY; import static org.jboss.as.controller.descriptions.ModelDescriptionConstants.VALUE; import static org.jboss.as.test.integration.domain.management.util.DomainTestSupport.validateFailedResponse; import static org.jboss.as.test.integration.domain.management.util.DomainTestSupport.validateResponse; import java.io.File; import java.io.InputStream; import java.util.Arrays; import java.util.HashSet; import java.util.List; import org.jboss.as.controller.PathAddress; import org.jboss.as.controller.PathElement; import org.jboss.as.controller.client.helpers.Operations; import org.jboss.as.controller.client.helpers.domain.DomainClient; import org.jboss.as.controller.operations.common.Util; import org.jboss.as.test.integration.domain.management.util.DomainLifecycleUtil; import org.jboss.as.test.integration.domain.management.util.DomainTestSupport; import org.jboss.as.test.shared.TimeoutUtil; 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; import org.junit.AfterClass; import org.junit.Assert; import org.junit.Before; import org.junit.BeforeClass; import org.junit.FixMethodOrder; import org.junit.Test; import org.junit.runners.MethodSorters; /** * Tests ignore-unused-configuration=true. * * @author <a href="kabir.khan@jboss.com">Kabir Khan</a> */ @FixMethodOrder(MethodSorters.NAME_ASCENDING) public class AutoIgnoredResourcesDomainTestCase { private static DomainTestSupport testSupport; private static DomainLifecycleUtil domainMasterLifecycleUtil; private static DomainLifecycleUtil domainSlaveLifecycleUtil; private static final ModelNode ROOT_ADDRESS = new ModelNode().setEmptyList(); private static final ModelNode MASTER_ROOT_ADDRESS = new ModelNode().add(HOST, "master"); private static final ModelNode SLAVE_ROOT_ADDRESS = new ModelNode().add(HOST, "slave"); static { ROOT_ADDRESS.protect(); MASTER_ROOT_ADDRESS.protect(); SLAVE_ROOT_ADDRESS.protect(); } private static final String EXTENSION_JMX = "org.jboss.as.jmx"; private static final String EXTENSION_LOGGING = "org.jboss.as.logging"; private static final String EXTENSION_REMOTING = "org.jboss.as.remoting"; private static final String EXTENSION_IO = "org.wildfly.extension.io"; private static final String EXTENSION_RC = "org.wildfly.extension.request-controller"; private static final String ROOT_PROFILE1 = "root-profile1"; private static final String ROOT_PROFILE2 = "root-profile2"; private static final String PROFILE1 = "profile1"; private static final String PROFILE2 = "profile2"; private static final String PROFILE3 = "profile3"; private static final String ROOT_SOCKETS1 = "root-sockets1"; private static final String ROOT_SOCKETS2 = "root-sockets2"; private static final String SOCKETS1 = "sockets1"; private static final String SOCKETS2 = "sockets2"; private static final String SOCKETS3 = "sockets3"; private static final String SOCKETSA = "socketsA"; private static final String GROUP1 = "group1"; private static final String GROUP2 = "group2"; private static final String SERVER1 = "server1"; @BeforeClass public static void setupDomain() throws Exception { setupDomain(false); } public static void setupDomain(boolean slaveIsBackupDC) throws Exception { //Make all the configs read-only so we can stop and start when we like to reset DomainTestSupport.Configuration config = DomainTestSupport.Configuration.create(AutoIgnoredResourcesDomainTestCase.class.getSimpleName(), "domain-configs/domain-auto-ignore.xml", "host-configs/host-auto-ignore-master.xml", "host-configs/host-auto-ignore-slave.xml", true, true, true); if (slaveIsBackupDC) config.getSlaveConfiguration().setBackupDC(true); testSupport = DomainTestSupport.create(config); // Start! testSupport.start(); domainMasterLifecycleUtil = testSupport.getDomainMasterLifecycleUtil(); domainSlaveLifecycleUtil = testSupport.getDomainSlaveLifecycleUtil(); } @AfterClass public static void tearDownDomain() throws Exception { testSupport.stop(); domainMasterLifecycleUtil = null; domainSlaveLifecycleUtil = null; testSupport = null; } private DomainClient masterClient; private DomainClient slaveClient; @Before public void setup() throws Exception { masterClient = domainMasterLifecycleUtil.getDomainClient(); slaveClient = domainSlaveLifecycleUtil.getDomainClient(); } ///////////////////////////////////////////////////////////////// // These tests check that a simple operation on the slave server // config pulls down the missing data from the DC @Test public void test00_CheckInitialBootExclusions() throws Exception { checkSlaveProfiles(PROFILE1, ROOT_PROFILE1); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP1); checkSlaveSocketBindingGroups(SOCKETS1, ROOT_SOCKETS1); checkSystemProperties(0); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } @Test public void test01_ChangeSlaveServerConfigSocketBindingGroupOverridePullsDownDataFromDc() throws Exception { validateResponse(slaveClient.execute(Util.getWriteAttributeOperation(getSlaveServerConfigAddress(SERVER1), SOCKET_BINDING_GROUP, SOCKETSA)), false); checkSlaveProfiles(PROFILE1, ROOT_PROFILE1); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP1); checkSlaveSocketBindingGroups(SOCKETS1, ROOT_SOCKETS1, SOCKETSA); checkSystemProperties(0); Assert.assertEquals(RELOAD_REQUIRED, getSlaveServerStatus(SERVER1)); restartSlaveServer(SERVER1); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } @Test public void test02_ChangeSlaveServerConfigGroupPullsDownDataFromDc() throws Exception { validateResponse(slaveClient.execute(Util.getWriteAttributeOperation(getSlaveServerConfigAddress(SERVER1), GROUP, GROUP2)), false); checkSlaveProfiles(PROFILE2, ROOT_PROFILE2); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP2); checkSlaveSocketBindingGroups(SOCKETSA, SOCKETS2, ROOT_SOCKETS2); checkSystemProperties(0); Assert.assertEquals(RELOAD_REQUIRED, getSlaveServerStatus(SERVER1)); restartSlaveServer(SERVER1); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } @Test public void test03_AddServerGroupAndServerConfigPullsDownDataFromDc() throws Exception { ModelNode addGroupOp = Util.createAddOperation(PathAddress.pathAddress(PathElement.pathElement(SERVER_GROUP, "testgroup"))); addGroupOp.get(PROFILE).set(PROFILE3); addGroupOp.get(SOCKET_BINDING_GROUP).set(SOCKETS3); validateResponse(masterClient.execute(addGroupOp), false); //New data should not be pushed yet since nothing on the slave uses it checkSlaveProfiles(PROFILE2, ROOT_PROFILE2); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP2); checkSlaveSocketBindingGroups(SOCKETSA, SOCKETS2, ROOT_SOCKETS2); checkSystemProperties(0); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); ModelNode addConfigOp = Util.createAddOperation(PathAddress.pathAddress(getSlaveServerConfigAddress("testserver"))); addConfigOp.get(GROUP).set("testgroup"); validateResponse(slaveClient.execute(addConfigOp), false); //Now that we have a group using the new data it should be pulled down checkSlaveProfiles(PROFILE2, PROFILE3, ROOT_PROFILE2); checkSlaveExtensions(EXTENSION_LOGGING, EXTENSION_JMX); checkSlaveServerGroups(GROUP2, "testgroup"); checkSlaveSocketBindingGroups(SOCKETSA, SOCKETS2, SOCKETS3, ROOT_SOCKETS2); checkSystemProperties(0); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } @Test public void test04_RestartDomainAndReloadReadOnlyConfig() throws Exception { //Clean up after ourselves for the next round of tests ///////////// restartDomainAndReloadReadOnlyConfig(); } ///////////////////////////////////////////////////////////////// // These tests use a composite to obtain the DC lock, and check // that an operation on the slave server config pulls down the // missing data from the DC @Test public void test10_ChangeSlaveServerConfigSocketBindingGroupOverridePullsDownDataFromDcWithDcLockTaken() throws Exception { validateResponse(slaveClient.execute(createDcLockTakenComposite(Util.getWriteAttributeOperation(getSlaveServerConfigAddress(SERVER1), SOCKET_BINDING_GROUP, SOCKETSA))), false); checkSlaveProfiles(PROFILE1, ROOT_PROFILE1); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP1); checkSlaveSocketBindingGroups(SOCKETS1, ROOT_SOCKETS1, SOCKETSA); checkSystemProperties(1); //Composite added a property Assert.assertEquals(RELOAD_REQUIRED, getSlaveServerStatus(SERVER1)); restartSlaveServer(SERVER1); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } @Test public void test11_ChangeSlaveServerConfigGroupPullsDownDataFromDcWithDcLockTaken() throws Exception { validateResponse(slaveClient.execute(createDcLockTakenComposite(Util.getWriteAttributeOperation(getSlaveServerConfigAddress(SERVER1), GROUP, GROUP2))), false); checkSlaveProfiles(PROFILE2, ROOT_PROFILE2); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP2); checkSlaveSocketBindingGroups(SOCKETSA, SOCKETS2, ROOT_SOCKETS2); checkSystemProperties(2); //Composite added a property Assert.assertEquals(RELOAD_REQUIRED, getSlaveServerStatus(SERVER1)); restartSlaveServer(SERVER1); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } @Test public void test12_AddServerGroupAndServerConfigPullsDownDataFromDcWithDcLockTaken() throws Exception { ModelNode addGroupOp = Util.createAddOperation(PathAddress.pathAddress(PathElement.pathElement(SERVER_GROUP, "testgroup"))); addGroupOp.get(PROFILE).set(PROFILE3); addGroupOp.get(SOCKET_BINDING_GROUP).set(SOCKETS3); validateResponse(masterClient.execute(createDcLockTakenComposite(addGroupOp)), false); //New data should not be pushed yet since nothing on the slave uses it checkSlaveProfiles(PROFILE2, ROOT_PROFILE2); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP2); checkSlaveSocketBindingGroups(SOCKETSA, SOCKETS2, ROOT_SOCKETS2); checkSystemProperties(3); //Composite added a property Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); ModelNode addConfigOp = Util.createAddOperation(PathAddress.pathAddress(getSlaveServerConfigAddress("testserver"))); addConfigOp.get(GROUP).set("testgroup"); validateResponse(slaveClient.execute(createDcLockTakenComposite(addConfigOp)), false); //Now that we have a group using the new data it should be pulled down checkSlaveProfiles(PROFILE2, ROOT_PROFILE2, PROFILE3); checkSlaveExtensions(EXTENSION_LOGGING, EXTENSION_JMX); checkSlaveServerGroups(GROUP2, "testgroup"); checkSlaveSocketBindingGroups(SOCKETSA, SOCKETS2, SOCKETS3, ROOT_SOCKETS2); checkSystemProperties(4); //Composite added a property Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } @Test public void test13_RestartDomainAndReloadReadOnlyConfig() throws Exception { //Clean up after ourselves for the next round of tests ///////////// restartDomainAndReloadReadOnlyConfig(); } ///////////////////////////////////////////////////////////////// // These tests use a composite to obtain the DC lock, and check // that an operation on the slave server config pulls down the // missing data from the DC // The first time this is attempted the operation will roll back // The second time it should succeed @Test public void test20_ChangeSlaveServerConfigSocketBindingGroupOverridePullsDownDataFromDcWithDcLockTakenAndRollback() throws Exception { validateFailedResponse(slaveClient.execute(createDcLockTakenCompositeWithRollback(Util.getWriteAttributeOperation(getSlaveServerConfigAddress(SERVER1), SOCKET_BINDING_GROUP, SOCKETSA)))); checkSlaveProfiles(PROFILE1, ROOT_PROFILE1); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP1); checkSlaveSocketBindingGroups(SOCKETS1, ROOT_SOCKETS1); checkSystemProperties(0); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); validateResponse(slaveClient.execute(createDcLockTakenComposite(Util.getWriteAttributeOperation(getSlaveServerConfigAddress(SERVER1), SOCKET_BINDING_GROUP, SOCKETSA))), false); checkSlaveProfiles(PROFILE1, ROOT_PROFILE1); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP1); checkSlaveSocketBindingGroups(SOCKETS1, SOCKETSA, ROOT_SOCKETS1); checkSystemProperties(1); //Composite added a property Assert.assertEquals(RELOAD_REQUIRED, getSlaveServerStatus(SERVER1)); restartSlaveServer(SERVER1); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } @Test public void test21_ChangeSlaveServerConfigGroupPullsDownDataFromDcWithDcLockTakenAndRollback() throws Exception { validateFailedResponse(slaveClient.execute(createDcLockTakenCompositeWithRollback(Util.getWriteAttributeOperation(getSlaveServerConfigAddress(SERVER1), GROUP, GROUP2)))); checkSlaveProfiles(PROFILE1, ROOT_PROFILE1); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP1); checkSlaveSocketBindingGroups(SOCKETS1, SOCKETSA, ROOT_SOCKETS1); checkSystemProperties(1); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); validateResponse(slaveClient.execute(createDcLockTakenComposite(Util.getWriteAttributeOperation(getSlaveServerConfigAddress(SERVER1), GROUP, GROUP2))), false); checkSlaveProfiles(PROFILE2, ROOT_PROFILE2); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP2); checkSlaveSocketBindingGroups(SOCKETSA, SOCKETS2, ROOT_SOCKETS2); checkSystemProperties(2); //Composite added a property Assert.assertEquals(RELOAD_REQUIRED, getSlaveServerStatus(SERVER1)); restartSlaveServer(SERVER1); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } @Test public void test22_AddServerGroupAndServerConfigPullsDownDataFromDcWithDcLockTakenAndRollback() throws Exception { ModelNode addGroupOp = Util.createAddOperation(PathAddress.pathAddress(PathElement.pathElement(SERVER_GROUP, "testgroup"))); addGroupOp.get(PROFILE).set(PROFILE3); addGroupOp.get(SOCKET_BINDING_GROUP).set(SOCKETS3); validateResponse(masterClient.execute(createDcLockTakenComposite(addGroupOp)), false); //New data should not be pushed yet since nothing on the slave uses it checkSlaveProfiles(PROFILE2, ROOT_PROFILE2); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP2); checkSlaveSocketBindingGroups(SOCKETSA, SOCKETS2, ROOT_SOCKETS2); checkSystemProperties(3); //Composite added a property Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); ModelNode addConfigOp = Util.createAddOperation(PathAddress.pathAddress(getSlaveServerConfigAddress("testserver"))); addConfigOp.get(GROUP).set("testgroup"); validateFailedResponse(slaveClient.execute(createDcLockTakenCompositeWithRollback(addConfigOp))); checkSlaveProfiles(PROFILE2, ROOT_PROFILE2); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP2); checkSlaveSocketBindingGroups(SOCKETSA, SOCKETS2, ROOT_SOCKETS2); checkSystemProperties(3); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); //Now that we have a group using the new data it should be pulled down validateResponse(slaveClient.execute(createDcLockTakenComposite(addConfigOp)), false); checkSlaveProfiles(PROFILE2, ROOT_PROFILE2, PROFILE3); checkSlaveExtensions(EXTENSION_LOGGING, EXTENSION_JMX); checkSlaveServerGroups(GROUP2, "testgroup"); checkSlaveSocketBindingGroups(SOCKETSA, SOCKETS2, SOCKETS3, ROOT_SOCKETS2); checkSystemProperties(4); //Composite added a property Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } @Test public void test23_RestartDomainAndReloadReadOnlyConfig() throws Exception { //Clean up after ourselves for the next round of tests ///////////// restartDomainAndReloadReadOnlyConfig(); } ///////////////////////////////////////////////////////////////// // These tests test that changing a server group on the DC // piggybacks missing data to the slave @Test public void test30_ChangeServerGroupSocketBindingGroupGetsPushedToSlave() throws Exception { ModelNode op = Util.getWriteAttributeOperation(PathAddress.pathAddress(PathElement.pathElement(SERVER_GROUP, GROUP1)).toModelNode(), SOCKET_BINDING_GROUP, SOCKETS2); validateResponse(masterClient.execute(op)); checkSlaveProfiles(PROFILE1, ROOT_PROFILE1); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP1); checkSlaveSocketBindingGroups(SOCKETS2, ROOT_SOCKETS2); Assert.assertEquals(RELOAD_REQUIRED, getSlaveServerStatus(SERVER1)); restartSlaveServer(SERVER1); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } @Test public void test31_ChangeServerGroupProfileGetsPushedToSlave() throws Exception { ModelNode op = Util.getWriteAttributeOperation(PathAddress.pathAddress(PathElement.pathElement(SERVER_GROUP, GROUP1)).toModelNode(), PROFILE, PROFILE2); validateResponse(masterClient.execute(op)); checkSlaveProfiles(PROFILE2, ROOT_PROFILE2); checkSlaveExtensions(EXTENSION_LOGGING); checkSlaveServerGroups(GROUP1); checkSlaveSocketBindingGroups(SOCKETS2, ROOT_SOCKETS2); Assert.assertEquals(RELOAD_REQUIRED, getSlaveServerStatus(SERVER1)); restartSlaveServer(SERVER1); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } ///////////////////////////////////////////////////////////////// // Test deployments to a server group get picked up by a server // switching to it @Test public void test40_ChangeServerGroupProfileAndGetDeployment() throws Exception { JavaArchive deployment = ShrinkWrap.create(JavaArchive.class); deployment.addClasses(TestClass.class, TestClassMBean.class); File testMarker = new File("target" + File.separator + "testmarker"); if (testMarker.exists()) { testMarker.delete(); } String serviceXml = "<server xmlns=\"urn:jboss:service:7.0\"" + " xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"" + " xsi:schemaLocation=\"urn:jboss:service:7.0 jboss-service_7_0.xsd\">" + " <mbean name=\"jboss:name=test,type=testclassfilemarker\" code=\"org.jboss.as.test.integration.autoignore.TestClass\">" + " <attribute name=\"path\">" + testMarker.getAbsolutePath() + "</attribute>" + " </mbean>" + "</server>"; deployment.addAsManifestResource(new StringAsset(serviceXml), "jboss-service.xml"); InputStream in = deployment.as(ZipExporter.class).exportAsInputStream(); masterClient.getDeploymentManager().execute(masterClient.getDeploymentManager().newDeploymentPlan().add("sardeployment.sar", in).deploy("sardeployment.sar").toServerGroup(GROUP2).build()); ModelNode op = Util.getWriteAttributeOperation(PathAddress.pathAddress(PathElement.pathElement(SERVER_GROUP, GROUP2)).toModelNode(), PROFILE, PROFILE3); validateResponse(masterClient.execute(op)); op = Util.getWriteAttributeOperation(getSlaveServerConfigAddress(SERVER1), GROUP, GROUP2); validateResponse(slaveClient.execute(op)); checkSlaveProfiles(PROFILE3); checkSlaveExtensions(EXTENSION_LOGGING, EXTENSION_JMX); checkSlaveServerGroups(GROUP2); checkSlaveSocketBindingGroups(SOCKETS2, ROOT_SOCKETS2); Assert.assertEquals(RELOAD_REQUIRED, getSlaveServerStatus(SERVER1)); Assert.assertFalse(testMarker.exists()); restartSlaveServer(SERVER1); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); //The mbean should have created this file // Assert.assertTrue(testMarker.exists()); } @Test public void test50_RestartDomainAndReloadReadOnlyConfig() throws Exception { //Clean up after ourselves for the next round of tests ///////////// restartDomainAndReloadReadOnlyConfig(); } @Test public void test51_testCompositeOperation() throws Exception { final ModelNode composite = new ModelNode(); composite.get(OP).set(COMPOSITE); composite.get(OP_ADDR).setEmptyList(); final ModelNode steps = composite.get(STEPS); ModelNode addGroupOp = Util.createAddOperation(PathAddress.pathAddress(PathElement.pathElement(SERVER_GROUP, "testgroup"))); addGroupOp.get(PROFILE).set(PROFILE3); addGroupOp.get(SOCKET_BINDING_GROUP).set(SOCKETS3); steps.add(addGroupOp); steps.add(Util.getWriteAttributeOperation(getSlaveServerConfigAddress(SERVER1), SOCKET_BINDING_GROUP, SOCKETS3)); steps.add(Util.getWriteAttributeOperation(getSlaveServerConfigAddress(SERVER1), GROUP, GROUP2)); steps.add(Util.getWriteAttributeOperation(getSlaveServerConfigAddress(SERVER1), GROUP, "testgroup")); validateResponse(masterClient.execute(composite)); checkSlaveProfiles(PROFILE3); checkSlaveExtensions(EXTENSION_LOGGING, EXTENSION_JMX); checkSlaveServerGroups("testgroup"); checkSlaveSocketBindingGroups(SOCKETS3); } ///////////////////////////////////////////////////////////////// // These tests check how ignoring unused resources works in conjunction with --backup when // ignore-unused-configuration is undefined/true/false @Test public void test60_RestartDomainAndReloadReadOnlyConfig() throws Exception { //Clean up after ourselves for the next round of tests ///////////// restartDomainAndReloadReadOnlyConfig(); } ///////////////////////////////////////////////////////////////// // ignore-unused-configuration is undefined and --backup not set // the behavior is as if the ignore-unused-configuration attribute had a value of 'true' @Test public void test61_IgnoreUnusedConfigurationAttrUndefined() throws Exception { undefineIgnoreUnsusedConfiguration(); test00_CheckInitialBootExclusions(); } @Test public void test62_RestartDomainAndReloadReadOnlyConfig() throws Exception { //Clean up after ourselves for the next round of tests ///////////// // start with --backup restartDomainAndReloadReadOnlyConfig(true); } ///////////////////////////////////////////////////////////////// // ignore-unused-configuration=true and --backup set // the behavior is as if the ignore-unused-configuration attribute had a value of 'true' @Test public void test63_IgnoreUnusedConfigurationAttrTrueBackup() throws Exception { test00_CheckInitialBootExclusions(); } ///////////////////////////////////////////////////////////////// // ignore-unused-configuration is undefined and --backup set // the behavior is as if the ignore-unused-configuration attribute had a value of 'false' @Test public void test64_IgnoreUnusedConfigurationAttrUndefinedBackup() throws Exception { undefineIgnoreUnsusedConfiguration(); checkFullConfiguration(); } ///////////////////////////////////////////////////////////////// // ignore-unused-configuration=false and --backup set @Test public void test65_IgnoreUnusedConfigurationAttrFalseBackup() throws Exception { setIgnoreUnusedConfiguration(false); checkFullConfiguration(); } @Test public void test66_RestartDomainAndReloadReadOnlyConfig() throws Exception { //Clean up after ourselves for the next round of tests ///////////// restartDomainAndReloadReadOnlyConfig(); } ///////////////////////////////////////////////////////////////// // ignore-unused-configuration=false and --backup not set @Test public void test67_IgnoreUnusedConfigurationAttrFalse() throws Exception { setIgnoreUnusedConfiguration(false); checkFullConfiguration(); } ///////////////////////////////////////////////////////////////// // Private stuff private void checkFullConfiguration() throws Exception { checkSlaveProfiles(ROOT_PROFILE1, ROOT_PROFILE2, PROFILE1, PROFILE2, PROFILE3); checkSlaveExtensions(EXTENSION_JMX, EXTENSION_LOGGING, EXTENSION_REMOTING, EXTENSION_IO, EXTENSION_RC); checkSlaveServerGroups(GROUP1, GROUP2); checkSlaveSocketBindingGroups(ROOT_SOCKETS1, ROOT_SOCKETS2, SOCKETS1, SOCKETS2, SOCKETS3, SOCKETSA); checkSystemProperties(0); Assert.assertEquals("running", getSlaveServerStatus(SERVER1)); } private ModelNode createDcLockTakenComposite(ModelNode op) { ModelNode composite = new ModelNode(); composite.get(OP).set(COMPOSITE); composite.get(OP_ADDR).setEmptyList(); ModelNode addProperty = Util.createAddOperation(PathAddress.pathAddress(PathElement.pathElement(SYSTEM_PROPERTY, String.valueOf(System.currentTimeMillis())))); addProperty.get(VALUE).set("xxx"); composite.get(STEPS).add(addProperty); composite.get(STEPS).add(op); return composite; } private ModelNode createDcLockTakenCompositeWithRollback(ModelNode op) { ModelNode composite = createDcLockTakenComposite(op); ModelNode rollback = Util.getWriteAttributeOperation(SLAVE_ROOT_ADDRESS.clone().add(SYSTEM_PROPERTY, "rollback-does-not-exist" + String.valueOf(System.currentTimeMillis())), VALUE, "xxx"); composite.get(STEPS).add(rollback); return composite; } private void checkSystemProperties(int size) throws Exception { Assert.assertEquals(size, getChildrenOfTypeOnSlave(SYSTEM_PROPERTY).asList().size()); } private void checkSlaveProfiles(String... profiles) throws Exception { checkEqualContents(getChildrenOfTypeOnSlave(PROFILE).asList(), profiles); } private void checkSlaveExtensions(String... extensions) throws Exception { if (true) { return; // Automatically ignoring extensions is disabled atm } checkEqualContents(getChildrenOfTypeOnSlave(EXTENSION).asList(), extensions); } private void checkSlaveServerGroups(String... groups) throws Exception { checkEqualContents(getChildrenOfTypeOnSlave(SERVER_GROUP).asList(), groups); } private void checkSlaveSocketBindingGroups(String... groups) throws Exception { checkEqualContents(getChildrenOfTypeOnSlave(SOCKET_BINDING_GROUP).asList(), groups); } private void undefineIgnoreUnsusedConfiguration() throws Exception { // undefine ignore-unused-configuration ModelNode slaveModel = validateResponse(masterClient.execute(Operations.createReadAttributeOperation(SLAVE_ROOT_ADDRESS, DOMAIN_CONTROLLER)), true); slaveModel.get(REMOTE).remove(IGNORE_UNUSED_CONFIG); ModelNode op = Operations.createWriteAttributeOperation(SLAVE_ROOT_ADDRESS, DOMAIN_CONTROLLER, slaveModel); validateResponse(masterClient.execute(op)); // reload slave Assert.assertEquals(RELOAD_REQUIRED, getSlaveHostStatus()); reloadSlaveHost(); // verify that ignore-unused-configuration is undefined op = Operations.createReadAttributeOperation(SLAVE_ROOT_ADDRESS, DOMAIN_CONTROLLER); Assert.assertFalse(validateResponse(masterClient.execute(op), true).get(REMOTE).hasDefined(IGNORE_UNUSED_CONFIG)); } private void setIgnoreUnusedConfiguration(boolean ignoreUnusedConfiguration) throws Exception { ModelNode slaveModel = validateResponse(masterClient.execute(Operations.createReadAttributeOperation(SLAVE_ROOT_ADDRESS, DOMAIN_CONTROLLER)), true); slaveModel.get(REMOTE).get(IGNORE_UNUSED_CONFIG).set(ignoreUnusedConfiguration); ModelNode op = Operations.createWriteAttributeOperation(SLAVE_ROOT_ADDRESS, DOMAIN_CONTROLLER, slaveModel); validateResponse(masterClient.execute(op)); // reload slave Assert.assertEquals(RELOAD_REQUIRED, getSlaveHostStatus()); reloadSlaveHost(); // verify value of ignore-unused-configuration op = Operations.createReadAttributeOperation(SLAVE_ROOT_ADDRESS, DOMAIN_CONTROLLER); Assert.assertEquals(ignoreUnusedConfiguration, validateResponse(masterClient.execute(op), true).get(REMOTE).get(IGNORE_UNUSED_CONFIG).asBoolean()); } private ModelNode getChildrenOfTypeOnSlave(String type) throws Exception { ModelNode op = Util.createOperation(READ_CHILDREN_NAMES_OPERATION, PathAddress.EMPTY_ADDRESS); op.get(CHILD_TYPE).set(type); ModelNode result = slaveClient.execute(op); return validateResponse(result); } private String getSlaveServerStatus(String serverName) throws Exception { ModelNode op = Util.getReadAttributeOperation(PathAddress.pathAddress(getSlaveRunningServerAddress(serverName)), "server-state"); ModelNode result = slaveClient.execute(op); return validateResponse(result).asString(); } private ModelNode getSlaveServerConfigAddress(String serverName) { return SLAVE_ROOT_ADDRESS.clone().add(SERVER_CONFIG, serverName); } private ModelNode getSlaveRunningServerAddress(String serverName) { return SLAVE_ROOT_ADDRESS.clone().add(SERVER, serverName); } private void checkEqualContents(List<ModelNode> values, String... expected) { HashSet<String> actualSet = new HashSet<String>(); for (ModelNode value : values) { actualSet.add(value.asString()); } HashSet<String> expectedSet = new HashSet<String>(Arrays.asList(expected)); Assert.assertEquals("Expected " + expectedSet + "; was " + actualSet, expectedSet, actualSet); } private void restartSlaveServer(String serverName) throws Exception { ModelNode op = Util.createOperation(RESTART, PathAddress.pathAddress(getSlaveServerConfigAddress(serverName))); op.get(BLOCKING).set(true); Assert.assertEquals("STARTED", validateResponse(slaveClient.execute(op), true).asString()); } private String getSlaveHostStatus() throws Exception { ModelNode op = Util.getReadAttributeOperation(PathAddress.pathAddress(SLAVE_ROOT_ADDRESS), HOST_STATE); ModelNode result = slaveClient.execute(op); return validateResponse(result).asString(); } private void reloadSlaveHost() throws Exception { domainSlaveLifecycleUtil.executeAwaitConnectionClosed(Operations.createOperation("reload", SLAVE_ROOT_ADDRESS)); domainSlaveLifecycleUtil.connect(); domainSlaveLifecycleUtil.awaitServers(System.currentTimeMillis()); } private void restartDomainAndReloadReadOnlyConfig() throws Exception { restartDomainAndReloadReadOnlyConfig(false); } private void restartDomainAndReloadReadOnlyConfig(boolean slaveIsBackupDC) throws Exception { DomainTestSupport.stopHosts(TimeoutUtil.adjust(30000), domainSlaveLifecycleUtil, domainMasterLifecycleUtil); testSupport.stop(); //Totally reinitialize the domain client setupDomain(slaveIsBackupDC); setup(); //Check we're back to where we were test00_CheckInitialBootExclusions(); } }