Search in sources :

Example 1 with OrdersInput

use of com.example.graphql.client.betterbotz.type.OrdersInput in project stargate by stargate.

the class BulkInsertTest method bulkInsertMoreProductsThanSelectionsUsingBulkAndOrderWithAtomic.

@Test
@DisplayName("Should execute multiple mutations including bulk with more elements than selections with atomic directive")
public void bulkInsertMoreProductsThanSelectionsUsingBulkAndOrderWithAtomic() {
    String productName = "Shiny Legs";
    String description = "Normal legs but shiny.";
    List<ProductsInput> productsInputs = new ArrayList<>();
    for (int i = 0; i < 10; i++) {
        productsInputs.add(ProductsInput.builder().id(UUID.randomUUID().toString()).name(productName).price("3199.99").created(now()).description(description).build());
    }
    String customerName = "c1";
    OrdersInput order = OrdersInput.builder().prodName(productName).customerName(customerName).price("3199.99").description(description).build();
    ApolloClient client = getApolloClient("/graphql/" + keyspace);
    BulkInsertProductsAndOrdersWithAtomicMutation mutation = BulkInsertProductsAndOrdersWithAtomicMutation.builder().values(productsInputs).orderValue(order).build();
    bulkInsertProductsAndOrdersWithAtomic(client, mutation);
    for (ProductsInput product : productsInputs) {
        GetProductsWithFilterQuery.Value product1Result = getProduct(client, (String) product.id());
        assertThat(product1Result.getId()).hasValue(product.id());
        assertThat(product1Result.getName()).hasValue(product.name());
        assertThat(product1Result.getPrice()).hasValue(product.price());
        assertThat(product1Result.getCreated()).hasValue(product.created());
        assertThat(product1Result.getDescription()).hasValue(product.description());
    }
    assertThat(session.execute(SimpleStatement.newInstance("SELECT * FROM \"Orders\" WHERE \"prodName\" = ?", productName)).one()).isNotNull().extracting(r -> r.getString("\"customerName\""), r -> r.getString("description")).containsExactly(customerName, description);
}
Also used : OrdersInput(com.example.graphql.client.betterbotz.type.OrdersInput) ApolloClient(com.apollographql.apollo.ApolloClient) GetProductsWithFilterQuery(com.example.graphql.client.betterbotz.products.GetProductsWithFilterQuery) Arrays(java.util.Arrays) InsertOrdersAndBulkInsertProductsWithAtomicMutation(com.example.graphql.client.betterbotz.atomic.InsertOrdersAndBulkInsertProductsWithAtomicMutation) Assertions.assertThat(org.assertj.core.api.Assertions.assertThat) ProductsInput(com.example.graphql.client.betterbotz.type.ProductsInput) UUID(java.util.UUID) SimpleStatement(com.datastax.oss.driver.api.core.cql.SimpleStatement) ApolloClient(com.apollographql.apollo.ApolloClient) BulkInsertProductsAndOrdersWithAtomicMutation(com.example.graphql.client.betterbotz.atomic.BulkInsertProductsAndOrdersWithAtomicMutation) OrdersInput(com.example.graphql.client.betterbotz.type.OrdersInput) ArrayList(java.util.ArrayList) DisplayName(org.junit.jupiter.api.DisplayName) Test(org.junit.jupiter.api.Test) List(java.util.List) BulkInsertProductsWithAtomicMutation(com.example.graphql.client.betterbotz.atomic.BulkInsertProductsWithAtomicMutation) BulkInsertProductsMutation(com.example.graphql.client.betterbotz.products.BulkInsertProductsMutation) BulkInsertProductsAndOrdersWithAtomicMutation(com.example.graphql.client.betterbotz.atomic.BulkInsertProductsAndOrdersWithAtomicMutation) GetProductsWithFilterQuery(com.example.graphql.client.betterbotz.products.GetProductsWithFilterQuery) ArrayList(java.util.ArrayList) ProductsInput(com.example.graphql.client.betterbotz.type.ProductsInput) Test(org.junit.jupiter.api.Test) DisplayName(org.junit.jupiter.api.DisplayName)

Example 2 with OrdersInput

use of com.example.graphql.client.betterbotz.type.OrdersInput in project stargate by stargate.

the class ApolloTest method getOrdersByValue.

