Merge pull request #22845 from mdeinum
* pr/22845: Polish 'Allow step action to be optional' Allow step action to be optional Closes gh-22845
This commit is contained in:
commit
07e59dff4f
|
@ -103,14 +103,17 @@ class SpringApplicationRunListeners {
|
|||
}
|
||||
|
||||
private void doWithListeners(String stepName, Consumer<SpringApplicationRunListener> listenerAction) {
|
||||
doWithListeners(stepName, listenerAction, StartupStep::end);
|
||||
doWithListeners(stepName, listenerAction, null);
|
||||
}
|
||||
|
||||
private void doWithListeners(String stepName, Consumer<SpringApplicationRunListener> listenerAction,
|
||||
Consumer<StartupStep> stepAction) {
|
||||
StartupStep step = this.applicationStartup.start(stepName);
|
||||
this.listeners.forEach(listenerAction);
|
||||
stepAction.accept(step);
|
||||
if (stepAction != null) {
|
||||
stepAction.accept(step);
|
||||
}
|
||||
step.end();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -141,6 +141,7 @@ import static org.mockito.Mockito.verifyNoMoreInteractions;
|
|||
* @author Madhura Bhave
|
||||
* @author Brian Clozel
|
||||
* @author Artsiom Yudovin
|
||||
* @author Marten Deinum
|
||||
*/
|
||||
@ExtendWith(OutputCaptureExtension.class)
|
||||
class SpringApplicationTests {
|
||||
|
@ -1179,6 +1180,29 @@ class SpringApplicationTests {
|
|||
assertThat(startCount).isEqualTo(endCount);
|
||||
}
|
||||
|
||||
@Test
|
||||
void customApplicationStartupPublishStartupStepsWithFailure() {
|
||||
ApplicationStartup applicationStartup = mock(ApplicationStartup.class);
|
||||
StartupStep startupStep = mock(StartupStep.class);
|
||||
given(applicationStartup.start(anyString())).willReturn(startupStep);
|
||||
given(startupStep.tag(anyString(), anyString())).willReturn(startupStep);
|
||||
given(startupStep.tag(anyString(), ArgumentMatchers.<Supplier<String>>any())).willReturn(startupStep);
|
||||
SpringApplication application = new SpringApplication(BrokenPostConstructConfig.class);
|
||||
application.setWebApplicationType(WebApplicationType.NONE);
|
||||
application.setApplicationStartup(applicationStartup);
|
||||
assertThatExceptionOfType(BeanCreationException.class).isThrownBy(application::run);
|
||||
verify(applicationStartup).start("spring.boot.application.starting");
|
||||
verify(applicationStartup).start("spring.boot.application.environment-prepared");
|
||||
verify(applicationStartup).start("spring.boot.application.failed");
|
||||
long startCount = mockingDetails(applicationStartup).getInvocations().stream()
|
||||
.filter((invocation) -> invocation.getMethod().toString().contains("start(")).count();
|
||||
long endCount = mockingDetails(startupStep).getInvocations().stream()
|
||||
.filter((invocation) -> invocation.getMethod().toString().contains("end(")).count();
|
||||
assertThat(startCount).isEqualTo(endCount + 1); // Will be same after
|
||||
// spring-framework #25572 is
|
||||
// fixed
|
||||
}
|
||||
|
||||
private <S extends AvailabilityState> ArgumentMatcher<ApplicationEvent> isAvailabilityChangeEventWithState(
|
||||
S state) {
|
||||
return (argument) -> (argument instanceof AvailabilityChangeEvent<?>)
|
||||
|
|
Loading…
Reference in New Issue