/* * 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.internal.stats50; import org.apache.geode.StatisticDescriptor; import org.apache.geode.Statistics; import org.apache.geode.StatisticsType; import org.apache.geode.StatisticsTypeFactory; import org.apache.geode.distributed.DistributedSystem; import org.apache.geode.internal.statistics.StatisticsTypeFactoryImpl; import org.apache.geode.test.junit.categories.IntegrationTest; import org.junit.Test; import org.junit.experimental.categories.Category; import java.util.Properties; import java.util.concurrent.BrokenBarrierException; import java.util.concurrent.CyclicBarrier; import java.util.concurrent.atomic.AtomicReference; import static org.apache.geode.distributed.ConfigurationProperties.*; import static org.junit.Assert.assertEquals; /** * */ @Category(IntegrationTest.class) public class AtomicStatsJUnitTest { /** * Test for bug 41340. Do two gets at the same time of a dirty stat, and make sure we get the * correct value for the stat. * * @throws Throwable */ @Test public void testConcurrentGets() throws Throwable { Properties props = new Properties(); props.setProperty(MCAST_PORT, "0"); // props.setProperty("statistic-sample-rate", "60000"); props.setProperty(STATISTIC_SAMPLING_ENABLED, "false"); DistributedSystem ds = DistributedSystem.connect(props); String statName = "TestStats"; String statDescription = "Tests stats"; final String statDesc = "blah blah blah"; StatisticsTypeFactory f = StatisticsTypeFactoryImpl.singleton(); StatisticsType type = f.createType(statName, statDescription, new StatisticDescriptor[] { f.createIntGauge("stat", statDesc, "bottles of beer on the wall"),}); final int statId = type.nameToId("stat"); try { final AtomicReference<Statistics> statsRef = new AtomicReference<Statistics>(); final CyclicBarrier beforeIncrement = new CyclicBarrier(3); final CyclicBarrier afterIncrement = new CyclicBarrier(3); Thread thread1 = new Thread("thread1") { public void run() { try { while (true) { beforeIncrement.await(); statsRef.get().incInt(statId, 1); afterIncrement.await(); } } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (BrokenBarrierException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }; Thread thread3 = new Thread("thread1") { public void run() { try { while (true) { beforeIncrement.await(); afterIncrement.await(); statsRef.get().getInt(statId); } } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (BrokenBarrierException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }; thread1.start(); thread3.start(); for (int i = 0; i < 5000; i++) { Statistics stats = ds.createAtomicStatistics(type, "stats"); statsRef.set(stats); beforeIncrement.await(); afterIncrement.await(); assertEquals("On loop " + i, 1, stats.getInt(statId)); stats.close(); } } finally { ds.disconnect(); } } }