@Test
public void getOrdersByValue() throws ExecutionException, InterruptedException {
    ApolloClient client = getApolloClient("/graphql/" + keyspace);
    OrdersInput ordersInput = OrdersInput.builder().prodName("Medium Lift Arms").build();
    GetOrdersByValueQuery query = GetOrdersByValueQuery.builder().value(ordersInput).build();
    CompletableFuture<GetOrdersByValueQuery.Data> future = new CompletableFuture<>();
    ApolloQueryCall<Optional<GetOrdersByValueQuery.Data>> observable = client.query(query);
    observable.enqueue(queryCallback(future));
    GetOrdersByValueQuery.Data result = future.get();
    observable.cancel();
    assertThat(result.getOrders()).isPresent();
    GetOrdersByValueQuery.Orders orders = result.getOrders().get();
    assertThat(orders.getValues()).isPresent();
    List<GetOrdersByValueQuery.Value> valuesList = orders.getValues().get();
    GetOrdersByValueQuery.Value value = valuesList.get(0);
    assertThat(value.getId()).hasValue("792d0a56-bb46-4bc2-bc41-5f4a94a83da9");
    assertThat(value.getProdId()).hasValue("31047029-2175-43ce-9fdd-b3d568b19bb2");
    assertThat(value.getProdName()).hasValue("Medium Lift Arms");
    assertThat(value.getCustomerName()).hasValue("Janice Evernathy");
    assertThat(value.getAddress()).hasValue("2101 Everplace Ave 3116");
    assertThat(value.getDescription()).hasValue("Ordering some more arms for my construction bot.");
    assertThat(value.getPrice()).hasValue("3199.99");
    assertThat(value.getSellPrice()).hasValue("3119.99");
}
Also used : GetOrdersByValueQuery(com.example.graphql.client.betterbotz.orders.GetOrdersByValueQuery) Optional(java.util.Optional) ApolloClient(com.apollographql.apollo.ApolloClient) OrdersInput(com.example.graphql.client.betterbotz.type.OrdersInput) CompletableFuture(java.util.concurrent.CompletableFuture) Value(com.example.graphql.client.betterbotz.products.GetProductsWithFilterQuery.Value) Test(org.junit.jupiter.api.Test)

Example 3 with OrdersInput

use of com.example.graphql.client.betterbotz.type.OrdersInput in project stargate by stargate.

the class BulkInsertTest method insertOrderAndBulkInsertNProductsWithAtomic.

@Test
@DisplayName("Should execute normal insert and multiple bulk mutations with atomic directive")
public void insertOrderAndBulkInsertNProductsWithAtomic() {
    String productId1 = UUID.randomUUID().toString();
    String productId2 = UUID.randomUUID().toString();
    String productName = "Shiny Legs";
    String description = "Normal legs but shiny.";
    ProductsInput product1 = ProductsInput.builder().id(productId1).name(productName).price("3199.99").created(now()).description(description).build();
    ProductsInput product2 = ProductsInput.builder().id(productId2).name("Non-Legs").price("1000.99").created(now()).description("Non-legs.").build();
    String customerName = "c1";
    OrdersInput order = OrdersInput.builder().prodName(productName).customerName(customerName).price("3199.99").description(description).build();
    ApolloClient client = getApolloClient("/graphql/" + keyspace);
    InsertOrdersAndBulkInsertProductsWithAtomicMutation mutation = InsertOrdersAndBulkInsertProductsWithAtomicMutation.builder().values(Arrays.asList(product1, product2)).orderValue(order).build();
    insertOrdersAndBulkInsertProductsWthAtomic(client, mutation);
    GetProductsWithFilterQuery.Value product1Result = getProduct(client, productId1);
    assertThat(product1Result.getId()).hasValue(productId1);
    assertThat(product1Result.getName()).hasValue(product1.name());
    assertThat(product1Result.getPrice()).hasValue(product1.price());
    assertThat(product1Result.getCreated()).hasValue(product1.created());
    assertThat(product1Result.getDescription()).hasValue(product1.description());
    GetProductsWithFilterQuery.Value product2Result = getProduct(client, productId2);
    assertThat(product2Result.getId()).hasValue(productId2);
    assertThat(product2Result.getName()).hasValue(product2.name());
    assertThat(product2Result.getPrice()).hasValue(product2.price());
    assertThat(product2Result.getCreated()).hasValue(product2.created());
    assertThat(product2Result.getDescription()).hasValue(product2.description());
    assertThat(session.execute(SimpleStatement.newInstance("SELECT * FROM \"Orders\" WHERE \"prodName\" = ?", productName)).one()).isNotNull().extracting(r -> r.getString("\"customerName\""), r -> r.getString("description")).containsExactly(customerName, description);
}
Also used : OrdersInput(com.example.graphql.client.betterbotz.type.OrdersInput) ApolloClient(com.apollographql.apollo.ApolloClient) GetProductsWithFilterQuery(com.example.graphql.client.betterbotz.products.GetProductsWithFilterQuery) Arrays(java.util.Arrays) InsertOrdersAndBulkInsertProductsWithAtomicMutation(com.example.graphql.client.betterbotz.atomic.InsertOrdersAndBulkInsertProductsWithAtomicMutation) Assertions.assertThat(org.assertj.core.api.Assertions.assertThat) ProductsInput(com.example.graphql.client.betterbotz.type.ProductsInput) UUID(java.util.UUID) SimpleStatement(com.datastax.oss.driver.api.core.cql.SimpleStatement) ApolloClient(com.apollographql.apollo.ApolloClient) BulkInsertProductsAndOrdersWithAtomicMutation(com.example.graphql.client.betterbotz.atomic.BulkInsertProductsAndOrdersWithAtomicMutation) OrdersInput(com.example.graphql.client.betterbotz.type.OrdersInput) ArrayList(java.util.ArrayList) DisplayName(org.junit.jupiter.api.DisplayName) Test(org.junit.jupiter.api.Test) List(java.util.List) BulkInsertProductsWithAtomicMutation(com.example.graphql.client.betterbotz.atomic.BulkInsertProductsWithAtomicMutation) BulkInsertProductsMutation(com.example.graphql.client.betterbotz.products.BulkInsertProductsMutation) GetProductsWithFilterQuery(com.example.graphql.client.betterbotz.products.GetProductsWithFilterQuery) ProductsInput(com.example.graphql.client.betterbotz.type.ProductsInput) InsertOrdersAndBulkInsertProductsWithAtomicMutation(com.example.graphql.client.betterbotz.atomic.InsertOrdersAndBulkInsertProductsWithAtomicMutation) Test(org.junit.jupiter.api.Test) DisplayName(org.junit.jupiter.api.DisplayName)

