56
54
# check we hit without re-reading
57
55
self.assertEquals(hc.get_sha1('foo'),
58
56
'aaf4c61ddcc5e8a2dabede0f3b482cd9aea9434d')
59
##self.assertEquals(hc.miss_count, 1)
60
##self.assertEquals(hc.hit_count, 1)
57
self.assertEquals(hc.miss_count, 1)
58
self.assertEquals(hc.hit_count, 1)
62
60
# check again without re-reading
63
61
self.assertEquals(hc.get_sha1('foo'),
64
62
'aaf4c61ddcc5e8a2dabede0f3b482cd9aea9434d')
65
##self.assertEquals(hc.miss_count, 1)
66
##self.assertEquals(hc.hit_count, 2)
63
self.assertEquals(hc.miss_count, 1)
64
self.assertEquals(hc.hit_count, 2)
68
66
# write new file and make sure it is seen
69
67
file('foo', 'wb').write('goodbye')
71
69
self.assertEquals(hc.get_sha1('foo'),
72
70
'3c8ec4874488f6090a157b014ce3397ca8e06d4f')
73
##self.assertEquals(hc.miss_count, 2)
71
self.assertEquals(hc.miss_count, 2)
75
73
# quickly write new file of same size and make sure it is seen
76
74
# this may rely on detection of timestamps that are too close
97
95
# should now be safe to cache it if we reread them
98
96
self.assertEquals(hc.get_sha1('foo'), sha1('g00dbye'))
99
##self.assertEquals(len(hc._cache), 1)
97
self.assertEquals(len(hc._cache), 1)
100
98
self.assertEquals(hc.get_sha1('foo2'), sha1('new content'))
101
##self.assertEquals(len(hc._cache), 2)
99
self.assertEquals(len(hc._cache), 2)
103
101
# write out, read back in and check that we don't need to
104
102
# re-read any files
108
106
hc = HashCache('.')
111
##self.assertEquals(len(hc._cache), 2)
109
self.assertEquals(len(hc._cache), 2)
112
110
self.assertEquals(hc.get_sha1('foo'), sha1('g00dbye'))
113
##self.assertEquals(hc.hit_count, 1)
114
##self.assertEquals(hc.miss_count, 0)
111
self.assertEquals(hc.hit_count, 1)
112
self.assertEquals(hc.miss_count, 0)
115
113
self.assertEquals(hc.get_sha1('foo2'), sha1('new content'))