From 9316f05d50b5e10c47c699a943e801c5a3366e1d Mon Sep 17 00:00:00 2001 From: Jakub Jedlicka Date: Thu, 12 Dec 2024 15:34:17 +0100 Subject: [PATCH] Refactor the test disabled by https://github.com/quarkusio/quarkus/issues/41292 The original test was based on serialization, which is no longer possible out of box. In quarkusio/quarkus#41292 was suggested use this modification to make the original code work. Now we checking if returned json, pageable item contains specific values. For more info see https://github.com/quarkusio/quarkus/issues/41292#issuecomment-2371862795 --- .../spring/data/primitivetypes/BookStore.java | 5 ++++- .../SpringDataCompositeEntityIT.java | 22 ++++++++++--------- 2 files changed, 16 insertions(+), 11 deletions(-) diff --git a/spring/spring-data/src/main/java/io/quarkus/ts/spring/data/primitivetypes/BookStore.java b/spring/spring-data/src/main/java/io/quarkus/ts/spring/data/primitivetypes/BookStore.java index 7bc26ac41..224f70419 100644 --- a/spring/spring-data/src/main/java/io/quarkus/ts/spring/data/primitivetypes/BookStore.java +++ b/spring/spring-data/src/main/java/io/quarkus/ts/spring/data/primitivetypes/BookStore.java @@ -1,5 +1,7 @@ package io.quarkus.ts.spring.data.primitivetypes; +import java.util.List; + import jakarta.enterprise.context.ApplicationScoped; import org.springframework.data.domain.Page; @@ -12,6 +14,7 @@ @ApplicationScoped public class BookStore implements PanacheRepository { public Page findPaged(Pageable pageable) { - return new PageImpl<>(this.findAll().page(pageable.getPageNumber(), pageable.getPageSize()).list()); + List list = this.findAll().list(); + return new PageImpl<>(list, pageable, list.size()); } } diff --git a/spring/spring-data/src/test/java/io/quarkus/ts/spring/data/primitivetypes/SpringDataCompositeEntityIT.java b/spring/spring-data/src/test/java/io/quarkus/ts/spring/data/primitivetypes/SpringDataCompositeEntityIT.java index 8b4b21d51..a994cfe12 100644 --- a/spring/spring-data/src/test/java/io/quarkus/ts/spring/data/primitivetypes/SpringDataCompositeEntityIT.java +++ b/spring/spring-data/src/test/java/io/quarkus/ts/spring/data/primitivetypes/SpringDataCompositeEntityIT.java @@ -9,12 +9,11 @@ import java.util.Arrays; import java.util.Collections; +import java.util.LinkedHashMap; import java.util.List; import java.util.Map; import org.junit.jupiter.api.Assertions; -import org.junit.jupiter.api.Disabled; -import org.junit.jupiter.api.Tag; import org.junit.jupiter.api.Test; import io.quarkus.test.scenarios.QuarkusScenario; @@ -98,18 +97,21 @@ void testJpaFieldsMapping() { } @Test - @Tag("QUARKUS-1521") - @Disabled("https://github.com/quarkusio/quarkus/issues/41292") - void ensureFieldPageableIsSerialized() { + void ensureFieldPageableContainsInfoAboutPage() { + int size = 2; + int page = 1; Response response = app.given() .accept("application/json") - .queryParam("size", "2") - .queryParam("page", "1") + .queryParam("size", size) + .queryParam("page", page) .when().get("/book/paged"); Assertions.assertEquals(200, response.statusCode()); - String pageable = response.body().jsonPath().get("pageable"); - Assertions.assertNotNull(pageable, - "Field 'pageable' of org.springframework.data.domain.PageImpl was not serialized"); + LinkedHashMap pageable = response.body().jsonPath().get("pageable"); + Assertions.assertNotNull(pageable, "Field 'pageable' should not be null"); + Assertions.assertEquals(true, pageable.get("paged"), + "The part of pageable response should contain paged equals to true"); + Assertions.assertEquals(size, pageable.get("pageSize"), "Element pageSize should be " + size); + Assertions.assertEquals(page, pageable.get("pageNumber"), "Element pageNumber should be " + page); } private Book updateBook(Book book) {