io.druid.segment.realtime.appenderator.AppenderatorTester.java Source code

Java tutorial

Introduction

Here is the source code for io.druid.segment.realtime.appenderator.AppenderatorTester.java

Source

/*
 * Licensed to Metamarkets Group Inc. (Metamarkets) under one
 * or more contributor license agreements. See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership. Metamarkets 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 io.druid.segment.realtime.appenderator;

import com.fasterxml.jackson.databind.ObjectMapper;
import com.google.common.collect.ImmutableMap;
import com.metamx.common.logger.Logger;
import com.metamx.emitter.EmittingLogger;
import com.metamx.emitter.core.LoggingEmitter;
import com.metamx.emitter.service.ServiceEmitter;
import io.druid.client.cache.CacheConfig;
import io.druid.client.cache.MapCache;
import io.druid.concurrent.Execs;
import io.druid.data.input.impl.DimensionsSpec;
import io.druid.data.input.impl.JSONParseSpec;
import io.druid.data.input.impl.MapInputRowParser;
import io.druid.data.input.impl.TimestampSpec;
import io.druid.granularity.QueryGranularities;
import io.druid.jackson.DefaultObjectMapper;
import io.druid.java.util.common.Granularity;
import io.druid.query.DefaultQueryRunnerFactoryConglomerate;
import io.druid.query.IntervalChunkingQueryRunnerDecorator;
import io.druid.query.Query;
import io.druid.query.QueryRunnerFactory;
import io.druid.query.QueryRunnerTestHelper;
import io.druid.query.aggregation.AggregatorFactory;
import io.druid.query.aggregation.CountAggregatorFactory;
import io.druid.query.aggregation.LongSumAggregatorFactory;
import io.druid.query.timeseries.TimeseriesQuery;
import io.druid.query.timeseries.TimeseriesQueryEngine;
import io.druid.query.timeseries.TimeseriesQueryQueryToolChest;
import io.druid.query.timeseries.TimeseriesQueryRunnerFactory;
import io.druid.segment.IndexIO;
import io.druid.segment.IndexMerger;
import io.druid.segment.column.ColumnConfig;
import io.druid.segment.indexing.DataSchema;
import io.druid.segment.indexing.RealtimeTuningConfig;
import io.druid.segment.indexing.granularity.UniformGranularitySpec;
import io.druid.segment.loading.DataSegmentPusher;
import io.druid.segment.realtime.FireDepartmentMetrics;
import io.druid.server.coordination.DataSegmentAnnouncer;
import io.druid.timeline.DataSegment;
import io.druid.timeline.partition.LinearShardSpec;
import org.apache.commons.io.FileUtils;

import java.io.File;
import java.io.IOException;
import java.util.List;
import java.util.Map;
import java.util.concurrent.CopyOnWriteArrayList;
import java.util.concurrent.ExecutorService;

public class AppenderatorTester implements AutoCloseable {
    public static final String DATASOURCE = "foo";

    private final DataSchema schema;
    private final RealtimeTuningConfig tuningConfig;
    private final FireDepartmentMetrics metrics;
    private final DataSegmentPusher dataSegmentPusher;
    private final ObjectMapper objectMapper;
    private final Appenderator appenderator;
    private final ExecutorService queryExecutor;
    private final IndexIO indexIO;
    private final IndexMerger indexMerger;
    private final ServiceEmitter emitter;

    private final List<DataSegment> pushedSegments = new CopyOnWriteArrayList<>();

    public AppenderatorTester(final int maxRowsInMemory) {
        this(maxRowsInMemory, null);
    }

    public AppenderatorTester(final int maxRowsInMemory, final File basePersistDirectory) {
        objectMapper = new DefaultObjectMapper();
        objectMapper.registerSubtypes(LinearShardSpec.class);

        final Map<String, Object> parserMap = objectMapper
                .convertValue(new MapInputRowParser(new JSONParseSpec(new TimestampSpec("ts", "auto", null),
                        new DimensionsSpec(null, null, null), null, null)), Map.class);
        schema = new DataSchema(DATASOURCE, parserMap,
                new AggregatorFactory[] { new CountAggregatorFactory("count"),
                        new LongSumAggregatorFactory("met", "met") },
                new UniformGranularitySpec(Granularity.MINUTE, QueryGranularities.NONE, null), objectMapper);

        tuningConfig = new RealtimeTuningConfig(maxRowsInMemory, null, null, basePersistDirectory, null, null, null,
                null, null, null, 0, 0, null, null);

        metrics = new FireDepartmentMetrics();
        queryExecutor = Execs.singleThreaded("queryExecutor(%d)");

        indexIO = new IndexIO(objectMapper, new ColumnConfig() {
            @Override
            public int columnCacheSizeBytes() {
                return 0;
            }
        });
        indexMerger = new IndexMerger(objectMapper, indexIO);

        emitter = new ServiceEmitter("test", "test",
                new LoggingEmitter(new Logger(AppenderatorTester.class), LoggingEmitter.Level.INFO, objectMapper));
        emitter.start();
        EmittingLogger.registerEmitter(emitter);
        dataSegmentPusher = new DataSegmentPusher() {
            @Deprecated
            @Override
            public String getPathForHadoop(String dataSource) {
                return getPathForHadoop();
            }

            @Override
            public String getPathForHadoop() {
                throw new UnsupportedOperationException();
            }

            @Override
            public DataSegment push(File file, DataSegment segment) throws IOException {
                pushedSegments.add(segment);
                return segment;
            }
        };
        appenderator = Appenderators.createRealtime(schema, tuningConfig, metrics, dataSegmentPusher, objectMapper,
                indexIO, indexMerger,
                new DefaultQueryRunnerFactoryConglomerate(
                        ImmutableMap.<Class<? extends Query>, QueryRunnerFactory>of(TimeseriesQuery.class,
                                new TimeseriesQueryRunnerFactory(
                                        new TimeseriesQueryQueryToolChest(new IntervalChunkingQueryRunnerDecorator(
                                                queryExecutor, QueryRunnerTestHelper.NOOP_QUERYWATCHER, emitter)),
                                        new TimeseriesQueryEngine(), QueryRunnerTestHelper.NOOP_QUERYWATCHER))),
                new DataSegmentAnnouncer() {
                    @Override
                    public void announceSegment(DataSegment segment) throws IOException {

                    }

                    @Override
                    public void unannounceSegment(DataSegment segment) throws IOException {

                    }

                    @Override
                    public void announceSegments(Iterable<DataSegment> segments) throws IOException {

                    }

                    @Override
                    public void unannounceSegments(Iterable<DataSegment> segments) throws IOException {

                    }

                    @Override
                    public boolean isAnnounced(DataSegment segment) {
                        return false;
                    }
                }, emitter, queryExecutor, MapCache.create(2048), new CacheConfig());
    }

    public DataSchema getSchema() {
        return schema;
    }

    public RealtimeTuningConfig getTuningConfig() {
        return tuningConfig;
    }

    public FireDepartmentMetrics getMetrics() {
        return metrics;
    }

    public DataSegmentPusher getDataSegmentPusher() {
        return dataSegmentPusher;
    }

    public ObjectMapper getObjectMapper() {
        return objectMapper;
    }

    public Appenderator getAppenderator() {
        return appenderator;
    }

    public List<DataSegment> getPushedSegments() {
        return pushedSegments;
    }

    @Override
    public void close() throws Exception {
        appenderator.close();
        queryExecutor.shutdownNow();
        emitter.close();
        FileUtils.deleteDirectory(tuningConfig.getBasePersistDirectory());
    }
}