As Marten mentioned, @IntegrationTest
should only be used when you need to test against the deployed Spring Boot application (e.g., deployed in an embedded Tomcat, Jetty, or Undertow container). So if your goal is to test your repository layer in isolation, you should not use @IntegrationTest
.
On the other hand, if your tests require specific Spring Boot functionality (in contrast to standard Spring Framework functionality, semantics, and defaults), then you will in fact want to annotate your test class with @SpringApplicationConfiguration
instead of @ContextConfiguration
. The reason is that @SpringApplicationConfiguration
preconfigures the SpringApplicationContextLoader
which is specific to Spring Boot.
Furthermore, if you want your repository layer integration tests to run faster (i.e., without the full overhead of Spring Boot), you may choose to exclude configuration classes annotated with @EnableAutoConfiguration
since that will auto-configure every candidate for auto-configuration found in the classpath. So, for example, if you just want to have Spring Boot auto-configure an embedded database and Spring Data JPA (with Hibernate as the JPA provider) along with entity scanning, you could compose your test configuration something like this:
@Configuration
@EnableJpaRepositories(basePackageClasses = UserRepository.class)
@EntityScan(basePackageClasses = User.class)
@Import({ DataSourceAutoConfiguration.class, HibernateJpaAutoConfiguration.class })
public class TestRepositoryConfig {}
And then use that configuration in your test class like this:
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = TestRepositoryConfig.class)
@Transactional
public class UserRepositoryTests { /* ... */ }
Regards,
Sam
p.s. You might find my answer to the following, related question useful as well: Disable security for unit tests with spring boot
SpringApplicationConfiguration
annotation not some arbitrary configuration you created. Also do you really need the@Integrationtest
? As that will start your application so that you can use aRestTemplate
or whatever to test your application. This is not what you seem to be doing or need. - M. Deinum@IntegrationTest
does? Judging from what you are trying to do it has nothing to do with an integration test, in the sense of Spring Boot. You are just writing a unit test for a repository, not an integration test. - M. Deinum@IntegrationTest
is for. So remove it, it also doesn't make sense to use the@SpringApplicationConfiguration
as you aren't passing an application class but just a mere configuration. Hence it is just a plain spring based test. - M. Deinum