* JAVA-14288 Rename spring-5-reactive-modules to spring-reactive-modules * JAVA-14288 Remove failing module * JAVA-14288 Revert commenting spring-cloud-openfeign-2 module
125 lines
3.2 KiB
Java
125 lines
3.2 KiB
Java
package com.baeldung.r2dbc;
|
|
|
|
|
|
import com.baeldung.r2dbc.model.Player;
|
|
import com.baeldung.r2dbc.repository.PlayerRepository;
|
|
import io.r2dbc.h2.H2ConnectionFactory;
|
|
import org.junit.Before;
|
|
import org.junit.Test;
|
|
import org.junit.runner.RunWith;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.boot.test.context.SpringBootTest;
|
|
import org.springframework.data.r2dbc.core.DatabaseClient;
|
|
import org.springframework.test.context.junit4.SpringRunner;
|
|
import reactor.core.publisher.Flux;
|
|
import reactor.core.publisher.Hooks;
|
|
import reactor.core.publisher.Mono;
|
|
import reactor.test.StepVerifier;
|
|
|
|
import java.util.Arrays;
|
|
import java.util.List;
|
|
|
|
@RunWith(SpringRunner.class)
|
|
@SpringBootTest
|
|
public class R2dbcApplicationIntegrationTest {
|
|
|
|
|
|
@Autowired
|
|
PlayerRepository playerRepository;
|
|
|
|
@Autowired
|
|
DatabaseClient client;
|
|
|
|
@Autowired
|
|
H2ConnectionFactory factory;
|
|
|
|
|
|
@Before
|
|
public void setup() {
|
|
|
|
Hooks.onOperatorDebug();
|
|
|
|
List<String> statements = Arrays.asList(//
|
|
"DROP TABLE IF EXISTS player;",
|
|
"CREATE table player (id INT AUTO_INCREMENT NOT NULL, name VARCHAR2, age INT NOT NULL);");
|
|
|
|
statements.forEach(it -> client.execute(it) //
|
|
.fetch() //
|
|
.rowsUpdated() //
|
|
.as(StepVerifier::create) //
|
|
.expectNextCount(1) //
|
|
.verifyComplete());
|
|
|
|
}
|
|
|
|
@Test
|
|
public void whenDeleteAll_then0IsExpected() {
|
|
|
|
|
|
playerRepository.deleteAll()
|
|
.as(StepVerifier::create)
|
|
.expectNextCount(0)
|
|
.verifyComplete();
|
|
}
|
|
|
|
@Test
|
|
public void whenInsert6_then6AreExpected() {
|
|
|
|
insertPlayers();
|
|
|
|
playerRepository.findAll()
|
|
.as(StepVerifier::create)
|
|
.expectNextCount(6)
|
|
.verifyComplete();
|
|
}
|
|
|
|
@Test
|
|
public void whenSearchForCR7_then1IsExpected() {
|
|
|
|
insertPlayers();
|
|
|
|
playerRepository.findAllByName("CR7")
|
|
.as(StepVerifier::create)
|
|
.expectNextCount(1)
|
|
.verifyComplete();
|
|
}
|
|
|
|
@Test
|
|
public void whenSearchFor32YearsOld_then2AreExpected() {
|
|
insertPlayers();
|
|
|
|
playerRepository.findByAge(32)
|
|
.as(StepVerifier::create)
|
|
.expectNextCount(2)
|
|
.verifyComplete();
|
|
}
|
|
|
|
@Test
|
|
public void whenBatchHas2Operations_then2AreExpected() {
|
|
Mono.from(factory.create())
|
|
.flatMapMany(connection -> Flux.from(connection
|
|
.createBatch()
|
|
.add("select * from player")
|
|
.add("select * from player")
|
|
.execute()))
|
|
.as(StepVerifier::create)
|
|
.expectNextCount(2)
|
|
.verifyComplete();
|
|
|
|
}
|
|
|
|
private void insertPlayers() {
|
|
List<Player> players = Arrays.asList(
|
|
new Player(null, "Kaka", 37),
|
|
new Player(null, "Messi", 32),
|
|
new Player(null, "Mbappé", 20),
|
|
new Player(null, "CR7", 34),
|
|
new Player(null, "Lewandowski", 30),
|
|
new Player(null, "Cavani", 32)
|
|
);
|
|
|
|
playerRepository.saveAll(players).subscribe();
|
|
}
|
|
}
|
|
|