[JAVA-32077] Fix broken spring-boot-graphql module integration tests. (#16026)

This commit is contained in:
Harry9656 2024-03-04 21:59:42 +01:00 committed by GitHub
parent 2a48b85f4d
commit a92756154d
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
13 changed files with 60 additions and 50 deletions

View File

@ -41,7 +41,7 @@
<module>spring-boot-environment</module> <module>spring-boot-environment</module>
<module>spring-boot-exceptions</module> <module>spring-boot-exceptions</module>
<module>spring-boot-flowable</module> <module>spring-boot-flowable</module>
<!-- <module>spring-boot-graphql</module>--> <!-- failing after upgrading to spring boot 3.2.x --> <module>spring-boot-graphql</module>
<!--<module>spring-boot-groovy</module>--> <!-- failing after upgrading to jdk17--> <!--<module>spring-boot-groovy</module>--> <!-- failing after upgrading to jdk17-->
<!-- <module>spring-boot-gradle</module> --> <!-- Not a maven project --> <!-- <module>spring-boot-gradle</module> --> <!-- Not a maven project -->
<module>spring-boot-jasypt</module> <module>spring-boot-jasypt</module>

View File

@ -119,6 +119,7 @@
<os-maven-plugin.version>1.6.2</os-maven-plugin.version> <os-maven-plugin.version>1.6.2</os-maven-plugin.version>
<maven-war-plugin.version>3.3.2</maven-war-plugin.version> <maven-war-plugin.version>3.3.2</maven-war-plugin.version>
<os-maven-plugin.version>1.7.0</os-maven-plugin.version> <os-maven-plugin.version>1.7.0</os-maven-plugin.version>
<start-class>com.baeldung.chooseapi.ChooseApiApp</start-class>
</properties> </properties>
</project> </project>

View File

@ -35,9 +35,9 @@ public class VehicleController {
} }
@MutationMapping @MutationMapping
public Vehicle addVehicle(@Argument String vin, @Argument Integer year, public Vehicle addVehicle(@Argument("vin") String vin, @Argument("year") Integer year,
@Argument String make, @Argument String model, @Argument String trim, @Argument("make") String make, @Argument("model") String model, @Argument("trim") String trim,
@Argument Location location) { @Argument("location") Location location) {
return this.inventoryService.addVehicle(vin, year, make, model, trim, location); return this.inventoryService.addVehicle(vin, year, make, model, trim, location);
} }
} }

View File

