TestCatalogServerResponse.java

/*
 * 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 com.facebook.presto.catalogserver;

import com.facebook.airlift.json.JsonModule;
import com.facebook.presto.common.QualifiedObjectName;
import com.facebook.presto.common.transaction.TransactionId;
import com.facebook.presto.connector.informationSchema.InformationSchemaTableHandle;
import com.facebook.presto.connector.informationSchema.InformationSchemaTransactionHandle;
import com.facebook.presto.metadata.HandleJsonModule;
import com.facebook.presto.spi.ConnectorId;
import com.facebook.presto.spi.ConnectorTableHandle;
import com.facebook.presto.spi.MaterializedViewDefinition;
import com.facebook.presto.spi.SchemaTableName;
import com.facebook.presto.spi.TableHandle;
import com.facebook.presto.spi.analyzer.ViewDefinition;
import com.facebook.presto.spi.connector.ConnectorTransactionHandle;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.google.inject.Guice;
import com.google.inject.Injector;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.UUID;

import static org.testng.Assert.assertEquals;

public class TestCatalogServerResponse
{
    private TestingCatalogServerClient testingCatalogServerClient;
    private ObjectMapper objectMapper;

    @BeforeTest
    public void setup()
    {
        this.testingCatalogServerClient = new TestingCatalogServerClient();
        Injector injector = Guice.createInjector(new JsonModule(), new HandleJsonModule());
        this.objectMapper = injector.getInstance(ObjectMapper.class);
    }

    @Test
    public void testSchemaExists()
            throws Exception
    {
        boolean schemaExists = testingCatalogServerClient.schemaExists(null, null, null);
        boolean actualSchemaExists = false;

        assertEquals(schemaExists, actualSchemaExists);
    }

    @Test
    public void testCatalogExists()
            throws Exception
    {
        boolean catalogExists = testingCatalogServerClient.catalogExists(null, null, null);
        boolean actualCatalogExists = true;

        assertEquals(catalogExists, actualCatalogExists);
    }

    @Test
    public void testListSchemaNames()
            throws Exception
    {
        String schemaNamesJson = testingCatalogServerClient.listSchemaNames(null, null, null);
        List<String> schemaNames = objectMapper.readValue(schemaNamesJson, new TypeReference<List<String>>() {});
        List<String> actualSchemaNames = new ArrayList<>(Arrays.asList(
                "information_schema",
                "tiny",
                "sf1",
                "sf100",
                "sf300",
                "sf1000",
                "sf3000",
                "sf10000",
                "sf30000",
                "sf100000"));

        assertEquals(schemaNames, actualSchemaNames);
    }

    @Test
    public void testGetTableHandle()
            throws Exception
    {
        String tableHandleJson = testingCatalogServerClient.getTableHandle(null, null, null);
        TableHandle tableHandle = objectMapper.readValue(tableHandleJson, TableHandle.class);
        ConnectorId connectorId = new ConnectorId("$info_schema@system");
        ConnectorTableHandle connectorHandle = new InformationSchemaTableHandle("system", "information_schema", "schemata");
        UUID uuid = UUID.fromString("ffe9ae3e-60de-4175-a0b5-d635767085fa");
        ConnectorTransactionHandle connectorTransactionHandle = new InformationSchemaTransactionHandle(new TransactionId(uuid));
        TableHandle actualTableHandle = new TableHandle(connectorId, connectorHandle, connectorTransactionHandle, Optional.empty());

        assertEquals(tableHandle, actualTableHandle);
    }

    @Test
    public void testListTables()
            throws Exception
    {
        String tableListJson = testingCatalogServerClient.listTables(null, null, null);
        List<QualifiedObjectName> tableList = objectMapper.readValue(tableListJson, new TypeReference<List<QualifiedObjectName>>() {});
        List<QualifiedObjectName> actualTableList = new ArrayList<>(Arrays.asList(new QualifiedObjectName("tpch", "sf1", "nation")));

        assertEquals(tableList, actualTableList);
    }

    @Test
    public void testListViews()
            throws Exception
    {
        String viewsListJson = testingCatalogServerClient.listViews(null, null, null);
        List<QualifiedObjectName> viewsList = objectMapper.readValue(viewsListJson, new TypeReference<List<QualifiedObjectName>>() {});
        List<QualifiedObjectName> actualViewsList = new ArrayList<>(Arrays.asList(
                new QualifiedObjectName("hive", "tpch", "eric"),
                new QualifiedObjectName("hive", "tpch", "eric2")));

        assertEquals(viewsList, actualViewsList);
    }

    @Test
    public void testGetViews()
            throws Exception
    {
        String viewsMapJson = testingCatalogServerClient.getViews(null, null, null);
        Map<QualifiedObjectName, ViewDefinition> viewsMap = objectMapper.readValue(viewsMapJson, new TypeReference<Map<QualifiedObjectName, ViewDefinition>>() {});
        Map<QualifiedObjectName, ViewDefinition> actualViewsMap = new HashMap<>();
        QualifiedObjectName key = new QualifiedObjectName("hive", "tpch", "eric");
        actualViewsMap.put(key, new ViewDefinition(
                "SELECT name\nFROM\n  tpch.sf1.nation\n",
                Optional.of("hive"),
                Optional.of("tpch"),
                new ArrayList<>(),
                Optional.of("ericn576"),
                false));
        assertEquals(viewsMap.keySet(), actualViewsMap.keySet());
        ViewDefinition viewDefinition = viewsMap.get(key);
        ViewDefinition actualViewDefinition = actualViewsMap.get(key);

        assertEquals(viewDefinition.getOriginalSql(), actualViewDefinition.getOriginalSql());
        assertEquals(viewDefinition.getCatalog(), actualViewDefinition.getCatalog());
        assertEquals(viewDefinition.getSchema(), actualViewDefinition.getSchema());
        assertEquals(viewDefinition.getOwner(), actualViewDefinition.getOwner());
    }

    @Test
    public void testGetView()
            throws Exception
    {
        String viewDefinitionJson = testingCatalogServerClient.getView(null, null, null);
        ViewDefinition viewDefinition = objectMapper.readValue(viewDefinitionJson, ViewDefinition.class);
        ViewDefinition actualViewDefinition = new ViewDefinition(
                "SELECT name\nFROM\n  tpch.sf1.nation\n",
                Optional.of("hive"),
                Optional.of("tpch"),
                new ArrayList<>(),
                Optional.of("ericn576"),
                false);

        assertEquals(viewDefinition.getOriginalSql(), actualViewDefinition.getOriginalSql());
        assertEquals(viewDefinition.getCatalog(), actualViewDefinition.getCatalog());
        assertEquals(viewDefinition.getSchema(), actualViewDefinition.getSchema());
        assertEquals(viewDefinition.getOwner(), actualViewDefinition.getOwner());
    }

    @Test
    public void testGetMaterializedView()
            throws Exception
    {
        String connectorMaterializedViewDefinitionJson = testingCatalogServerClient.getMaterializedView(null, null, null);
        MaterializedViewDefinition materializedViewDefinition = objectMapper.readValue(
                connectorMaterializedViewDefinitionJson,
                MaterializedViewDefinition.class);
        String originalSql = "SELECT\n  name\n, nationkey\nFROM\n  test_customer_base\n";
        String schema = "tpch";
        String table = "eric";
        List<SchemaTableName> baseTables = new ArrayList<>(Arrays.asList(new SchemaTableName("tpch", "test_customer_base")));
        Optional<String> owner = Optional.of("ericn576");
        List<MaterializedViewDefinition.ColumnMapping> columnMappings = new ArrayList<>();
        MaterializedViewDefinition.TableColumn tableColumn = new MaterializedViewDefinition.TableColumn(
                new SchemaTableName("tpch", "eric"),
                "name",
                true);
        MaterializedViewDefinition.TableColumn listTableColumn = new MaterializedViewDefinition.TableColumn(
                new SchemaTableName("tpch", "test_customer_base"),
                "name",
                true);
        columnMappings.add(new MaterializedViewDefinition.ColumnMapping(tableColumn, new ArrayList<>(Arrays.asList(listTableColumn))));
        List<SchemaTableName> baseTablesOnOuterJoinSide = new ArrayList<>();
        Optional<List<String>> validRefreshColumns = Optional.of(new ArrayList<>(Arrays.asList("nationkey")));
        MaterializedViewDefinition actualMaterializedViewDefinition = new MaterializedViewDefinition(
                originalSql,
                schema,
                table,
                baseTables,
                owner,
                columnMappings,
                baseTablesOnOuterJoinSide,
                validRefreshColumns);

        assertEquals(materializedViewDefinition.getOriginalSql(), actualMaterializedViewDefinition.getOriginalSql());
        assertEquals(materializedViewDefinition.getSchema(), actualMaterializedViewDefinition.getSchema());
        assertEquals(materializedViewDefinition.getTable(), actualMaterializedViewDefinition.getTable());
        assertEquals(materializedViewDefinition.getBaseTables(), actualMaterializedViewDefinition.getBaseTables());
        assertEquals(materializedViewDefinition.getOwner(), actualMaterializedViewDefinition.getOwner());
        assertEquals(materializedViewDefinition.getColumnMappingsAsMap(), actualMaterializedViewDefinition.getColumnMappingsAsMap());
        assertEquals(materializedViewDefinition.getBaseTablesOnOuterJoinSide(), actualMaterializedViewDefinition.getBaseTablesOnOuterJoinSide());
        assertEquals(materializedViewDefinition.getValidRefreshColumns(), actualMaterializedViewDefinition.getValidRefreshColumns());
    }

    @Test
    public void testGetReferencedMaterializedViews()
            throws Exception
    {
        String referencedMaterializedViewsListJson = testingCatalogServerClient.getReferencedMaterializedViews(null, null, null);
        List<QualifiedObjectName> referencedMaterializedViewsList = objectMapper.readValue(referencedMaterializedViewsListJson, new TypeReference<List<QualifiedObjectName>>() {});
        List<QualifiedObjectName> actualReferencedMaterializedViewsList = new ArrayList<>(
                Arrays.asList(new QualifiedObjectName("hive", "tpch", "test_customer_base")));

        assertEquals(referencedMaterializedViewsList, actualReferencedMaterializedViewsList);
    }
}