Example 4 with OrdersInput

use of com.example.graphql.client.betterbotz.type.OrdersInput in project stargate by stargate.

the class BulkInsertTest method bulkInsertNProductsUsingBulkAndOrderWithAtomic.

@Test
@DisplayName("Should execute multiple mutations including bulk with atomic directive")
public void bulkInsertNProductsUsingBulkAndOrderWithAtomic() {
    String productId1 = UUID.randomUUID().toString();
    String productId2 = UUID.randomUUID().toString();
    String productName = "Shiny Legs";
    String description = "Normal legs but shiny.";
    ProductsInput product1 = ProductsInput.builder().id(productId1).name(productName).price("3199.99").created(now()).description(description).build();
    ProductsInput product2 = ProductsInput.builder().id(productId2).name("Non-Legs").price("1000.99").created(now()).description("Non-legs.").build();
    String customerName = "c1";
    OrdersInput order = OrdersInput.builder().prodName(productName).customerName(customerName).price("3199.99").description(description).build();
    ApolloClient client = getApolloClient("/graphql/" + keyspace);
    BulkInsertProductsAndOrdersWithAtomicMutation mutation = BulkInsertProductsAndOrdersWithAtomicMutation.builder().values(Arrays.asList(product1, product2)).orderValue(order).build();
    List<BulkInsertProductsAndOrdersWithAtomicMutation.Product> result = bulkInsertProductsAndOrdersWithAtomic(client, mutation).getProducts().get();
    BulkInsertProductsAndOrdersWithAtomicMutation.Product firstInsertedProduct = result.get(0);
    BulkInsertProductsAndOrdersWithAtomicMutation.Product secondInsertedProduct = result.get(1);
    assertThat(firstInsertedProduct.getApplied().get()).isTrue();
    assertThat(firstInsertedProduct.getValue()).hasValueSatisfying(value -> {
        assertThat(value.getId()).hasValue(productId1);
    });
    assertThat(secondInsertedProduct.getApplied().get()).isTrue();
    assertThat(secondInsertedProduct.getValue()).hasValueSatisfying(value -> {
        assertThat(value.getId()).hasValue(productId2);
    });
    // retrieve from db
    GetProductsWithFilterQuery.Value product1Result = getProduct(client, productId1);
    assertThat(product1Result.getId()).hasValue(productId1);
    assertThat(product1Result.getName()).hasValue(product1.name());
    assertThat(product1Result.getPrice()).hasValue(product1.price());
    assertThat(product1Result.getCreated()).hasValue(product1.created());
    assertThat(product1Result.getDescription()).hasValue(product1.description());
    GetProductsWithFilterQuery.Value product2Result = getProduct(client, productId2);
    assertThat(product2Result.getId()).hasValue(productId2);
    assertThat(product2Result.getName()).hasValue(product2.name());
    assertThat(product2Result.getPrice()).hasValue(product2.price());
    assertThat(product2Result.getCreated()).hasValue(product2.created());
    assertThat(product2Result.getDescription()).hasValue(product2.description());
    assertThat(session.execute(SimpleStatement.newInstance("SELECT * FROM \"Orders\" WHERE \"prodName\" = ?", productName)).one()).isNotNull().extracting(r -> r.getString("\"customerName\""), r -> r.getString("description")).containsExactly(customerName, description);
}
Also used : OrdersInput(com.example.graphql.client.betterbotz.type.OrdersInput) ApolloClient(com.apollographql.apollo.ApolloClient) GetProductsWithFilterQuery(com.example.graphql.client.betterbotz.products.GetProductsWithFilterQuery) Arrays(java.util.Arrays) InsertOrdersAndBulkInsertProductsWithAtomicMutation(com.example.graphql.client.betterbotz.atomic.InsertOrdersAndBulkInsertProductsWithAtomicMutation) Assertions.assertThat(org.assertj.core.api.Assertions.assertThat) ProductsInput(com.example.graphql.client.betterbotz.type.ProductsInput) UUID(java.util.UUID) SimpleStatement(com.datastax.oss.driver.api.core.cql.SimpleStatement) ApolloClient(com.apollographql.apollo.ApolloClient) BulkInsertProductsAndOrdersWithAtomicMutation(com.example.graphql.client.betterbotz.atomic.BulkInsertProductsAndOrdersWithAtomicMutation) OrdersInput(com.example.graphql.client.betterbotz.type.OrdersInput) ArrayList(java.util.ArrayList) DisplayName(org.junit.jupiter.api.DisplayName) Test(org.junit.jupiter.api.Test) List(java.util.List) BulkInsertProductsWithAtomicMutation(com.example.graphql.client.betterbotz.atomic.BulkInsertProductsWithAtomicMutation) BulkInsertProductsMutation(com.example.graphql.client.betterbotz.products.BulkInsertProductsMutation) BulkInsertProductsAndOrdersWithAtomicMutation(com.example.graphql.client.betterbotz.atomic.BulkInsertProductsAndOrdersWithAtomicMutation) GetProductsWithFilterQuery(com.example.graphql.client.betterbotz.products.GetProductsWithFilterQuery) ProductsInput(com.example.graphql.client.betterbotz.type.ProductsInput) Test(org.junit.jupiter.api.Test) DisplayName(org.junit.jupiter.api.DisplayName)

