/* * Copyright 2012 Nodeable Inc * * Licensed 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 com.streamreduce.storm.utils; import java.util.Collections; import com.google.common.collect.ImmutableMap; import org.junit.Assert; import org.junit.Test; /** * Class used to test that {@link MetricsUtils} works as expected. */ public class MetricsUtilsTest { @Test public void testCreateUniqueMetricName() throws Exception { String metricName = "TEST_METRIC_NAME"; // Test empty criteria Assert.assertEquals(metricName, MetricsUtils.createUniqueMetricName(metricName, null)); Assert.assertEquals(metricName, MetricsUtils.createUniqueMetricName(metricName, Collections.EMPTY_MAP)); // Test non-empty criteria Assert.assertEquals(metricName + "{age=31,name=Jeremy}", MetricsUtils.createUniqueMetricName(metricName, ImmutableMap.of( "age", "31", "name", "Jeremy" ))); // Test non-empty criteria with different order Assert.assertEquals(metricName + "{age=31,name=Jeremy}", MetricsUtils.createUniqueMetricName(metricName, ImmutableMap.of( "name", "Jeremy", "age", "31" ))); } }