|
22 | 22 | import jakarta.servlet.http.HttpServletRequest; |
23 | 23 | import jakarta.servlet.http.HttpServletResponse; |
24 | 24 | import org.junit.jupiter.api.Test; |
| 25 | +import org.junit.jupiter.api.extension.ExtendWith; |
25 | 26 |
|
26 | 27 | import org.springframework.beans.factory.ObjectProvider; |
27 | 28 | import org.springframework.beans.factory.annotation.Value; |
|
30 | 31 | import org.springframework.boot.autoconfigure.template.TemplateAvailabilityProvider; |
31 | 32 | import org.springframework.boot.autoconfigure.template.TemplateAvailabilityProviders; |
32 | 33 | import org.springframework.boot.test.context.runner.WebApplicationContextRunner; |
| 34 | +import org.springframework.boot.test.system.CapturedOutput; |
| 35 | +import org.springframework.boot.test.system.OutputCaptureExtension; |
33 | 36 | import org.springframework.context.ApplicationContext; |
34 | 37 | import org.springframework.context.annotation.Bean; |
35 | 38 | import org.springframework.context.annotation.Configuration; |
|
53 | 56 | * Tests for {@link WelcomePageHandlerMapping}. |
54 | 57 | * |
55 | 58 | * @author Andy Wilkinson |
| 59 | + * @author Moritz Halbritter |
56 | 60 | */ |
| 61 | +@ExtendWith(OutputCaptureExtension.class) |
57 | 62 | class WelcomePageHandlerMappingTests { |
58 | 63 |
|
59 | 64 | private final WebApplicationContextRunner contextRunner = new WebApplicationContextRunner() |
@@ -163,6 +168,17 @@ void prefersAStaticResourceToATemplate() { |
163 | 168 | }); |
164 | 169 | } |
165 | 170 |
|
| 171 | + @Test |
| 172 | + void logsInvalidAcceptHeader(CapturedOutput output) { |
| 173 | + this.contextRunner.withUserConfiguration(TemplateConfiguration.class).run((context) -> { |
| 174 | + MockMvc mockMvc = MockMvcBuilders.webAppContextSetup(context).build(); |
| 175 | + mockMvc.perform(get("/").accept("*/*q=0.8")) |
| 176 | + .andExpect(status().isOk()) |
| 177 | + .andExpect(content().string("index template")); |
| 178 | + }); |
| 179 | + assertThat(output).contains("Received invalid Accept header. Assuming all media types are accepted"); |
| 180 | + } |
| 181 | + |
166 | 182 | @Configuration(proxyBeanMethods = false) |
167 | 183 | static class HandlerMappingConfiguration { |
168 | 184 |
|
|
0 commit comments