TestReplayer.java

99 lines | 3.463 kB Blame History Raw Download
/*
 * Copyright 2010-2012 Ning, Inc.
 *
 * Ning 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 com.ning.billing.meter.timeline.persistent;

import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import org.testng.Assert;
import org.testng.annotations.Test;

import com.ning.billing.meter.MeterTestSuiteNoDB;
import com.ning.billing.meter.timeline.sources.SourceSamplesForTimestamp;

import com.google.common.base.Function;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.Lists;

public class TestReplayer extends MeterTestSuiteNoDB {

    private static final File basePath = new File(System.getProperty("java.io.tmpdir"), "TestReplayer-" + System.currentTimeMillis());

    private static final class MockReplayer extends Replayer {

        private final List<File> expectedFiles;
        private int seen = 0;

        public MockReplayer(final String path, final List<File> expectedFiles) {
            super(path);
            this.expectedFiles = expectedFiles;
        }

        @Override
        public void read(final File file, final Function<SourceSamplesForTimestamp, Void> fn) throws IOException {
            Assert.assertEquals(file, expectedFiles.get(seen));
            seen++;
        }

        public int getSeen() {
            return seen;
        }
    }

    private final StreamyBytesPersistentOutputStream outputStream = new StreamyBytesPersistentOutputStream(basePath.toString(), "pweet", null, true);

    @Test(groups = "fast")
    public void testStringOrdering() throws Exception {
        final File file1 = new File("aaa.bbb.12345.bin");
        final File file2 = new File("aaa.bbb.12346.bin");
        final File file3 = new File("aaa.bbb.02345.bin");

        final List<File> sortedCopy = Replayer.FILE_ORDERING.sortedCopy(ImmutableList.<File>of(file2, file1, file3));
        Assert.assertEquals(sortedCopy.get(0), file3);
        Assert.assertEquals(sortedCopy.get(1), file1);
        Assert.assertEquals(sortedCopy.get(2), file2);
    }

    @Test(groups = "slow")
    public void testOrdering() throws Exception {
        Assert.assertTrue(basePath.mkdir());

        final List<String> filePathsCreated = new ArrayList<String>();
        final List<File> filesCreated = new ArrayList<File>();
        final int expected = 50;

        for (int i = 0; i < expected; i++) {
            filePathsCreated.add(outputStream.getFileName());
            Thread.sleep(17);
        }

        // Create the files in the opposite ordering to make sure we can re-read them in order
        for (int i = expected - 1; i >= 0; i--) {
            final File file = new File(filePathsCreated.get(i));
            Assert.assertTrue(file.createNewFile());
            filesCreated.add(file);
        }

        final MockReplayer replayer = new MockReplayer(basePath.toString(), Lists.reverse(filesCreated));
        replayer.readAll();

        Assert.assertEquals(replayer.getSeen(), expected);
    }
}