refactor: Moved exceptions into package `exceptions` - Aligned Code
[demos/kafka/chat] / src / test / java / de / juplo / kafka / chat / backend / AbstractConfigurationIT.java
index 53ad04e..1b4cf38 100644 (file)
@@ -10,6 +10,8 @@ import org.testcontainers.shaded.org.awaitility.Awaitility;
 
 import java.time.Duration;
 
+import static org.hamcrest.Matchers.endsWith;
+
 
 public abstract class AbstractConfigurationIT
 {
@@ -18,6 +20,7 @@ public abstract class AbstractConfigurationIT
   @Autowired
   WebTestClient webTestClient;
 
+
   @Test
   @DisplayName("The app starts, the data is restored and accessible")
   void testAppStartsDataIsRestoredAndAccessible()
@@ -79,4 +82,30 @@ public abstract class AbstractConfigurationIT
               .expectBody().jsonPath("$.text").isEqualTo("Hallo, ich heiße Peter!");
         });
   }
+
+  @Test
+  @DisplayName("A PUT-message for a non-existent chat-room yields 404 NOT FOUND")
+  void testNotFoundForPutMessageToNonExistentChatRoom()
+  {
+    String otherChatRoomId = "7f59ec77-832e-4a17-8d22-55ef46242c17";
+
+    Awaitility
+        .await()
+        .atMost(Duration.ofSeconds(15))
+        .untilAsserted(() ->
+            webTestClient
+                .put()
+                .uri(
+                    "http://localhost:{port}/{chatRoomId}/otto/66",
+                    port,
+                    otherChatRoomId)
+                .contentType(MediaType.TEXT_PLAIN)
+                .accept(MediaType.APPLICATION_JSON)
+                .bodyValue("The devil rules route 66")
+                .exchange()
+                .expectStatus().isNotFound()
+                .expectBody()
+                .jsonPath("$.type").value(endsWith("/problem/unknown-chatroom"))
+                .jsonPath("$.chatroomId").isEqualTo(otherChatRoomId));
+  }
 }