我有这个测试:
@RunWith(SpringRunner.class)
@DataJpaTest(excludeFilters = @Filter(type = FilterType.REGEX,
pattern = "io\\.rainrobot\\.adwisdom\\.repository\\.es\\..*"))
public class AskTest {
不应扫描此软件包中的存储库:io.rainrobot.adwisdom.repository.ex。*- 但是当我运行测试时,出现此错误:
Caused by: java.lang.IllegalArgumentException: Failed to create query for method public abstract org.springframework.data.domain.Page io.rainrobot.adwisdom.repository.es.AskElasticRepository.findByTitle(java.lang.String,org.springframework.data.domain.PageRequest)! No property title found for type Ask!
以下是配置:
@SpringBootApplication public class Application {
public static void main(String[] args) throws Exception {
SpringApplication.run(Application.class, args);
}}
@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(basePackages="io.rainrobot.adwisdom.repository.sql")
@EntityScan(basePackages = {"io.rainrobot.adwisdom.dto"},
basePackageClasses = {Jsr310JpaConverters.class})
public class JpaConfig {
}
@Configuration
@EnableElasticsearchRepositories(basePackages=
"io.rainrobot.adwisdom.repository.es")
@EntityScan(basePackages = {"io.rainrobot.adwisdom.dto"},
basePackageClasses = {Jsr310JpaConverters.class})
public class ElasticsearchCongifuration {
@Value("${elasticsearch.host:localhost}")
public String host;
@Value("${elasticsearch.port:9300}")
public int port;
@Bean
public Client client(){
TransportClient client = null;
try{
InetAddress inetAddress = InetAddress.getByName(host);
TransportAddress transportAddress
= new TransportAddress(inetAddress, port);
client = new PreBuiltTransportClient(Settings.EMPTY)
.addTransportAddress(transportAddress);
} catch (UnknownHostException e) { }
return client;
}
}
和application.properties:
# JPA config
spring.datasource.url=jdbc:mysql://localhost:3306/advisdom?useTimezone=true&serverTimezone=UTC&createDatabaseIfNotExist=true
spring.datasource.username=admin
spring.datasource.password=admin
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.jpa.show-sql=true
spring.jpa.generate-ddl=true
spring.jpa.hibernate.ddl-auto=create
spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect
# Local Elasticsearch config
elasticsearch.host=localhost
elasticsearch.port=9200
loggin.level.org.springframework: DEBUG
# App config
server.port=8102
spring.application.name=BootElastic
如何使用@DataJpaTest排除组件?
答案 0 :(得分:1)
过滤器仅影响组件扫描。如果该扫描找到您的配置,则此行:
@EnableElasticsearchRepositories(basePackages=
"io.rainrobot.adwisdom.repository.es")
然后将为您尝试排除的软件包启用存储库。
至少这是我的理解。 验证是否从配置中删除该行应该很容易。