com.yahoo.bard.webservice.web.endpoints.JobsEndpointResources.java Source code

Java tutorial

Introduction

Here is the source code for com.yahoo.bard.webservice.web.endpoints.JobsEndpointResources.java

Source

// Copyright 2016 Yahoo Inc.
// Licensed under the terms of the Apache license. Please see LICENSE.md file distributed with this work for terms.
package com.yahoo.bard.webservice.web.endpoints;

import com.yahoo.bard.webservice.async.jobs.jobrows.DefaultJobField;
import com.yahoo.bard.webservice.async.jobs.jobrows.JobField;
import com.yahoo.bard.webservice.async.jobs.jobrows.JobRow;
import com.yahoo.bard.webservice.async.jobs.stores.ApiJobStore;
import com.yahoo.bard.webservice.async.jobs.stores.HashJobStore;
import com.yahoo.bard.webservice.async.preresponses.stores.HashPreResponseStore;
import com.yahoo.bard.webservice.async.preresponses.stores.PreResponseStore;
import com.yahoo.bard.webservice.data.Result;
import com.yahoo.bard.webservice.data.ResultSet;
import com.yahoo.bard.webservice.data.ResultSetSchema;
import com.yahoo.bard.webservice.data.metric.MetricColumn;
import com.yahoo.bard.webservice.data.time.AllGranularity;
import com.yahoo.bard.webservice.data.time.Granularity;
import com.yahoo.bard.webservice.web.PreResponse;
import com.yahoo.bard.webservice.web.responseprocessors.ResponseContext;
import com.yahoo.bard.webservice.web.responseprocessors.ResponseContextKeys;

import org.joda.time.DateTime;

import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;

import javax.ws.rs.core.MultivaluedHashMap;

/**
 * A resource class to hold all the objects for testing the JobsEndpoint.
 */
public class JobsEndpointResources {

    /**
     * Get an instance of ApiJobStore for testing.
     *
     * @return An instance of ApiJobStore
     */
    public static ApiJobStore getApiJobStore() {
        ApiJobStore apiJobStore = new HashJobStore();

        Map<JobField, String> fieldValueMap1 = new HashMap<>();
        fieldValueMap1.put(DefaultJobField.JOB_TICKET, "ticket1");
        fieldValueMap1.put(DefaultJobField.DATE_CREATED, "2016-01-01");
        fieldValueMap1.put(DefaultJobField.DATE_UPDATED, "2016-01-01");
        fieldValueMap1.put(DefaultJobField.QUERY, "https://localhost:PORT/v1/data/QUERY");
        fieldValueMap1.put(DefaultJobField.STATUS, "success");
        fieldValueMap1.put(DefaultJobField.USER_ID, "momo");

        JobRow jobRow1 = new JobRow(DefaultJobField.JOB_TICKET, fieldValueMap1);
        apiJobStore.save(jobRow1);

        Map<JobField, String> fieldValueMap2 = new HashMap<>();
        fieldValueMap2.put(DefaultJobField.JOB_TICKET, "ticket2");
        fieldValueMap2.put(DefaultJobField.DATE_CREATED, "2016-01-01");
        fieldValueMap2.put(DefaultJobField.DATE_UPDATED, "2016-01-01");
        fieldValueMap2.put(DefaultJobField.QUERY, "https://localhost:PORT/v1/data/QUERY");
        fieldValueMap2.put(DefaultJobField.STATUS, "pending");
        fieldValueMap2.put(DefaultJobField.USER_ID, "dodo");

        JobRow jobRow2 = new JobRow(DefaultJobField.JOB_TICKET, fieldValueMap2);
        apiJobStore.save(jobRow2);

        Map<JobField, String> fieldValueMap3 = new HashMap<>();
        fieldValueMap3.put(DefaultJobField.JOB_TICKET, "ticket3p");
        fieldValueMap3.put(DefaultJobField.DATE_CREATED, "2016-01-01");
        fieldValueMap3.put(DefaultJobField.DATE_UPDATED, "2016-01-01");
        fieldValueMap3.put(DefaultJobField.QUERY, "https://localhost:PORT/v1/data/QUERY");
        fieldValueMap3.put(DefaultJobField.STATUS, "success");
        fieldValueMap3.put(DefaultJobField.USER_ID, "yoyo");

        JobRow jobRow3 = new JobRow(DefaultJobField.JOB_TICKET, fieldValueMap3);
        apiJobStore.save(jobRow3);

        return apiJobStore;
    }

    /**
     * Get an instance of PreResponseStore for testing.
     *
     * @return An instance of PreResponseStore.
     */
    public static PreResponseStore getPreResponseStore() {
        PreResponseStore preResponseStore = new HashPreResponseStore();
        Granularity granularity = AllGranularity.INSTANCE;

        Map<MetricColumn, Object> metricValues = new HashMap<>();
        MetricColumn pageViewColumn = new MetricColumn("pageViews");
        metricValues.put(pageViewColumn, new BigDecimal(111));

        ResultSetSchema schema = new ResultSetSchema(granularity, Collections.singleton(pageViewColumn));
        Result result = new Result(new HashMap<>(), metricValues, DateTime.parse("2016-01-12T00:00:00.000Z"));
        List<Result> results = new ArrayList<>();
        results.add(result);
        ResultSet resultSet = new ResultSet(schema, results);

        LinkedHashSet<String> apiMetricColumnNames = new LinkedHashSet<>();
        apiMetricColumnNames.add("pageViews");

        ResponseContext responseContext = new ResponseContext();
        responseContext.put("headers", new MultivaluedHashMap<>());
        responseContext.put("apiMetricColumnNames", apiMetricColumnNames);
        responseContext.put("requestedApiDimensionFields", new LinkedHashMap<>());

        PreResponse preResponse = new PreResponse(resultSet, responseContext);
        preResponseStore.save("ticket1", preResponse);

        preResponseStore.save("IExistOnlyInPreResponseStore", preResponse);

        ResponseContext errorResponseContext = new ResponseContext();
        errorResponseContext.put("headers", new MultivaluedHashMap<>());
        errorResponseContext.put(ResponseContextKeys.STATUS.getName(), 500);
        errorResponseContext.put(ResponseContextKeys.ERROR_MESSAGE.getName(), "Error");
        errorResponseContext.put("apiMetricColumnNames", apiMetricColumnNames);
        errorResponseContext.put("requestedApiDimensionFields", new HashMap<>());
        PreResponse errorPresResponse = new PreResponse(resultSet, errorResponseContext);
        preResponseStore.save("errorPreResponse", errorPresResponse);

        //Pagination test resources
        Result result1 = new Result(new HashMap<>(), metricValues, DateTime.parse("2016-01-12T00:00:00.000Z"));
        Result result2 = new Result(new HashMap<>(), metricValues, DateTime.parse("2016-01-13T00:00:00.000Z"));
        Result result3 = new Result(new HashMap<>(), metricValues, DateTime.parse("2016-01-14T00:00:00.000Z"));

        List<Result> results1 = new ArrayList<>();
        results1.add(result1);
        results1.add(result2);
        results1.add(result3);
        ResultSet resultSet1 = new ResultSet(schema, results1);
        PreResponse preResponse1 = new PreResponse(resultSet1, responseContext);
        preResponseStore.save("ticket3p", preResponse1);

        return preResponseStore;
    }
}