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
35
36
37
38
39
40
41
42
43 package org.eclipse.jgit.util;
44
45 import static org.junit.Assert.assertEquals;
46 import static org.junit.Assert.assertNotNull;
47 import static org.junit.Assert.assertNull;
48
49 import java.io.IOException;
50 import java.nio.file.Files;
51 import java.nio.file.Path;
52
53 import org.junit.After;
54 import org.junit.Before;
55 import org.junit.Test;
56
57 public class SimpleLruCacheTest {
58
59 private Path trash;
60
61 private SimpleLruCache<String, String> cache;
62
63
64 @Before
65 public void setup() throws IOException {
66 trash = Files.createTempDirectory("tmp_");
67 cache = new SimpleLruCache<>(100, 0.2f);
68 }
69
70 @Before
71 @After
72 public void tearDown() throws Exception {
73 FileUtils.delete(trash.toFile(),
74 FileUtils.RECURSIVE | FileUtils.SKIP_MISSING);
75 }
76
77 @Test
78 public void testPutGet() {
79 cache.put("a", "A");
80 cache.put("z", "Z");
81 assertEquals("A", cache.get("a"));
82 assertEquals("Z", cache.get("z"));
83 }
84
85 @Test(expected = IllegalArgumentException.class)
86 public void testPurgeFactorTooLarge() {
87 cache.configure(5, 1.01f);
88 }
89
90 @Test(expected = IllegalArgumentException.class)
91 public void testPurgeFactorTooLarge2() {
92 cache.configure(5, 100);
93 }
94
95 @Test(expected = IllegalArgumentException.class)
96 public void testPurgeFactorTooSmall() {
97 cache.configure(5, 0);
98 }
99
100 @Test(expected = IllegalArgumentException.class)
101 public void testPurgeFactorTooSmall2() {
102 cache.configure(5, -100);
103 }
104
105 @Test
106 public void testGetMissing() {
107 assertEquals(null, cache.get("a"));
108 }
109
110 @Test
111 public void testPurge() {
112 for (int i = 0; i < 101; i++) {
113 cache.put("a" + i, "a" + i);
114 }
115 assertEquals(80, cache.size());
116 assertNull(cache.get("a0"));
117 assertNull(cache.get("a20"));
118 assertNotNull(cache.get("a21"));
119 assertNotNull(cache.get("a99"));
120 }
121
122 @Test
123 public void testConfigure() {
124 for (int i = 0; i < 100; i++) {
125 cache.put("a" + i, "a" + i);
126 }
127 assertEquals(100, cache.size());
128 cache.configure(10, 0.3f);
129 assertEquals(7, cache.size());
130 assertNull(cache.get("a0"));
131 assertNull(cache.get("a92"));
132 assertNotNull(cache.get("a93"));
133 assertNotNull(cache.get("a99"));
134 }
135 }