blob: c763b17b1af67217d9aee392e54836ffcccf2c5a [file] [log] [blame]
/*
* 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 static org.apache.geode.cache.Region.SEPARATOR;
import static org.apache.geode.test.awaitility.GeodeAwaitility.await;
import static org.assertj.core.api.Assertions.assertThat;
import java.io.File;
import javax.management.ObjectName;
import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.TemporaryFolder;
import org.apache.geode.cache.Cache;
import org.apache.geode.cache.RegionFactory;
import org.apache.geode.cache.RegionShortcut;
import org.apache.geode.distributed.DistributedMember;
import org.apache.geode.management.CacheServerMXBean;
import org.apache.geode.management.ManagementService;
import org.apache.geode.management.MemberMXBean;
import org.apache.geode.management.RegionMXBean;
import org.apache.geode.test.dunit.rules.ClusterStartupRule;
import org.apache.geode.test.dunit.rules.MemberVM;
import org.apache.geode.test.junit.rules.GfshCommandRule;
public class ShowMetricsDUnitTest {
private MemberVM locator, server;
@Rule
public ClusterStartupRule lsRule = new ClusterStartupRule();
@Rule
public GfshCommandRule gfsh = new GfshCommandRule();
@Rule
public TemporaryFolder tempFolder = new TemporaryFolder();
@Before
public void before() throws Exception {
locator = lsRule.startLocatorVM(0);
server = lsRule.startServerVM(1, locator.getPort());
int serverPort = server.getPort();
server.invoke(() -> {
Cache cache = ClusterStartupRule.getCache();
RegionFactory<Integer, Integer> dataRegionFactory =
cache.createRegionFactory(RegionShortcut.REPLICATE);
dataRegionFactory.create("REGION1");
DistributedMember member = cache.getDistributedSystem().getDistributedMember();
await().until(() -> isBeanReady(cache, 5, "", member, serverPort));
});
locator.invoke(() -> {
Cache cache = ClusterStartupRule.getCache();
// Wait for all of the relevant beans to be ready
await().until(() -> isBeanReady(cache, 1, "", null, 0));
await().until(() -> isBeanReady(cache, 2, "REGION1", null, 0));
DistributedMember member = cache.getDistributedSystem().getDistributedMember();
await().until(() -> isBeanReady(cache, 3, "", member, 0));
});
gfsh.connect(locator);
}
private static boolean isBeanReady(Cache cache, int beanType, String regionName,
DistributedMember distributedMember, int cacheServerPort) {
ManagementService mgmtService = ManagementService.getManagementService(cache);
Object bean = null;
switch (beanType) {
case 1:
bean = mgmtService.getDistributedSystemMXBean();
break;
case 2:
bean = mgmtService.getDistributedRegionMXBean(SEPARATOR + regionName);
break;
case 3:
ObjectName memberMBeanName = mgmtService.getMemberMBeanName(distributedMember);
bean = mgmtService.getMBeanInstance(memberMBeanName, MemberMXBean.class);
break;
case 4:
ObjectName regionMBeanName =
mgmtService.getRegionMBeanName(distributedMember, SEPARATOR + regionName);
bean = mgmtService.getMBeanInstance(regionMBeanName, RegionMXBean.class);
break;
case 5:
ObjectName csMxBeanName =
mgmtService.getCacheServerMBeanName(cacheServerPort, distributedMember);
bean = mgmtService.getMBeanInstance(csMxBeanName, CacheServerMXBean.class);
break;
}
return bean != null;
}
@Test
public void testShowMetricsDefault() throws Exception {
gfsh.executeAndAssertThat("show metrics").statusIsSuccess();
}
@Test
public void testShowMetricsRegion() throws Exception {
gfsh.executeAndAssertThat("show metrics --region=REGION1").statusIsSuccess();
assertThat(gfsh.getGfshOutput()).contains("Cluster-wide Region Metrics");
}
@Test
public void testShowMetricsMember() throws Exception {
gfsh.executeAndAssertThat(
"show metrics --member=" + server.getName() + " --port=" + server.getPort())
.statusIsSuccess().containsOutput("Member Metrics").containsOutput("cacheserver");
}
@Test
public void testShowMetricsMemberWithFileOutput() throws Exception {
File output = tempFolder.newFile("memberMetricReport.csv");
output.delete();
gfsh.executeAndAssertThat("show metrics --member=" + server.getName() + " --port="
+ server.getPort() + " --file=" + output.getAbsolutePath()).statusIsSuccess()
.containsOutput("Member Metrics").containsOutput("cacheserver")
.containsOutput("File saved to " + output.getAbsolutePath());
assertThat(output).exists();
}
@Test
public void testShowMetricsRegionFromMember() throws Exception {
gfsh.executeAndAssertThat("show metrics --member=" + server.getName() + " --region=REGION1")
.statusIsSuccess();
assertThat(gfsh.getGfshOutput())
.contains("Metrics for region:" + SEPARATOR + "REGION1 On Member server-1");
}
}