Commit 39c1e47e authored by Andy Wilkinson's avatar Andy Wilkinson

Use 3 decimal places at most for logged startup time

Fixes gh-18278
parent 7d3e53c9
...@@ -87,7 +87,7 @@ class StartupInfoLogger { ...@@ -87,7 +87,7 @@ class StartupInfoLogger {
message.append("Started "); message.append("Started ");
appendApplicationName(message); appendApplicationName(message);
message.append(" in "); message.append(" in ");
message.append(stopWatch.getTotalTimeSeconds()); message.append(stopWatch.getTotalTimeMillis() / 1000.0);
message.append(" seconds"); message.append(" seconds");
try { try {
double uptime = ManagementFactory.getRuntimeMXBean().getUptime() / 1000.0; double uptime = ManagementFactory.getRuntimeMXBean().getUptime() / 1000.0;
......
...@@ -20,6 +20,8 @@ import org.apache.commons.logging.Log; ...@@ -20,6 +20,8 @@ import org.apache.commons.logging.Log;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.mockito.ArgumentCaptor; import org.mockito.ArgumentCaptor;
import org.springframework.util.StopWatch;
import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThat;
import static org.mockito.BDDMockito.given; import static org.mockito.BDDMockito.given;
import static org.mockito.Mockito.mock; import static org.mockito.Mockito.mock;
...@@ -31,7 +33,7 @@ import static org.mockito.Mockito.verify; ...@@ -31,7 +33,7 @@ import static org.mockito.Mockito.verify;
* @author Dave Syer * @author Dave Syer
* @author Andy Wilkinson * @author Andy Wilkinson
*/ */
class StartUpLoggerTests { class StartupInfoLoggerTests {
private final Log log = mock(Log.class); private final Log log = mock(Log.class);
...@@ -44,4 +46,17 @@ class StartUpLoggerTests { ...@@ -44,4 +46,17 @@ class StartUpLoggerTests {
assertThat(captor.getValue().toString()).startsWith("Starting " + getClass().getSimpleName()); assertThat(captor.getValue().toString()).startsWith("Starting " + getClass().getSimpleName());
} }
@Test
void startedFormat() {
StopWatch stopWatch = new StopWatch();
stopWatch.start();
given(this.log.isInfoEnabled()).willReturn(true);
stopWatch.stop();
new StartupInfoLogger(getClass()).logStarted(this.log, stopWatch);
ArgumentCaptor<Object> captor = ArgumentCaptor.forClass(Object.class);
verify(this.log).info(captor.capture());
assertThat(captor.getValue().toString()).matches("Started " + getClass().getSimpleName()
+ " in \\d+\\.\\d{1,3} seconds \\(JVM running for \\d+\\.\\d{1,3}\\)");
}
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment