Merge pull request #15172 from lucaCambi77/BAEL-7110
[BAEL-7110] Overriding Spring Beans in Integration Test
This commit is contained in:
commit
c3d48cebf1
|
@ -0,0 +1,13 @@
|
|||
package com.baeldung.overridebean;
|
||||
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
|
||||
@Configuration
|
||||
public class Config {
|
||||
|
||||
@Bean
|
||||
public Service helloWorld() {
|
||||
return new ServiceImpl();
|
||||
}
|
||||
}
|
|
@ -0,0 +1,19 @@
|
|||
package com.baeldung.overridebean;
|
||||
|
||||
import org.springframework.web.bind.annotation.GetMapping;
|
||||
import org.springframework.web.bind.annotation.RestController;
|
||||
|
||||
@RestController
|
||||
public class Endpoint {
|
||||
|
||||
private final Service service;
|
||||
|
||||
public Endpoint(Service service) {
|
||||
this.service = service;
|
||||
}
|
||||
|
||||
@GetMapping("/hello")
|
||||
public String helloWorldEndpoint() {
|
||||
return service.helloWorld();
|
||||
}
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
package com.baeldung.overridebean;
|
||||
|
||||
public interface Service {
|
||||
String helloWorld();
|
||||
}
|
|
@ -0,0 +1,8 @@
|
|||
package com.baeldung.overridebean;
|
||||
|
||||
public class ServiceImpl implements Service {
|
||||
|
||||
public String helloWorld() {
|
||||
return "hello world";
|
||||
}
|
||||
}
|
|
@ -0,0 +1,14 @@
|
|||
package com.baeldung.overridebean.boot;
|
||||
|
||||
import org.springframework.boot.SpringApplication;
|
||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||
import org.springframework.boot.autoconfigure.security.oauth2.resource.servlet.OAuth2ResourceServerAutoConfiguration;
|
||||
import org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration;
|
||||
|
||||
@SpringBootApplication(exclude = { SecurityAutoConfiguration.class, OAuth2ResourceServerAutoConfiguration.class })
|
||||
public class Application {
|
||||
|
||||
public static void main(String[] args) {
|
||||
SpringApplication.run(Application.class, args);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,18 @@
|
|||
package com.baeldung.overridebean.conditional;
|
||||
|
||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
|
||||
import com.baeldung.overridebean.Service;
|
||||
import com.baeldung.overridebean.ServiceImpl;
|
||||
|
||||
@Configuration
|
||||
public class ConditionalConfig {
|
||||
|
||||
@Bean
|
||||
@ConditionalOnProperty(name = "service.stub", havingValue = "false")
|
||||
public Service helloWorld() {
|
||||
return new ServiceImpl();
|
||||
}
|
||||
}
|
|
@ -0,0 +1,18 @@
|
|||
package com.baeldung.overridebean.profile;
|
||||
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
import org.springframework.context.annotation.Profile;
|
||||
|
||||
import com.baeldung.overridebean.Service;
|
||||
import com.baeldung.overridebean.ServiceImpl;
|
||||
|
||||
@Configuration
|
||||
@Profile("prod")
|
||||
public class ProfileConfig {
|
||||
|
||||
@Bean
|
||||
public Service helloWorld() {
|
||||
return new ServiceImpl();
|
||||
}
|
||||
}
|
|
@ -1,2 +1,3 @@
|
|||
keycloak.enabled=true
|
||||
spring.security.oauth2.resourceserver.jwt.issuer-uri=http://localhost:8180/auth/realms/baeldung-api
|
||||
service.stub=false
|
|
@ -0,0 +1,30 @@
|
|||
package com.baeldung.overridebean.conditional;
|
||||
|
||||
import static org.hamcrest.Matchers.containsString;
|
||||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
|
||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
|
||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
||||
import org.springframework.boot.test.context.SpringBootTest;
|
||||
import org.springframework.test.web.servlet.MockMvc;
|
||||
|
||||
import com.baeldung.overridebean.Endpoint;
|
||||
import com.baeldung.overridebean.boot.Application;
|
||||
|
||||
@SpringBootTest(classes = { Application.class, ConditionalConfig.class, Endpoint.class, ConditionalTestConfig.class }, properties = "service.stub=true")
|
||||
@AutoConfigureMockMvc
|
||||
class ConditionIntegrationTest {
|
||||
|
||||
@Autowired
|
||||
private MockMvc mockMvc;
|
||||
|
||||
@Test
|
||||
void givenConditionalConfig_whenServiceStubIsTrue_thenStubOk() throws Exception {
|
||||
this.mockMvc.perform(get("/hello"))
|
||||
.andExpect(status().isOk())
|
||||
.andExpect(content().string(containsString("hello conditional stub")));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,10 @@
|
|||
package com.baeldung.overridebean.conditional;
|
||||
|
||||
import com.baeldung.overridebean.Service;
|
||||
|
||||
public class ConditionalStub implements Service {
|
||||
|
||||
public String helloWorld() {
|
||||
return "hello conditional stub";
|
||||
}
|
||||
}
|
|
@ -0,0 +1,17 @@
|
|||
package com.baeldung.overridebean.conditional;
|
||||
|
||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
|
||||
import org.springframework.boot.test.context.TestConfiguration;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
|
||||
import com.baeldung.overridebean.Service;
|
||||
|
||||
@TestConfiguration
|
||||
public class ConditionalTestConfig {
|
||||
|
||||
@Bean
|
||||
@ConditionalOnProperty(name = "service.stub", havingValue = "true")
|
||||
public Service helloWorld() {
|
||||
return new ConditionalStub();
|
||||
}
|
||||
}
|
|
@ -0,0 +1,37 @@
|
|||
package com.baeldung.overridebean.mockbean;
|
||||
|
||||
import static org.hamcrest.Matchers.containsString;
|
||||
import static org.mockito.Mockito.when;
|
||||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
|
||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
|
||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
||||
import org.springframework.boot.test.context.SpringBootTest;
|
||||
import org.springframework.boot.test.mock.mockito.MockBean;
|
||||
import org.springframework.test.web.servlet.MockMvc;
|
||||
|
||||
import com.baeldung.overridebean.Endpoint;
|
||||
import com.baeldung.overridebean.Service;
|
||||
import com.baeldung.overridebean.boot.Application;
|
||||
|
||||
@SpringBootTest(classes = { Application.class, Endpoint.class })
|
||||
@AutoConfigureMockMvc
|
||||
class MockBeanIntegrationTest {
|
||||
|
||||
@Autowired
|
||||
private MockMvc mockMvc;
|
||||
|
||||
@MockBean
|
||||
private Service service;
|
||||
|
||||
@Test
|
||||
void givenServiceMockBean_whenGetHelloEndpoint_thenMockOk() throws Exception {
|
||||
when(service.helloWorld()).thenReturn("hello mock bean");
|
||||
this.mockMvc.perform(get("/hello"))
|
||||
.andExpect(status().isOk())
|
||||
.andExpect(content().string(containsString("hello mock bean")));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,31 @@
|
|||
package com.baeldung.overridebean.overridebeandefinition;
|
||||
|
||||
import static org.hamcrest.Matchers.containsString;
|
||||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
|
||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
|
||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
||||
import org.springframework.boot.test.context.SpringBootTest;
|
||||
import org.springframework.test.web.servlet.MockMvc;
|
||||
|
||||
import com.baeldung.overridebean.Config;
|
||||
import com.baeldung.overridebean.Endpoint;
|
||||
import com.baeldung.overridebean.boot.Application;
|
||||
|
||||
@SpringBootTest(classes = { Application.class, Config.class, Endpoint.class, OverrideBeanDefinitionTestConfig.class }, properties = "spring.main.allow-bean-definition-overriding=true")
|
||||
@AutoConfigureMockMvc
|
||||
class OverrideBeanDefinitionIntegrationTest {
|
||||
|
||||
@Autowired
|
||||
private MockMvc mockMvc;
|
||||
|
||||
@Test
|
||||
void givenNoProfile_whenAllowBeanDefinitionOverriding_thenStubOk() throws Exception {
|
||||
this.mockMvc.perform(get("/hello"))
|
||||
.andExpect(status().isOk())
|
||||
.andExpect(content().string(containsString("hello no profile stub")));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,10 @@
|
|||
package com.baeldung.overridebean.overridebeandefinition;
|
||||
|
||||
import com.baeldung.overridebean.Service;
|
||||
|
||||
public class OverrideBeanDefinitionServiceStub implements Service {
|
||||
|
||||
public String helloWorld() {
|
||||
return "hello no profile stub";
|
||||
}
|
||||
}
|
|
@ -0,0 +1,15 @@
|
|||
package com.baeldung.overridebean.overridebeandefinition;
|
||||
|
||||
import org.springframework.boot.test.context.TestConfiguration;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
|
||||
import com.baeldung.overridebean.Service;
|
||||
|
||||
@TestConfiguration
|
||||
public class OverrideBeanDefinitionTestConfig {
|
||||
|
||||
@Bean
|
||||
public Service helloWorld() {
|
||||
return new OverrideBeanDefinitionServiceStub();
|
||||
}
|
||||
}
|
|
@ -0,0 +1,31 @@
|
|||
package com.baeldung.overridebean.primary;
|
||||
|
||||
import static org.hamcrest.Matchers.containsString;
|
||||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
|
||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
|
||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
||||
import org.springframework.boot.test.context.SpringBootTest;
|
||||
import org.springframework.test.web.servlet.MockMvc;
|
||||
|
||||
import com.baeldung.overridebean.Config;
|
||||
import com.baeldung.overridebean.Endpoint;
|
||||
import com.baeldung.overridebean.boot.Application;
|
||||
|
||||
@SpringBootTest(classes = { Application.class, Config.class, Endpoint.class, PrimaryTestConfig.class })
|
||||
@AutoConfigureMockMvc
|
||||
class PrimaryIntegrationTest {
|
||||
|
||||
@Autowired
|
||||
private MockMvc mockMvc;
|
||||
|
||||
@Test
|
||||
void givenTestConfiguration_whenPrimaryBeanIsDefined_thenStubOk() throws Exception {
|
||||
this.mockMvc.perform(get("/hello"))
|
||||
.andExpect(status().isOk())
|
||||
.andExpect(content().string(containsString("hello primary stub")));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,10 @@
|
|||
package com.baeldung.overridebean.primary;
|
||||
|
||||
import com.baeldung.overridebean.Service;
|
||||
|
||||
public class PrimaryServiceStub implements Service {
|
||||
|
||||
public String helloWorld() {
|
||||
return "hello primary stub";
|
||||
}
|
||||
}
|
|
@ -0,0 +1,17 @@
|
|||
package com.baeldung.overridebean.primary;
|
||||
|
||||
import org.springframework.boot.test.context.TestConfiguration;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Primary;
|
||||
|
||||
import com.baeldung.overridebean.Service;
|
||||
|
||||
@TestConfiguration
|
||||
public class PrimaryTestConfig {
|
||||
|
||||
@Primary
|
||||
@Bean("service.stub")
|
||||
public Service helloWorld() {
|
||||
return new PrimaryServiceStub();
|
||||
}
|
||||
}
|
|
@ -0,0 +1,38 @@
|
|||
package com.baeldung.overridebean.profile;
|
||||
|
||||
import static org.hamcrest.Matchers.containsString;
|
||||
import static org.mockito.Mockito.when;
|
||||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
|
||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
|
||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
||||
import org.springframework.boot.test.context.SpringBootTest;
|
||||
import org.springframework.test.context.ActiveProfiles;
|
||||
import org.springframework.test.web.servlet.MockMvc;
|
||||
|
||||
import com.baeldung.overridebean.Endpoint;
|
||||
import com.baeldung.overridebean.Service;
|
||||
import com.baeldung.overridebean.boot.Application;
|
||||
|
||||
@SpringBootTest(classes = { Application.class, ProfileConfig.class, Endpoint.class, ProfileTestConfig.class })
|
||||
@AutoConfigureMockMvc
|
||||
@ActiveProfiles("mock")
|
||||
class ProfileMockIntegrationTest {
|
||||
|
||||
@Autowired
|
||||
private MockMvc mockMvc;
|
||||
|
||||
@Autowired
|
||||
private Service service;
|
||||
|
||||
@Test
|
||||
void givenConfigurationWithProfile_whenTestProfileIsActive_thenMockOk() throws Exception {
|
||||
when(service.helloWorld()).thenReturn("hello profile mock");
|
||||
this.mockMvc.perform(get("/hello"))
|
||||
.andExpect(status().isOk())
|
||||
.andExpect(content().string(containsString("hello profile mock")));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,10 @@
|
|||
package com.baeldung.overridebean.profile;
|
||||
|
||||
import com.baeldung.overridebean.Service;
|
||||
|
||||
public class ProfileServiceStub implements Service {
|
||||
|
||||
public String helloWorld() {
|
||||
return "hello profile stub";
|
||||
}
|
||||
}
|
|
@ -0,0 +1,32 @@
|
|||
package com.baeldung.overridebean.profile;
|
||||
|
||||
import static org.hamcrest.Matchers.containsString;
|
||||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
|
||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
|
||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;
|
||||
import org.springframework.boot.test.context.SpringBootTest;
|
||||
import org.springframework.test.context.ActiveProfiles;
|
||||
import org.springframework.test.web.servlet.MockMvc;
|
||||
|
||||
import com.baeldung.overridebean.Endpoint;
|
||||
import com.baeldung.overridebean.boot.Application;
|
||||
|
||||
@SpringBootTest(classes = { Application.class, ProfileConfig.class, Endpoint.class, ProfileTestConfig.class })
|
||||
@AutoConfigureMockMvc
|
||||
@ActiveProfiles("stub")
|
||||
class ProfileStubIntegrationTest {
|
||||
|
||||
@Autowired
|
||||
private MockMvc mockMvc;
|
||||
|
||||
@Test
|
||||
void givenConfigurationWithProfile_whenTestProfileIsActive_thenStubOk() throws Exception {
|
||||
this.mockMvc.perform(get("/hello"))
|
||||
.andExpect(status().isOk())
|
||||
.andExpect(content().string(containsString("hello profile stub")));
|
||||
}
|
||||
}
|
|
@ -0,0 +1,25 @@
|
|||
package com.baeldung.overridebean.profile;
|
||||
|
||||
import static org.mockito.Mockito.mock;
|
||||
|
||||
import org.springframework.boot.test.context.TestConfiguration;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Profile;
|
||||
|
||||
import com.baeldung.overridebean.Service;
|
||||
|
||||
@TestConfiguration
|
||||
public class ProfileTestConfig {
|
||||
|
||||
@Bean
|
||||
@Profile("stub")
|
||||
public Service helloWorldStub() {
|
||||
return new ProfileServiceStub();
|
||||
}
|
||||
|
||||
@Bean
|
||||
@Profile("mock")
|
||||
public Service helloWorldMock() {
|
||||
return mock(Service.class);
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue