All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.stargate.it.http.graphql.graphqlfirst.UdtTest Maven / Gradle / Ivy

There is a newer version: 2.1.0-BETA-19
Show newest version
/*
 * Copyright The Stargate Authors
 *
 * 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 io.stargate.it.http.graphql.graphqlfirst;

import static org.assertj.core.api.AssertionsForClassTypes.assertThat;

import com.datastax.oss.driver.api.core.CqlIdentifier;
import com.datastax.oss.driver.api.core.CqlSession;
import com.datastax.oss.driver.api.core.metadata.schema.KeyspaceMetadata;
import com.datastax.oss.driver.api.core.type.UserDefinedType;
import com.jayway.jsonpath.JsonPath;
import io.stargate.it.driver.CqlSessionExtension;
import io.stargate.it.driver.TestKeyspace;
import io.stargate.it.http.RestUtils;
import io.stargate.it.storage.StargateConnectionInfo;
import java.util.Arrays;
import java.util.Optional;
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.DisplayName;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;

@ExtendWith(CqlSessionExtension.class)
public class UdtTest extends GraphqlFirstTestBase {

  private static GraphqlFirstClient CLIENT;
  private static String KEYSPACE;

  @BeforeAll
  public static void setup(
      StargateConnectionInfo cluster, @TestKeyspace CqlIdentifier keyspaceId, CqlSession session) {
    CLIENT =
        new GraphqlFirstClient(
            cluster.seedAddress(), RestUtils.getAuthToken(cluster.seedAddress()));
    KEYSPACE = keyspaceId.asInternal();
    CLIENT.deploySchema(
        KEYSPACE,
        "type Key @cql_entity(target: UDT) @cql_input {\n"
            + "  k: Int\n"
            + "}\n"
            + "type Value @cql_entity(target: UDT) @cql_input {\n"
            + "  v: Int\n"
            + "}\n"
            + "type Foo @cql_input {\n"
            // UDT as partition key
            + "  k: Key! @cql_column(partitionKey: true, typeHint: \"frozen<\\\"Key\\\">\")\n"
            // UDT as a regular column with index => must be frozen
            + "  v: Value @cql_column(typeHint: \"frozen<\\\"Value\\\">\") @cql_index\n"
            // List of UDT (the element is implicitly frozen) with index on elements
            + "  vs1: [Value] @cql_index\n"
            // List of UDT with FULL index => the list must be frozen
            + "  vs2: [Value]  @cql_column(typeHint: \"frozen>\")\n"
            + "                @cql_index(target: FULL)\n"
            + "}\n"
            + "type Query {\n"
            + "  foo(k: KeyInput!): Foo\n"
            + "  foosByV(v: ValueInput): [Foo]\n"
            + "  foosByVs1(\n"
            + "    v: ValueInput @cql_where(field: \"vs1\" predicate: CONTAINS)\n"
            + "  ): [Foo]\n"
            + "  foosByVs2(\n"
            + "    vs2: [ValueInput]\n"
            + "  ): [Foo]\n"
            + "}\n");

    Optional keyspace = session.refreshSchema().getKeyspace(keyspaceId);
    UserDefinedType keyType =
        keyspace
            .flatMap(ks -> ks.getUserDefinedType(CqlIdentifier.fromInternal("Key")))
            .orElseThrow(AssertionError::new);
    UserDefinedType valueType =
        keyspace
            .flatMap(ks -> ks.getUserDefinedType(CqlIdentifier.fromInternal("Value")))
            .orElseThrow(AssertionError::new);
    // Just insert one row. We just want to check that the queries run and things get serialized and
    // deserialized correctly, we're not testing the backend.
    session.execute(
        "INSERT INTO \"Foo\"(k, v, vs1, vs2) VALUES(?, ?, ?, ?)",
        keyType.newValue(1),
        valueType.newValue(2),
        Arrays.asList(valueType.newValue(3)),
        Arrays.asList(valueType.newValue(4)));
  }

  @Test
  @DisplayName("Should query by UDT primary key")
  public void queryByPrimaryKey() {
    // when
    Object response =
        CLIENT.executeKeyspaceQuery(KEYSPACE, "query { result: foo(k: {k: 1}) { k { k } } }");

    // then
    assertThat(JsonPath.read(response, "$.result.k.k")).isEqualTo(1);
  }

  @Test
  @DisplayName("Should query by indexed UDT column")
  public void queryByIndex() {
    // when
    Object response =
        CLIENT.executeKeyspaceQuery(KEYSPACE, "query { result: foosByV(v: {v: 2}) { k { k } } }");

    // then
    assertThat(JsonPath.read(response, "$.result[0].k.k")).isEqualTo(1);
  }

  @Test
  @DisplayName("Should query by CONTAINS in indexed UDT list")
  public void queryListContains() {
    // when
    Object response =
        CLIENT.executeKeyspaceQuery(KEYSPACE, "query { result: foosByVs1(v: {v: 3}) { k { k } } }");

    // then
    assertThat(JsonPath.read(response, "$.result[0].k.k")).isEqualTo(1);
  }

  @Test
  @DisplayName("Should query by FULL indexed UDT list")
  public void queryListFull() {
    // when
    Object response =
        CLIENT.executeKeyspaceQuery(
            KEYSPACE, "query { result: foosByVs2(vs2: [{v: 4}]) { k { k } } }");

    // then
    assertThat(JsonPath.read(response, "$.result[0].k.k")).isEqualTo(1);
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy