Проблема в том, что метод @PostConstruct не вызывается во время тестов maven, но отлично работает, если я запускаю эти тесты в IDEA.
Почему он не вызывается во время тестов maven и как это исправить?
Мой тестовый класс:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = {AppConfig.class, DBConfig.class})
@WebAppConfiguration
public class SecurityTest {
@Autowired
private WebApplicationContext context;
private MockMvc mockMvc;
@Before
public void setup() {
mockMvc = MockMvcBuilders
.webAppContextSetup(context)
.apply(springSecurity())
.build();
}
@Test
public void openLibraryPage() throws Exception {
mockMvc.perform(get("/books")
.with(httpBasic("admin", "admin")))
.andDo(print())
.andExpect(status().is2xxSuccessful());
}
}
Класс, содержащий @PostConstruct(эта конфигурация работает нормально, и beans в этом классе инициализируются как в тестах maven, так и в тестах идей, просто метод @PostConstruct по какой-то причине не вызывается в тестах maven)
@Configuration
@ComponentScan("test.task")
public class DBConfig {
private static final Logger log = LogManager.getLogger(DBConfig.class);
@Autowired
private DataSource dataSource;
@PostConstruct
public void initializeDatabase() {
.. some code ..
}
@Bean
public DataSource dataSource() {
DriverManagerDataSource dataSource = new DriverManagerDataSource("jdbc:h2:mem:test-task;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE", "sa", "");
dataSource.setDriverClassName("org.h2.Driver");
return dataSource;
}
@Bean
public JdbcTemplate jdbcTemplate() {
return new JdbcTemplate(dataSource);
}
}
и мой pom.xml
<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>test.task</groupId>
<artifactId>library</artifactId>
<version>1.0.0</version>
<packaging>war</packaging>
<properties>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>3.1.0</version>
<executions>
<execution>
<id>default-war</id>
<phase>prepare-package</phase>
<configuration>
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<version>1.4.197</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.0.1.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.0.1.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.0.1.RELEASE</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>5.0.1.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-config</artifactId>
<version>5.0.1.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-web</artifactId>
<version>5.0.1.RELEASE</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
</dependency>
<dependency>
<groupId>org.springframework.security</groupId>
<artifactId>spring-security-test</artifactId>
<version>5.0.1.RELEASE</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.11.1</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>2.11.1</version>
</dependency>
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>javax.servlet.jsp-api</artifactId>
<version>2.3.1</version>
</dependency>
<dependency>
<groupId>org.thymeleaf</groupId>
<artifactId>thymeleaf-spring5</artifactId>
<version>3.0.9.RELEASE</version>
</dependency>
<dependency>
<groupId>org.liquibase</groupId>
<artifactId>liquibase-core</artifactId>
<version>3.6.2</version>
</dependency>
</dependencies>
</project>
# ОБНОВЛЕНИЕ 1
Добавил DBConfig.class в @ContextConfiguration, ничего не изменилось.




При запуске теста вы просто загружаете AppConfig в контекст. И похоже, что DBConfig не загружен в контекст, что является причиной того, что метод initializeDatabase не вызывается.
Чтобы он заработал, должен быть загружен DBConfig,
@ContextConfiguration(classes = {AppConfig.class, DBConfig.class})
@SpringBootTest (классы = {AppConfig.class, DBConfig.class}). Не могли бы вы попробовать это?
Я пробовал это, но ничего не изменилось
У меня была такая же проблема, и для меня это было потому, что следующая зависимость не была в пути к классам:
<!-- https://mvnrepository.com/artifact/javax.annotation/javax.annotation-api -->
<dependency>
<groupId>javax.annotation</groupId>
<artifactId>javax.annotation-api</artifactId>
<version>1.3.2</version>
</dependency>
Используют ли IntelliJ и Maven одну и ту же версию Java? Возможно, IntelliJ использует Java <9, поэтому он работает, а Maven использует Java> = 9 и, следовательно, нуждается в упомянутой мной зависимости.
Спасибо за ответ. Если вы нашли ответ в другом сообщении StackOverflow, можно пометить его как «дубликат».
Версии были те же (java 8), но это все равно помогло
Я попробовал, но ничего не изменилось. Кроме того, бины из
DBConfig, похоже, нормально инициализируются без добавленияDBConfig.classв@ContextConfiguration.