Aggregations

ApolloClient (com.apollographql.apollo.ApolloClient)4 OrdersInput (com.example.graphql.client.betterbotz.type.OrdersInput)4 Test (org.junit.jupiter.api.Test)4 SimpleStatement (com.datastax.oss.driver.api.core.cql.SimpleStatement)3 BulkInsertProductsAndOrdersWithAtomicMutation (com.example.graphql.client.betterbotz.atomic.BulkInsertProductsAndOrdersWithAtomicMutation)3 BulkInsertProductsWithAtomicMutation (com.example.graphql.client.betterbotz.atomic.BulkInsertProductsWithAtomicMutation)3 InsertOrdersAndBulkInsertProductsWithAtomicMutation (com.example.graphql.client.betterbotz.atomic.InsertOrdersAndBulkInsertProductsWithAtomicMutation)3 BulkInsertProductsMutation (com.example.graphql.client.betterbotz.products.BulkInsertProductsMutation)3 GetProductsWithFilterQuery (com.example.graphql.client.betterbotz.products.GetProductsWithFilterQuery)3 ProductsInput (com.example.graphql.client.betterbotz.type.ProductsInput)3 ArrayList (java.util.ArrayList)3 Arrays (java.util.Arrays)3 List (java.util.List)3 UUID (java.util.UUID)3 Assertions.assertThat (org.assertj.core.api.Assertions.assertThat)3 DisplayName (org.junit.jupiter.api.DisplayName)3 GetOrdersByValueQuery (com.example.graphql.client.betterbotz.orders.GetOrdersByValueQuery)1 Value (com.example.graphql.client.betterbotz.products.GetProductsWithFilterQuery.Value)1 Optional (java.util.Optional)1 CompletableFuture (java.util.concurrent.CompletableFuture)1