Add 'data-cassandra-reactive' smoke test
This commit is contained in:
@@ -21,6 +21,7 @@ smoke_tests:
|
||||
- conditional
|
||||
- configuration-properties
|
||||
- data-cassandra
|
||||
- data-cassandra-reactive
|
||||
- data-jdbc-h2
|
||||
- data-jdbc-postgresql
|
||||
- data-jpa
|
||||
|
||||
1
data-cassandra-reactive/README.adoc
Normal file
1
data-cassandra-reactive/README.adoc
Normal file
@@ -0,0 +1 @@
|
||||
Tests if Spring Data Cassandra Reactive works
|
||||
16
data-cassandra-reactive/build.gradle
Normal file
16
data-cassandra-reactive/build.gradle
Normal file
@@ -0,0 +1,16 @@
|
||||
plugins {
|
||||
id 'java'
|
||||
id 'org.springframework.boot'
|
||||
id 'org.springframework.aot.smoke-test'
|
||||
id 'org.graalvm.buildtools.native'
|
||||
}
|
||||
|
||||
dependencies {
|
||||
implementation(platform(org.springframework.boot.gradle.plugin.SpringBootPlugin.BOM_COORDINATES))
|
||||
implementation("org.springframework.boot:spring-boot-starter-data-cassandra-reactive")
|
||||
|
||||
testImplementation("org.springframework.boot:spring-boot-starter-test")
|
||||
|
||||
aotTestImplementation(project(":aot-smoke-test-support"))
|
||||
aotTestImplementation("org.awaitility:awaitility:4.2.0")
|
||||
}
|
||||
6
data-cassandra-reactive/docker-compose.yml
Normal file
6
data-cassandra-reactive/docker-compose.yml
Normal file
@@ -0,0 +1,6 @@
|
||||
version: '3.1'
|
||||
services:
|
||||
cassandra:
|
||||
image: 'cassandra:4'
|
||||
ports:
|
||||
- '9042'
|
||||
@@ -0,0 +1,33 @@
|
||||
package com.example.data.cassandra.reactive;
|
||||
|
||||
import java.time.Duration;
|
||||
|
||||
import org.awaitility.Awaitility;
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import org.springframework.aot.smoketest.support.assertj.AssertableOutput;
|
||||
import org.springframework.aot.smoketest.support.junit.AotSmokeTest;
|
||||
|
||||
import static org.assertj.core.api.Assertions.assertThat;
|
||||
|
||||
@AotSmokeTest
|
||||
class DataCassandraReactiveApplicationAotTests {
|
||||
|
||||
@Test
|
||||
void findAll(AssertableOutput output) {
|
||||
Awaitility.await().atMost(Duration.ofSeconds(10)).untilAsserted(() -> {
|
||||
assertThat(output).hasSingleLineContaining("findAll(): Person{firstname='first-1', lastname='last-1'}")
|
||||
.hasSingleLineContaining("findAll(): Person{firstname='first-2', lastname='last-2'}")
|
||||
.hasSingleLineContaining("findAll(): Person{firstname='first-3', lastname='last-3'}");
|
||||
});
|
||||
}
|
||||
|
||||
@Test
|
||||
void findByLastName(AssertableOutput output) {
|
||||
Awaitility.await().atMost(Duration.ofSeconds(10)).untilAsserted(() -> {
|
||||
assertThat(output)
|
||||
.hasSingleLineContaining("findByLastname(): Person{firstname='first-3', lastname='last-3'}");
|
||||
});
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,33 @@
|
||||
package com.example.data.cassandra.reactive;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
import org.springframework.boot.CommandLineRunner;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
@Component
|
||||
class CLR implements CommandLineRunner {
|
||||
|
||||
private final PersonRepository personRepository;
|
||||
|
||||
CLR(PersonRepository personRepository) {
|
||||
this.personRepository = personRepository;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void run(String... args) {
|
||||
this.personRepository.save(new Person(UUID.randomUUID().toString(), "first-1", "last-1"))
|
||||
.then(this.personRepository.save(new Person(UUID.randomUUID().toString(), "first-2", "last-2")))
|
||||
.then(this.personRepository.save(new Person(UUID.randomUUID().toString(), "first-3", "last-3")))
|
||||
.block();
|
||||
|
||||
this.personRepository.findAll().subscribe((person) -> {
|
||||
System.out.printf("findAll(): %s%n", person);
|
||||
}, (ex) -> ex.printStackTrace(System.out));
|
||||
|
||||
this.personRepository.findByLastname("last-3").subscribe((person) -> {
|
||||
System.out.printf("findByLastname(): %s%n", person);
|
||||
}, (ex) -> ex.printStackTrace(System.out));
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,25 @@
|
||||
package com.example.data.cassandra.reactive;
|
||||
|
||||
import com.datastax.oss.driver.api.core.CqlSession;
|
||||
import com.datastax.oss.driver.api.core.CqlSessionBuilder;
|
||||
|
||||
import org.springframework.boot.autoconfigure.cassandra.CassandraProperties;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
import org.springframework.data.cassandra.core.cql.generator.CreateKeyspaceCqlGenerator;
|
||||
import org.springframework.data.cassandra.core.cql.keyspace.CreateKeyspaceSpecification;
|
||||
|
||||
@Configuration
|
||||
class CassandraConfiguration {
|
||||
|
||||
@Bean
|
||||
CqlSession cqlSession(CqlSessionBuilder cqlSessionBuilder, CassandraProperties properties) {
|
||||
// This creates the keyspace on startup
|
||||
try (CqlSession session = cqlSessionBuilder.build()) {
|
||||
session.execute(CreateKeyspaceCqlGenerator
|
||||
.toCql(CreateKeyspaceSpecification.createKeyspace(properties.getKeyspaceName()).ifNotExists()));
|
||||
}
|
||||
return cqlSessionBuilder.build();
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,14 @@
|
||||
package com.example.data.cassandra.reactive;
|
||||
|
||||
import org.springframework.boot.SpringApplication;
|
||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||
|
||||
@SpringBootApplication
|
||||
public class DataCassandraReactiveApplication {
|
||||
|
||||
public static void main(String[] args) throws InterruptedException {
|
||||
SpringApplication.run(DataCassandraReactiveApplication.class, args);
|
||||
Thread.currentThread().join(); // To be able to measure memory consumption
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,59 @@
|
||||
package com.example.data.cassandra.reactive;
|
||||
|
||||
import org.springframework.data.cassandra.core.mapping.Column;
|
||||
import org.springframework.data.cassandra.core.mapping.Indexed;
|
||||
import org.springframework.data.cassandra.core.mapping.PrimaryKey;
|
||||
import org.springframework.data.cassandra.core.mapping.Table;
|
||||
|
||||
@Table
|
||||
public class Person {
|
||||
|
||||
@PrimaryKey
|
||||
private String id;
|
||||
|
||||
@Column
|
||||
private String firstname;
|
||||
|
||||
@Column
|
||||
@Indexed
|
||||
private String lastname;
|
||||
|
||||
public Person() {
|
||||
}
|
||||
|
||||
public Person(String id, String firstname, String lastname) {
|
||||
this.id = id;
|
||||
this.firstname = firstname;
|
||||
this.lastname = lastname;
|
||||
}
|
||||
|
||||
public String getId() {
|
||||
return id;
|
||||
}
|
||||
|
||||
public void setId(String id) {
|
||||
this.id = id;
|
||||
}
|
||||
|
||||
public String getFirstname() {
|
||||
return firstname;
|
||||
}
|
||||
|
||||
public void setFirstname(String firstname) {
|
||||
this.firstname = firstname;
|
||||
}
|
||||
|
||||
public String getLastname() {
|
||||
return lastname;
|
||||
}
|
||||
|
||||
public void setLastname(String lastname) {
|
||||
this.lastname = lastname;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "Person{" + "firstname='" + firstname + '\'' + ", lastname='" + lastname + '\'' + '}';
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,26 @@
|
||||
/*
|
||||
* Copyright 2020 the original author or 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
|
||||
*
|
||||
* https://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.example.data.cassandra.reactive;
|
||||
|
||||
import reactor.core.publisher.Flux;
|
||||
|
||||
import org.springframework.data.repository.reactive.ReactiveCrudRepository;
|
||||
|
||||
public interface PersonRepository extends ReactiveCrudRepository<Person, String> {
|
||||
|
||||
Flux<Person> findByLastname(String lastname);
|
||||
|
||||
}
|
||||
@@ -0,0 +1,4 @@
|
||||
spring.cassandra.contact-points=${CASSANDRA_HOST:127.0.0.1}:${CASSANDRA_PORT_9042:9042}
|
||||
spring.cassandra.local-datacenter=datacenter1
|
||||
spring.cassandra.keyspace-name=example
|
||||
spring.cassandra.schema-action=recreate
|
||||
@@ -0,0 +1,14 @@
|
||||
package com.example.data.cassandra.reactive;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
|
||||
import org.springframework.boot.test.context.SpringBootTest;
|
||||
|
||||
@SpringBootTest
|
||||
class DataCassandraReactiveApplicationTests {
|
||||
|
||||
@Test
|
||||
void contextLoads() {
|
||||
}
|
||||
|
||||
}
|
||||
@@ -49,6 +49,7 @@ include "command-line-runner"
|
||||
include "conditional"
|
||||
include "configuration-properties"
|
||||
include "data-cassandra"
|
||||
include "data-cassandra-reactive"
|
||||
include "data-jdbc-h2"
|
||||
include "data-jdbc-postgresql"
|
||||
include "data-jpa"
|
||||
|
||||
Reference in New Issue
Block a user