@ContextConfiguration annotation has 'inheritLocations' and 'inheritInitializers' elements which specify whether configuration locations (config classes/resources) and context initializers declared by superclasses should be inherited. By default both flags are true. That means a test subclass inherits both the config locations as well as the context initializers declared by any superclasses. Let's understand that with examples.
Using default i.e. inheritLocations=true and inheritInitializers=true
A Spring application
package com.logicbig.example;
import org.springframework.stereotype.Service;
@Service
public interface CustomerService {
String getCustomerById(String id);
}
package com.logicbig.example;
import org.springframework.stereotype.Service;
@Service
public interface OrderService {
String getOrdersForCustomer(String customerId);
}
package com.logicbig.example;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class AppConfig {
@Bean
public CustomerService customerService() {
return new CustomerService() {
@Override
public String getCustomerById(String id) {
return "Customer " + id;
}
};
}
}
package com.logicbig.example;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class AppConfigExtended {
@Bean
public OrderService orderService() {
return new OrderService() {
@Override
public String getOrdersForCustomer(String customerId) {
return "orders for customer " + customerId;
}
};
}
}
Test Folder
package com.logicbig.example;
import org.springframework.context.ApplicationContextInitializer;
import org.springframework.context.ConfigurableApplicationContext;
public class MyContextInitializer implements
ApplicationContextInitializer<ConfigurableApplicationContext> {
@Override
public void initialize(ConfigurableApplicationContext ac) {
System.out.println("-- in context initializer --");
}
}
The Test classes
package com.logicbig.example;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.util.Assert;
@ContextConfiguration(classes = AppConfig.class,
initializers = MyContextInitializer.class)
public class BaseServiceTests {
@Autowired
private CustomerService customerService;
@Test
public void testCustomerById() {
String customer = customerService.getCustomerById("323");
System.out.println("-- CustomerById test --");
System.out.println(customer);
Assert.notNull(customer, "customer is null for id 323");
}
}
package com.logicbig.example;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit.jupiter.SpringExtension;
import org.springframework.util.Assert;
@ExtendWith(SpringExtension.class)
@ContextConfiguration(classes = AppConfigExtended.class)
public class ExtendedServiceTests extends BaseServiceTests {
@Autowired
private OrderService orderService;
@Test
public void testOrderCustomer() {
String orders = orderService.getOrdersForCustomer("323");
System.out.println("-- OrdersByCustomer test --");
System.out.println(orders);
Assert.notNull(orders, "Orders is null for id 323");
}
}
Setting inheritLocations = false and inheritInitializers = false
With the same above Spring application, let's don't inherit config locations (the config class) from the super class by setting inheritLocations=false. We will also provide an alternative configuration which will replace the super class's one.
package com.logicbig.example;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.util.Assert;
@ContextConfiguration(
inheritLocations = false,
inheritInitializers = false,
classes = {
AppConfigExtended.class, OtherAppConfig.class
})
public class ExtendedServiceTests extends BaseServiceTests {
@Autowired
private OrderService orderService;
.............
}
package com.logicbig.example;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class OtherAppConfig {
@Bean
public CustomerService customerService() {
return new CustomerService() {
@Override
public String getCustomerById(String id) {
return "Other Customer " + id;
}
};
}
}
Running ExtendedServiceTests
Example ProjectDependencies and Technologies Used: - spring-context 7.0.4 (Spring Context)
Version Compatibility: 5.0.0.RELEASE - 7.0.4 Version compatibilities of spring-context with this example: Versions in green have been tested.
- spring-test 7.0.4 (Spring TestContext Framework)
- junit-jupiter-engine 6.0.2 (Module "junit-jupiter-engine" of JUnit)
- JDK 25
- Maven 3.9.11
|