ここでは、5.2.0.RELEASEに春-テストをアップグレードした後、IT試験での問題を抱えています。
次のコード:
@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
@AutoConfigureMockMvc
// @WebMvcTest
public class TestedControllerIT {
private static final ObjectMapper JSON_OBJECT_MAPPER = new ObjectMapper();
private static final String TOPIC = "topic";
@Autowired
private MockMvc mockMvc;
@Autowired
private TestedRepository testedRepository;
@Before
public void init() {
testedRepository.deleteAll();
}
@Test
public void shouldReinjectError()
throws Exception {
// Given
LinkedHashMap kafkaMessage = new LinkedHashMap<String, Object>();
kafkaMessage.put("orderNumber", "orderNumber");
kafkaMessage.put("recordedDate", 1564652757990L);
kafkaMessage.put("creationDate", 1564652546217L);
final RejetTechnique rejetTechnique = RejetTechnique.builder()
.creationDate(LocalDateTime.now())
.id("1")
.offset(12L)
.topic(TOPIC)
.stackTrace("")
.kafkaMessage(kafkaMessage)
.build();
testedRepository.save(rejetTechnique);
// When
final MvcResult result = mockMvc.perform(MockMvcRequestBuilders.post("/rejet-technique/reinjection"))
.andExpect(MockMvcResultMatchers.status().is(200))
.andReturn();
//Then
assertThat(result.getResponse().getContentAsString()).isEqualTo("{\"status\":\"OK\"}");
assertThat(testedRepository.findAll().size()).isEqualTo(0);
final Properties props = new Properties();
props.put("bootstrap.servers", "localhost:9092");
props.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
props.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
TopicPartition topicPartition = new TopicPartition(TOPIC, 0);
ConsumerRecords<String, Object> records;
try (KafkaConsumer kafkaConsumer = new KafkaConsumer(props)) {
List<TopicPartition> topics = Collections.singletonList(topicPartition);
kafkaConsumer.assign(topics);
kafkaConsumer.seekToEnd(topics);
long current = kafkaConsumer.position(topicPartition);
kafkaConsumer.seek(topicPartition, current - 1);
Duration duration = Duration.of(1000, ChronoUnit.MILLIS);
records = kafkaConsumer.poll(duration);
}
String resultRecordValue = (String) records.records(topicPartition).get(0).value();
assertThat(resultRecordValue).isEqualTo(convertMessageToJson(kafkaMessage));
}
private String convertMessageToJson(final Object message)
throws JsonProcessingException {
return JSON_OBJECT_MAPPER.writeValueAsString(message);
}
}
私たちに次のエラーが与えられます。
java.lang.NoClassDefFoundErrorが:org.springframework.core.annotation.MergedAnnotations $ SearchStrategy
org.springframework.test.contextでorg.springframework.test.context.support.AbstractTestContextBootstrapper.buildMergedContextConfiguration(AbstractTestContextBootstrapper.java:386)でorg.springframework.test.context.support.TestPropertySourceUtils.buildMergedTestPropertySources(TestPropertySourceUtils.java:74)でorg.springframework.test.context.support.AbstractTestContextBootstrapper.buildTestContextでorg.springframework.test.context.support.AbstractTestContextBootstrapper.buildMergedContextConfiguration(AbstractTestContextBootstrapper.java:265)で.support.AbstractTestContextBootstrapper.buildDefaultMergedContextConfiguration(AbstractTestContextBootstrapper.java:312)(AbstractTestContextBootstrapper .java:108)org.springframework.boot.test.context.SpringBootTestContextBootstrapper.buildTestContext(SpringBootTestContextBootstrapper.javaで:org.springframework.test.context.TestContextManagerで99)。org.springframework.test.context.TestContextManagerで(TestContextManager.java:137)。(TestContextManager.java:122)org.springframework.test.context.junit4.SpringJUnit4ClassRunnerでorg.springframework.test.context.junit4.SpringJUnit4ClassRunnerで.createTestContextManager(SpringJUnit4ClassRunner.java:151)。(SpringJUnit4ClassRunner.java:142)org.springframework.test.context.junit4.SpringRunnerた。(SpringRunner.java:49)でjava.base / jdk.internal.reflect.DelegatingConstructorAccessorImplでjava.base / jdk.internal.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)でjava.base / jdk.internal.reflect.NativeConstructorAccessorImpl.newInstance0(ネイティブメソッド) java.base / java.lang.reflect.Constructorで.newInstance(DelegatingConstructorAccessorImpl.java:45)。org.junitでorg.junit.internal.builders.AnnotatedBuilder.runnerForClass(AnnotatedBuilder.java:86)でorg.junit.internal.builders.AnnotatedBuilder.buildRunner(AnnotatedBuilder.java:104)でのnewInstance(Constructor.java:490) org.junit.runners.model.RunnerBuilder.safeRunnerForClassでorg.junit.internal.builders.AllDefaultPossibilitiesBuilder.runnerForClass(AllDefaultPossibilitiesBuilder.java:26)で.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:59)(RunnerBuilder.java :com.intellij.rt.junit.IdeaTestRunner $でcom.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgsでorg.junit.internal.requests.ClassRequest.getRunner(ClassRequest.java:33)(JUnit4IdeaTestRunner.java:49)の59) com.intellij.rtでcom.intellij.rt.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:230)でRepeater.startRunnerWithArgs(IdeaTestRunner.java:33)。java.lang.ClassNotFoundException:java.base / jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.javaでorg.springframework.core.annotation.MergedAnnotations $ SearchStrategyによって引き起こさjunit.JUnitStarter.main(JUnitStarter.java:58) :25もっとjava.base / java.lang.ClassLoader.loadClassでjava.base / jdk.internal.loader.ClassLoaders $ AppClassLoader.loadClass(ClassLoaders.java:178)(ClassLoader.java:1077)...にて766)
注意:これは、のリリース5.2.0.RC1まで完璧に動作春-テスト。
それはに関連すると思われるこの。
誰もが任意の手掛かりを持っていますか?
助けてくれてありがとう=)
プロジェクトで一貫性のある春のバージョンを持っている必要があります。
私は春のブーツを使用して、私の問題を解決しました。