stroom.util.TestRoundRobinSet.java Source code

Java tutorial

Introduction

Here is the source code for stroom.util.TestRoundRobinSet.java

Source

/*
 * Copyright 2016 Crown Copyright
 *
 * 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 stroom.util;

import java.util.Collection;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;

import org.apache.commons.lang.mutable.MutableLong;
import org.junit.Assert;
import org.junit.Test;
import org.junit.runner.RunWith;

import stroom.util.shared.SharedObject;
import stroom.util.test.StroomUnitTest;
import stroom.util.test.StroomJUnit4ClassRunner;
import stroom.util.thread.ThreadUtil;

/**
 * Tests that the round robin list works correctly.
 */
@RunWith(StroomJUnit4ClassRunner.class)
public class TestRoundRobinSet extends StroomUnitTest {
    private static final int N3 = 3;
    private static final int N4 = 4;

    static class RoundRobinSetTestObject implements SharedObject {
        private static final long serialVersionUID = -7648759863152854689L;
        int i;

        public RoundRobinSetTestObject(final int i) {
            this.i = i;
        }

        @Override
        public String toString() {
            return String.valueOf(i);
        }
    }

    /**
     * Tests that the round robin list works correctly.
     */
    @Test
    public void test() {
        final RoundRobinSet<RoundRobinSetTestObject> rrList = new RoundRobinSet<RoundRobinSetTestObject>();
        rrList.add(new RoundRobinSetTestObject(1));
        rrList.add(new RoundRobinSetTestObject(2));
        rrList.add(new RoundRobinSetTestObject(N3));
        rrList.add(new RoundRobinSetTestObject(N4));

        Assert.assertEquals("123", getString(rrList));
        Assert.assertEquals("234", getString(rrList));
        Assert.assertEquals("341", getString(rrList));
        Assert.assertEquals("412", getString(rrList));
        Assert.assertEquals("123", getString(rrList));
    }

    @Test
    public void testSync() throws InterruptedException {
        final RoundRobinSet<RoundRobinSetTestObject> rrList = new RoundRobinSet<RoundRobinSetTestObject>();
        rrList.add(new RoundRobinSetTestObject(1));
        rrList.add(new RoundRobinSetTestObject(2));
        rrList.add(new RoundRobinSetTestObject(N3));
        rrList.add(new RoundRobinSetTestObject(N4));

        final MutableLong failureCount = new MutableLong(0);

        final ExecutorService executorService = Executors.newCachedThreadPool();
        for (int i = 0; i < 10; i++) {
            executorService.execute(() -> {
                for (int j = 0; j < 100; j++) {
                    ThreadUtil.sleepUpTo(10);

                    try {
                        getString(rrList);
                    } catch (final Throwable e) {
                        System.err.println(e.getMessage());
                        failureCount.increment();
                    }
                }
            });
        }

        executorService.shutdown();
        executorService.awaitTermination(2, TimeUnit.MINUTES);

        Assert.assertEquals(0, failureCount.longValue());
    }

    private String getString(final Collection<RoundRobinSetTestObject> c) {
        final StringBuilder sb = new StringBuilder();
        int i = 0;
        for (final RoundRobinSetTestObject value : c) {
            sb.append(value);
            i++;
            if (i == N3) {
                break;
            }
        }
        return sb.toString();
    }
}