@ -5,10 +5,10 @@ import lombok.Builder;
import lombok.Data; import lombok.Data;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import javax.persistence.Entity; import jakarta.persistence.Entity;
import javax.persistence.FetchType; import jakarta.persistence.FetchType;
import javax.persistence.Id; import jakarta.persistence.Id;
import javax.persistence.OneToMany; import jakarta.persistence.OneToMany;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
@ -20,7 +20,6 @@ import java.util.List;
public class Location { public class Location {
@Id @Id
private String zipcode; private String zipcode;
private String city; private String city;
private String state; private String state;

View File

@ -1,11 +1,15 @@
package com.baeldung.graphql.error.handling.domain; package com.baeldung.graphql.error.handling.domain;
import jakarta.persistence.Entity;
import jakarta.persistence.FetchType;
import jakarta.persistence.Id;
import jakarta.persistence.JoinColumn;
import jakarta.persistence.ManyToOne;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
import lombok.Builder; import lombok.Builder;
import lombok.Data; import lombok.Data;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import javax.persistence.*;
@Data @Data
@Entity @Entity

View File

@ -4,10 +4,6 @@ import java.util.Map;
public class VehicleAlreadyPresentException extends AbstractGraphQLException { public class VehicleAlreadyPresentException extends AbstractGraphQLException {
public VehicleAlreadyPresentException(String message) {
super(message);
}
public VehicleAlreadyPresentException(String message, Map<String, Object> additionParams) { public VehicleAlreadyPresentException(String message, Map<String, Object> additionParams) {
super(message, additionParams); super(message, additionParams);
} }

View File

@ -1,5 +1,14 @@
package com.baeldung.graphql.error.handling.service; package com.baeldung.graphql.error.handling.service;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import org.springframework.stereotype.Service;
import org.springframework.util.StringUtils;
import com.baeldung.graphql.error.handling.domain.Location; import com.baeldung.graphql.error.handling.domain.Location;
import com.baeldung.graphql.error.handling.domain.Vehicle; import com.baeldung.graphql.error.handling.domain.Vehicle;
import com.baeldung.graphql.error.handling.exception.InvalidInputException; import com.baeldung.graphql.error.handling.exception.InvalidInputException;
@ -7,11 +16,8 @@ import com.baeldung.graphql.error.handling.exception.VehicleAlreadyPresentExcept
import com.baeldung.graphql.error.handling.exception.VehicleNotFoundException; import com.baeldung.graphql.error.handling.exception.VehicleNotFoundException;
import com.baeldung.graphql.error.handling.repository.InventoryRepository; import com.baeldung.graphql.error.handling.repository.InventoryRepository;
import com.baeldung.graphql.error.handling.repository.LocationRepository; import com.baeldung.graphql.error.handling.repository.LocationRepository;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Service;
import javax.transaction.Transactional; import jakarta.transaction.Transactional;
import java.util.*;
@Service @Service
public class InventoryService { public class InventoryService {
@ -49,7 +55,7 @@ public class InventoryService {
} }
public List<Vehicle> searchByLocation(String zipcode) { public List<Vehicle> searchByLocation(String zipcode) {
if (StringUtils.isEmpty(zipcode) || zipcode.length() != 5) { if (StringUtils.hasText(zipcode) || zipcode.length() != 5) {
throw new InvalidInputException("Invalid zipcode " + zipcode + " provided."); throw new InvalidInputException("Invalid zipcode " + zipcode + " provided.");
} }
return this.locationRepository.findById(zipcode) return this.locationRepository.findById(zipcode)

View File

@ -6,10 +6,8 @@ import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration; import org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration;
import org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration; import org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration;
@SpringBootApplication @SpringBootApplication(exclude = {
@EnableAutoConfiguration(exclude = { SecurityAutoConfiguration.class
SecurityAutoConfiguration.class,
HibernateJpaAutoConfiguration.class
}) })
public class GraphqlApplication { public class GraphqlApplication {

View File

@ -10,8 +10,6 @@ spring:
driverClassName: "org.h2.Driver" driverClassName: "org.h2.Driver"
username: sa username: sa
password: password:
initialization-mode: always
platform: h2
jpa: jpa:
show-sql: true show-sql: true
properties: properties:
@ -19,6 +17,11 @@ spring:
dialect: org.hibernate.dialect.H2Dialect dialect: org.hibernate.dialect.H2Dialect
ddl-auto: none ddl-auto: none
globally_quoted_identifiers: true globally_quoted_identifiers: true
defer-datasource-initialization: true
h2: h2:
console.enabled: true console.enabled: true
sql:
init:
platform: h2
mode: always

View File

@ -1,6 +1,6 @@
insert into "location" values('07092', 'Mountainside', 'NJ'); insert into "location" ("zipcode", "city", "state") values ('07092', 'Mountainside', 'NJ');
insert into "location" values ('94118', 'San Francisco', 'CA'); insert into "location" ("zipcode", "city", "state") values ('94118', 'San Francisco', 'CA');
insert into "location" values ('10002', 'New York', 'NY'); insert into "location" ("zipcode", "city", "state") values ('10002', 'New York', 'NY');
insert into "vehicle" ("vin", "year", "make", "model", "trim", "fk_location") values('KM8JN72DX7U587496', 2007, 'Hyundai', 'Tucson', null, '07092'); insert into "vehicle" ("vin", "year", "make", "model", "trim", "fk_location") values('KM8JN72DX7U587496', 2007, 'Hyundai', 'Tucson', null, '07092');
insert into "vehicle" ("vin", "year", "make", "model", "trim", "fk_location") values('JTKKU4B41C1023346', 2012, 'Toyota', 'Scion', 'Xd', '94118'); insert into "vehicle" ("vin", "year", "make", "model", "trim", "fk_location") values('JTKKU4B41C1023346', 2012, 'Toyota', 'Scion', 'Xd', '94118');

View File

@ -1,20 +1,22 @@
package com.baeldung.chooseapi.controllers; package com.baeldung.chooseapi.controllers;
import com.baeldung.chooseapi.ChooseApiApp;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.graphql.test.tester.HttpGraphQlTester;
import org.springframework.test.context.ActiveProfiles;
import java.nio.file.Files; import java.nio.file.Files;
import java.nio.file.Path; import java.nio.file.Path;
import java.nio.file.Paths; import java.nio.file.Paths;
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT, import org.junit.jupiter.api.Test;
properties = { "grpc.server.port=-1" }, // Disable gRPC external server import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.graphql.tester.AutoConfigureHttpGraphQlTester;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.graphql.test.tester.HttpGraphQlTester;
import org.springframework.test.context.ActiveProfiles;
import com.baeldung.chooseapi.ChooseApiApp;
@SpringBootTest(properties = { "grpc.server.port=-1" }, // Disable gRPC external server
classes = ChooseApiApp.class) classes = ChooseApiApp.class)
@ActiveProfiles("chooseapi") @ActiveProfiles("chooseapi")
@AutoConfigureHttpGraphQlTester
class BooksControllerGraphQLIntegrationTest { class BooksControllerGraphQLIntegrationTest {
@Autowired @Autowired

View File

@ -1,24 +1,25 @@
package com.baeldung.graphql.error.handling; package com.baeldung.graphql.error.handling;
import org.junit.jupiter.api.Test; import static graphql.ErrorType.NullValueInNonNullableField;
import org.springframework.beans.factory.annotation.Autowired; import static org.springframework.graphql.execution.ErrorType.INTERNAL_ERROR;
import org.springframework.boot.test.context.SpringBootTest; import static org.springframework.graphql.execution.ErrorType.NOT_FOUND;
import org.springframework.boot.test.context.SpringBootTest.WebEnvironment;
import org.springframework.graphql.test.tester.HttpGraphQlTester;
import org.springframework.test.context.ActiveProfiles;
import java.io.IOException; import java.io.IOException;
import java.nio.file.Files; import java.nio.file.Files;
import java.nio.file.Path; import java.nio.file.Path;
import java.nio.file.Paths; import java.nio.file.Paths;
import static graphql.ErrorType.NullValueInNonNullableField; import org.junit.jupiter.api.Test;
import static org.springframework.graphql.execution.ErrorType.INTERNAL_ERROR; import org.springframework.beans.factory.annotation.Autowired;
import static org.springframework.graphql.execution.ErrorType.NOT_FOUND; import org.springframework.boot.test.autoconfigure.graphql.tester.AutoConfigureHttpGraphQlTester;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.graphql.test.tester.HttpGraphQlTester;
import org.springframework.test.context.ActiveProfiles;
@SpringBootTest(webEnvironment = WebEnvironment.RANDOM_PORT, classes = GraphQLErrorHandlerApplication.class) @SpringBootTest(classes = GraphQLErrorHandlerApplication.class)
@ActiveProfiles("error-handling") @ActiveProfiles("error-handling")
public class GraphQLErrorHandlerIntegrationTest { @AutoConfigureHttpGraphQlTester
class GraphQLErrorHandlerIntegrationTest {
private static final String GRAPHQL_TEST_REQUEST_PATH = "src/test/resources/graphql-files/request/%s_request.graphql"; private static final String GRAPHQL_TEST_REQUEST_PATH = "src/test/resources/graphql-files/request/%s_request.graphql";
private static final String GRAPHQL_TEST_RESPONSE_PATH = "src/test/resources/graphql-files/response/%s_response.json"; private static final String GRAPHQL_TEST_RESPONSE_PATH = "src/test/resources/graphql-files/response/%s_response.json";

View File

@ -4,9 +4,9 @@ import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest; import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest(classes = GraphqlApplication.class) @SpringBootTest(classes = GraphqlApplication.class)
public class SpringContextTest { class SpringContextTest {
@Test @Test
public void whenSpringContextIsBootstrapped_thenNoExceptions() { void whenSpringContextIsBootstrapped_thenNoExceptions() {
} }
} }