test-filecache.py
184 lines
| 4.2 KiB
| text/x-python
|
PythonLexer
/ tests / test-filecache.py
Idan Kamara
|
r14928 | import sys, os, subprocess | ||
Brodie Rao
|
r16683 | if subprocess.call(['python', '%s/hghave' % os.environ['TESTDIR'], | ||
'cacheable']): | ||||
Idan Kamara
|
r14928 | sys.exit(80) | ||
Idan Kamara
|
r18313 | from mercurial import util, scmutil, extensions, hg, ui | ||
Idan Kamara
|
r14928 | |||
filecache = scmutil.filecache | ||||
class fakerepo(object): | ||||
def __init__(self): | ||||
self._filecache = {} | ||||
def join(self, p): | ||||
return p | ||||
def sjoin(self, p): | ||||
return p | ||||
Siddharth Agarwal
|
r20045 | @filecache('x', 'y') | ||
Idan Kamara
|
r14928 | def cached(self): | ||
print 'creating' | ||||
Siddharth Agarwal
|
r20040 | return 'string from function' | ||
Idan Kamara
|
r14928 | |||
def invalidate(self): | ||||
for k in self._filecache: | ||||
try: | ||||
delattr(self, k) | ||||
except AttributeError: | ||||
pass | ||||
def basic(repo): | ||||
Siddharth Agarwal
|
r20045 | print "* neither file exists" | ||
Siddharth Agarwal
|
r20041 | # calls function | ||
Idan Kamara
|
r14928 | repo.cached | ||
repo.invalidate() | ||||
Siddharth Agarwal
|
r20045 | print "* neither file still exists" | ||
Siddharth Agarwal
|
r20041 | # uses cache | ||
Idan Kamara
|
r14928 | repo.cached | ||
# create empty file | ||||
f = open('x', 'w') | ||||
f.close() | ||||
repo.invalidate() | ||||
Siddharth Agarwal
|
r20041 | print "* empty file x created" | ||
Idan Kamara
|
r14928 | # should recreate the object | ||
repo.cached | ||||
f = open('x', 'w') | ||||
f.write('a') | ||||
f.close() | ||||
repo.invalidate() | ||||
Siddharth Agarwal
|
r20041 | print "* file x changed size" | ||
Idan Kamara
|
r14928 | # should recreate the object | ||
repo.cached | ||||
repo.invalidate() | ||||
Siddharth Agarwal
|
r20045 | print "* nothing changed with either file" | ||
Siddharth Agarwal
|
r20041 | # stats file again, reuses object | ||
Idan Kamara
|
r14928 | repo.cached | ||
# atomic replace file, size doesn't change | ||||
# hopefully st_mtime doesn't change as well so this doesn't use the cache | ||||
# because of inode change | ||||
f = scmutil.opener('.')('x', 'w', atomictemp=True) | ||||
f.write('b') | ||||
Greg Ward
|
r15057 | f.close() | ||
Idan Kamara
|
r14928 | |||
repo.invalidate() | ||||
Siddharth Agarwal
|
r20041 | print "* file x changed inode" | ||
Idan Kamara
|
r14928 | repo.cached | ||
Siddharth Agarwal
|
r20045 | # create empty file y | ||
f = open('y', 'w') | ||||
f.close() | ||||
repo.invalidate() | ||||
print "* empty file y created" | ||||
# should recreate the object | ||||
repo.cached | ||||
f = open('y', 'w') | ||||
f.write('A') | ||||
f.close() | ||||
repo.invalidate() | ||||
print "* file y changed size" | ||||
# should recreate the object | ||||
repo.cached | ||||
f = scmutil.opener('.')('y', 'w', atomictemp=True) | ||||
f.write('B') | ||||
f.close() | ||||
repo.invalidate() | ||||
print "* file y changed inode" | ||||
repo.cached | ||||
f = scmutil.opener('.')('x', 'w', atomictemp=True) | ||||
f.write('c') | ||||
f.close() | ||||
f = scmutil.opener('.')('y', 'w', atomictemp=True) | ||||
f.write('C') | ||||
f.close() | ||||
repo.invalidate() | ||||
print "* both files changed inode" | ||||
repo.cached | ||||
Idan Kamara
|
r14928 | def fakeuncacheable(): | ||
def wrapcacheable(orig, *args, **kwargs): | ||||
return False | ||||
def wrapinit(orig, *args, **kwargs): | ||||
pass | ||||
originit = extensions.wrapfunction(util.cachestat, '__init__', wrapinit) | ||||
Matt Mackall
|
r14937 | origcacheable = extensions.wrapfunction(util.cachestat, 'cacheable', | ||
wrapcacheable) | ||||
Idan Kamara
|
r14928 | |||
Siddharth Agarwal
|
r20045 | for fn in ['x', 'y']: | ||
try: | ||||
os.remove(fn) | ||||
except OSError: | ||||
pass | ||||
Idan Kamara
|
r14928 | |||
basic(fakerepo()) | ||||
util.cachestat.cacheable = origcacheable | ||||
util.cachestat.__init__ = originit | ||||
Idan Kamara
|
r18313 | def test_filecache_synced(): | ||
timeless@mozdev.org
|
r26098 | # test old behavior that caused filecached properties to go out of sync | ||
Idan Kamara
|
r18313 | os.system('hg init && echo a >> a && hg ci -qAm.') | ||
repo = hg.repository(ui.ui()) | ||||
# first rollback clears the filecache, but changelog to stays in __dict__ | ||||
repo.rollback() | ||||
repo.commit('.') | ||||
# second rollback comes along and touches the changelog externally | ||||
# (file is moved) | ||||
repo.rollback() | ||||
# but since changelog isn't under the filecache control anymore, we don't | ||||
# see that it changed, and return the old changelog without reconstructing | ||||
# it | ||||
repo.commit('.') | ||||
Idan Kamara
|
r18316 | def setbeforeget(repo): | ||
os.remove('x') | ||||
Siddharth Agarwal
|
r20045 | os.remove('y') | ||
Siddharth Agarwal
|
r20040 | repo.cached = 'string set externally' | ||
Idan Kamara
|
r18316 | repo.invalidate() | ||
Siddharth Agarwal
|
r20045 | print "* neither file exists" | ||
Idan Kamara
|
r18316 | print repo.cached | ||
repo.invalidate() | ||||
f = open('x', 'w') | ||||
f.write('a') | ||||
f.close() | ||||
Siddharth Agarwal
|
r20041 | print "* file x created" | ||
Idan Kamara
|
r18316 | print repo.cached | ||
Siddharth Agarwal
|
r20045 | repo.cached = 'string 2 set externally' | ||
repo.invalidate() | ||||
print "* string set externally again" | ||||
print repo.cached | ||||
repo.invalidate() | ||||
f = open('y', 'w') | ||||
f.write('b') | ||||
f.close() | ||||
print "* file y created" | ||||
print repo.cached | ||||
Idan Kamara
|
r14928 | print 'basic:' | ||
basic(fakerepo()) | ||||
print 'fakeuncacheable:' | ||||
fakeuncacheable() | ||||
Idan Kamara
|
r18313 | test_filecache_synced() | ||
Idan Kamara
|
r18316 | |||
print 'setbeforeget:' | ||||
setbeforeget(fakerepo()) | ||||