/* * Licensed to the Apache Software Foundation (ASF) under one or more contributor license * agreements. See the NOTICE file distributed with this work for additional information regarding * copyright ownership. The ASF licenses this file to You 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.apache.geode.management.internal.cli.commands; import org.apache.geode.cache.*; import org.apache.geode.distributed.ConfigurationProperties; import org.apache.geode.management.cli.Result; import org.apache.geode.management.internal.cli.i18n.CliStrings; import org.apache.geode.test.dunit.SerializableRunnable; import org.apache.geode.test.dunit.SerializableRunnableIF; import org.apache.geode.test.dunit.VM; import org.apache.geode.test.junit.categories.DistributedTest; import org.junit.Test; import org.junit.experimental.categories.Category; import java.io.Serializable; import java.util.Properties; import static org.apache.geode.test.dunit.Assert.assertEquals; import static org.apache.geode.test.dunit.Assert.assertNotNull; import static org.apache.geode.test.dunit.Host.getHost; import static org.apache.geode.test.dunit.LogWriterUtils.getDUnitLogLevel; import static org.apache.geode.test.dunit.LogWriterUtils.getLogWriter; import static org.apache.geode.distributed.ConfigurationProperties.*; /** * The ListAndDescribeDiskStoreCommandsDUnitTest class is a test suite of functional tests cases * testing the proper functioning of the 'list disk-store' and 'describe disk-store' commands. * </p> * * @see org.apache.geode.management.internal.cli.commands.CliCommandTestBase * @see org.apache.geode.management.internal.cli.commands.DiskStoreCommands * @since GemFire 7.0 */ @Category(DistributedTest.class) public class ListAndDescribeDiskStoreCommandsDUnitTest extends CliCommandTestBase { @Override public final void postSetUpCliCommandTestBase() throws Exception { setUpJmxManagerOnVm0ThenConnect(null); setupGemFire(); } @Test public void testListDiskStore() throws Exception { final Result result = executeCommand(CliStrings.LIST_DISK_STORE); assertNotNull(result); getLogWriter().info(toString(result)); assertEquals(Result.Status.OK, result.getStatus()); } @Test public void testDescribeDiskStore() throws Exception { final Result result = executeCommand( CliStrings.DESCRIBE_DISK_STORE + " --member=producerServer --name=producerData"); assertNotNull(result); getLogWriter().info(toString(result)); assertEquals(Result.Status.OK, result.getStatus()); } @Test public void testDescribeDiskStoreWithInvalidMemberName() throws Exception { final Result commandResult = executeCommand( CliStrings.DESCRIBE_DISK_STORE + " --member=badMemberName --name=producerData"); assertNotNull(commandResult); assertEquals(Result.Status.ERROR, commandResult.getStatus()); assertEquals(CliStrings.format(CliStrings.MEMBER_NOT_FOUND_ERROR_MESSAGE, "badMemberName"), toString(commandResult)); } @Test public void testDescribeDiskStoreWithInvalidDiskStoreName() { final Result commandResult = executeCommand( CliStrings.DESCRIBE_DISK_STORE + " --member=producerServer --name=badDiskStoreName"); assertNotNull(commandResult); assertEquals(Result.Status.ERROR, commandResult.getStatus()); assertEquals( "A disk store with name (badDiskStoreName) was not found on member (producerServer).", toString(commandResult)); } private static String toString(final Result result) { assert result != null : "The Result object from the command execution cannot be null!"; final StringBuilder buffer = new StringBuilder(System.getProperty("line.separator")); while (result.hasNextLine()) { buffer.append(result.nextLine()); buffer.append(System.getProperty("line.separator")); } return buffer.toString().trim(); } private Peer createPeer(final Properties distributedSystemConfiguration, final VM vm) { return new Peer(distributedSystemConfiguration, vm); } private void setupGemFire() throws Exception { final VM vm1 = getHost(0).getVM(1); final VM vm2 = getHost(0).getVM(2); final Peer peer1 = createPeer(createDistributedSystemProperties("consumerServer"), vm1); final Peer peer2 = createPeer(createDistributedSystemProperties("producerServer"), vm2); createPersistentRegion(peer1, "consumers", "consumerData"); createPersistentRegion(peer1, "observers", "observerData"); createPersistentRegion(peer2, "producer", "producerData"); createPersistentRegion(peer2, "producer-factory", "producerData"); } private Properties createDistributedSystemProperties(final String gemfireName) { final Properties distributedSystemProperties = new Properties(); distributedSystemProperties.setProperty(ConfigurationProperties.LOG_LEVEL, getDUnitLogLevel()); distributedSystemProperties.setProperty(NAME, gemfireName); return distributedSystemProperties; } private void createPersistentRegion(final Peer peer, final String regionName, final String diskStoreName) throws Exception { peer.run(new SerializableRunnable("Creating Persistent Region for Member " + peer.getName()) { @Override public void run() { getSystem(peer.getDistributedSystemConfiguration()); final Cache cache = getCache(); DiskStore diskStore = cache.findDiskStore(diskStoreName); if (diskStore == null) { final DiskStoreFactory diskStoreFactory = cache.createDiskStoreFactory(); diskStoreFactory.setDiskDirs(getDiskDirs()); diskStore = diskStoreFactory.create(diskStoreName); } final RegionFactory regionFactory = cache.createRegionFactory(); regionFactory.setDataPolicy(DataPolicy.PERSISTENT_REPLICATE); regionFactory.setDiskStoreName(diskStore.getName()); regionFactory.setScope(Scope.DISTRIBUTED_NO_ACK); regionFactory.create(regionName); } }); } private static class Peer implements Serializable { private final Properties distributedSystemConfiguration; private final VM vm; protected Peer(final Properties distributedSystemConfiguration, final VM vm) { assert distributedSystemConfiguration != null : "The GemFire distributed system configuration properties cannot be null!"; this.distributedSystemConfiguration = distributedSystemConfiguration; this.vm = vm; } public Properties getDistributedSystemConfiguration() { return distributedSystemConfiguration; } public String getName() { return getDistributedSystemConfiguration().getProperty(NAME); } public VM getVm() { return vm; } public void run(final SerializableRunnableIF runnable) throws Exception { if (getVm() == null) { runnable.run(); } else { getVm().invoke(runnable); } } } }