~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/selftest/testhashcache.py

  • Committer: Robert Collins
  • Date: 2005-09-27 07:24:40 UTC
  • mfrom: (1185.1.41)
  • Revision ID: robertc@robertcollins.net-20050927072440-1bf4d99c3e1db5b3
pair programming worx... merge integration and weave

Show diffs side-by-side

added added

removed removed

Lines of Context:
15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
16
 
17
17
import os
18
 
import sha
19
 
import sys
20
18
import time
 
19
from bzrlib.selftest import TestCaseInTempDir
21
20
 
22
 
from bzrlib.errors import BzrError
23
 
from bzrlib.hashcache import HashCache
24
 
from bzrlib.tests import TestCaseInTempDir, TestSkipped
25
21
 
26
22
 
27
23
def sha1(t):
 
24
    import sha
28
25
    return sha.new(t).hexdigest()
29
26
 
30
27
 
31
28
def pause():
32
29
    if False:
33
30
        return
34
 
    if sys.platform in ('win32', 'cygwin'):
 
31
    if os.name == 'nt':
35
32
        time.sleep(3)
36
33
        return
37
34
    # allow it to stabilize
38
35
    start = int(time.time())
39
36
    while int(time.time()) == start:
40
37
        time.sleep(0.2)
41
 
 
42
 
 
43
 
class FixThisError(Exception):
44
 
    pass
45
38
    
46
39
 
47
40
class TestHashCache(TestCaseInTempDir):
48
41
 
49
42
    def test_hashcache(self):
50
43
        """Functional tests for hashcache"""
 
44
        from bzrlib.hashcache import HashCache
 
45
        import os
51
46
 
52
47
        # make a dummy bzr directory just to hold the cache
53
48
        os.mkdir('.bzr')
54
 
        hc = HashCache('.', '.bzr/stat-cache')
 
49
        hc = HashCache('.')
55
50
 
56
51
        file('foo', 'wb').write('hello')
57
52
        os.mkdir('subdir')
65
60
        # check we hit without re-reading
66
61
        self.assertEquals(hc.get_sha1('foo'),
67
62
                          'aaf4c61ddcc5e8a2dabede0f3b482cd9aea9434d')
68
 
        self.assertEquals(hc.miss_count, 1)
69
 
        self.assertEquals(hc.hit_count, 1)
 
63
        ##self.assertEquals(hc.miss_count, 1)
 
64
        ##self.assertEquals(hc.hit_count, 1)
70
65
 
71
66
        # check again without re-reading
72
67
        self.assertEquals(hc.get_sha1('foo'),
73
68
                          'aaf4c61ddcc5e8a2dabede0f3b482cd9aea9434d')
74
 
        self.assertEquals(hc.miss_count, 1)
75
 
        self.assertEquals(hc.hit_count, 2)
 
69
        ##self.assertEquals(hc.miss_count, 1)
 
70
        ##self.assertEquals(hc.hit_count, 2)
76
71
 
77
72
        # write new file and make sure it is seen
78
73
        file('foo', 'wb').write('goodbye')
79
74
        pause()
80
75
        self.assertEquals(hc.get_sha1('foo'),
81
76
                          '3c8ec4874488f6090a157b014ce3397ca8e06d4f')
82
 
        self.assertEquals(hc.miss_count, 2)
 
77
        ##self.assertEquals(hc.miss_count, 2)
83
78
 
84
79
        # quickly write new file of same size and make sure it is seen
85
80
        # this may rely on detection of timestamps that are too close
99
94
 
100
95
        self.assertEquals(hc.get_sha1('subdir'), None)
101
96
 
102
 
        # pause briefly to make sure they're not treated as new uncacheable
103
 
        # files
 
97
        # it's likely neither are cached at the moment because they 
 
98
        # changed recently, but we can't be sure
104
99
        pause()
105
100
 
 
101
        # should now be safe to cache it if we reread them
106
102
        self.assertEquals(hc.get_sha1('foo'), sha1('g00dbye'))
 
103
        ##self.assertEquals(len(hc._cache), 1)
107
104
        self.assertEquals(hc.get_sha1('foo2'), sha1('new content'))
 
105
        ##self.assertEquals(len(hc._cache), 2)
108
106
 
109
107
        # write out, read back in and check that we don't need to
110
108
        # re-read any files
111
109
        hc.write()
112
110
        del hc
113
111
 
114
 
        hc = HashCache('.', '.bzr/stat-cache')
 
112
        hc = HashCache('.')
115
113
        hc.read()
116
114
 
117
 
        self.assertEquals(len(hc._cache), 2)
 
115
        ##self.assertEquals(len(hc._cache), 2)
118
116
        self.assertEquals(hc.get_sha1('foo'), sha1('g00dbye'))
119
 
        self.assertEquals(hc.hit_count, 1)
120
 
        self.assertEquals(hc.miss_count, 0)
 
117
        ##self.assertEquals(hc.hit_count, 1)
 
118
        ##self.assertEquals(hc.miss_count, 0)
121
119
        self.assertEquals(hc.get_sha1('foo2'), sha1('new content'))
122
 
 
123
 
    def test_hashcache_raise(self):
124
 
        """check that hashcache can raise BzrError"""
125
 
 
126
 
        os.mkdir('.bzr')
127
 
        hc = HashCache('.', '.bzr/stat-cache')
128
 
        ok = False
129
 
 
130
 
        # make a best effort to create a weird kind of file
131
 
        funcs = (getattr(os, 'mkfifo', None), getattr(os, 'mknod', None))
132
 
        for func in funcs:
133
 
            if func is None:
134
 
                continue
135
 
            try:
136
 
                func('a')
137
 
                ok = True
138
 
                break
139
 
            except FixThisError:
140
 
                pass
141
 
 
142
 
        if ok:
143
 
            self.assertRaises(BzrError, hc.get_sha1, 'a')
144
 
        else:
145
 
            raise TestSkipped('No weird file type could be created')