1 |
|
|
2 |
|
|
3 |
|
|
4 |
|
|
5 |
|
|
6 |
|
|
7 |
|
|
8 |
|
|
9 |
|
|
10 |
|
|
11 |
|
|
12 |
|
|
13 |
|
|
14 |
|
|
15 |
|
|
16 |
|
|
17 |
|
|
18 |
|
|
19 |
|
|
20 |
|
|
21 |
|
|
22 |
|
|
23 |
|
|
24 |
|
|
25 |
|
|
26 |
|
|
27 |
|
|
28 |
|
|
29 |
|
|
30 |
|
|
31 |
|
|
32 |
|
|
33 |
|
|
34 |
|
package info.magnolia.module.cache.filter; |
35 |
|
|
36 |
|
import static org.easymock.EasyMock.*; |
37 |
|
|
38 |
|
import info.magnolia.cms.cache.CacheConstants; |
39 |
|
import info.magnolia.cms.filters.WebContainerResources; |
40 |
|
import info.magnolia.cms.filters.WebContainerResourcesImpl; |
41 |
|
import info.magnolia.test.ComponentsTestUtil; |
42 |
|
import info.magnolia.test.MgnlTestCase; |
43 |
|
|
44 |
|
import javax.servlet.FilterChain; |
45 |
|
import javax.servlet.http.HttpServletRequest; |
46 |
|
import javax.servlet.http.HttpServletResponse; |
47 |
|
|
48 |
|
import org.easymock.EasyMock; |
49 |
|
import org.junit.Before; |
50 |
|
import org.junit.Test; |
51 |
|
|
52 |
|
|
53 |
|
|
54 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (29) |
Complexity: 3 |
Complexity Density: 0.12 |
|
55 |
|
public class CacheHeadersFilterTest extends MgnlTestCase { |
56 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (2) |
Complexity: 1 |
Complexity Density: 0.5 |
|
57 |
2 |
@Override... |
58 |
|
@Before |
59 |
|
public void setUp() throws Exception { |
60 |
2 |
super.setUp(); |
61 |
2 |
ComponentsTestUtil.setImplementation(WebContainerResources.class, WebContainerResourcesImpl.class); |
62 |
|
} |
63 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (11) |
Complexity: 1 |
Complexity Density: 0.09 |
1PASS
|
|
64 |
1 |
@Test... |
65 |
|
public void testFilterCacheRequest() throws Exception { |
66 |
1 |
final HttpServletRequest request = createStrictMock(HttpServletRequest.class); |
67 |
1 |
final HttpServletResponse response = createStrictMock(HttpServletResponse.class); |
68 |
1 |
final FilterChain chain = createStrictMock(FilterChain.class); |
69 |
|
|
70 |
1 |
expect(request.getAttribute(EasyMock.<String> anyObject())).andReturn(null).anyTimes(); |
71 |
|
|
72 |
1 |
response.setHeader(CacheConstants.HEADER_CACHE_CONTROL, CacheConstants.HEADER_VALUE_MAX_AGE + "=86400, " + CacheConstants.HEADER_VALUE_PUBLIC); |
73 |
1 |
response.setDateHeader(eq(CacheConstants.HEADER_EXPIRES), anyLong()); |
74 |
1 |
chain.doFilter(request, response); |
75 |
|
|
76 |
1 |
replay(request, response, chain); |
77 |
1 |
CacheHeadersFilter filter = new CacheHeadersFilter(); |
78 |
1 |
filter.doFilter(request, response, chain); |
79 |
1 |
verify(request, response, chain); |
80 |
|
} |
81 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (13) |
Complexity: 1 |
Complexity Density: 0.08 |
1PASS
|
|
82 |
1 |
@Test... |
83 |
|
public void testFilterNoCacheRequest() throws Exception { |
84 |
1 |
final HttpServletRequest request = createStrictMock(HttpServletRequest.class); |
85 |
1 |
final HttpServletResponse response = createStrictMock(HttpServletResponse.class); |
86 |
1 |
final FilterChain chain = createStrictMock(FilterChain.class); |
87 |
|
|
88 |
1 |
expect(request.getAttribute(EasyMock.<String> anyObject())).andReturn(null).anyTimes(); |
89 |
|
|
90 |
1 |
response.setHeader(CacheConstants.HEADER_PRAGMA, CacheConstants.HEADER_VALUE_NO_CACHE); |
91 |
1 |
response.setHeader(CacheConstants.HEADER_CACHE_CONTROL, CacheConstants.HEADER_CACHE_CONTROL_VALUE_DISABLE_CACHE); |
92 |
1 |
response.setDateHeader(CacheConstants.HEADER_EXPIRES, 0L); |
93 |
1 |
chain.doFilter(request, response); |
94 |
|
|
95 |
1 |
replay(request, response, chain); |
96 |
1 |
CacheHeadersFilter filter = new CacheHeadersFilter(); |
97 |
1 |
filter.setNocache(true); |
98 |
1 |
filter.doFilter(request, response, chain); |
99 |
1 |
verify(request, response, chain); |
100 |
|
} |
101 |
|
} |