test-propertycache.py
179 lines
| 6.4 KiB
| text/x-python
|
PythonLexer
/ tests / test-propertycache.py
Pierre-Yves David
|
r19845 | """test behavior of propertycache and unfiltered propertycache | ||
Mads Kiilerich
|
r19951 | The repoview overlay is quite complex. We test the behavior of | ||
Pierre-Yves David
|
r19845 | property cache of both localrepo and repoview to prevent | ||
regression.""" | ||||
import os, subprocess | ||||
import mercurial.localrepo | ||||
import mercurial.repoview | ||||
import mercurial.util | ||||
import mercurial.hg | ||||
import mercurial.ui as uimod | ||||
# create some special property cache that trace they call | ||||
calllog = [] | ||||
@mercurial.util.propertycache | ||||
def testcachedfoobar(repo): | ||||
name = repo.filtername | ||||
if name is None: | ||||
name = '' | ||||
val = len(name) | ||||
calllog.append(val) | ||||
return val | ||||
Pierre-Yves David
|
r19846 | unficalllog = [] | ||
@mercurial.localrepo.unfilteredpropertycache | ||||
def testcachedunfifoobar(repo): | ||||
name = repo.filtername | ||||
if name is None: | ||||
name = '' | ||||
val = 100 + len(name) | ||||
unficalllog.append(val) | ||||
return val | ||||
Pierre-Yves David
|
r19845 | #plug them on repo | ||
mercurial.localrepo.localrepository.testcachedfoobar = testcachedfoobar | ||||
Pierre-Yves David
|
r19846 | mercurial.localrepo.localrepository.testcachedunfifoobar = testcachedunfifoobar | ||
Pierre-Yves David
|
r19845 | |||
Mads Kiilerich
|
r21024 | # Create an empty repo and instantiate it. It is important to run | ||
# these tests on the real object to detect regression. | ||||
Pierre-Yves David
|
r19845 | repopath = os.path.join(os.environ['TESTTMP'], 'repo') | ||
Pierre-Yves David
|
r19878 | assert subprocess.call(['hg', 'init', repopath]) == 0 | ||
Pierre-Yves David
|
r19845 | ui = uimod.ui() | ||
repo = mercurial.hg.repository(ui, path=repopath).unfiltered() | ||||
print '' | ||||
print '=== property cache ===' | ||||
print '' | ||||
print 'calllog:', calllog | ||||
print 'cached value (unfiltered):', | ||||
print vars(repo).get('testcachedfoobar', 'NOCACHE') | ||||
print '' | ||||
print '= first access on unfiltered, should do a call' | ||||
print 'access:', repo.testcachedfoobar | ||||
print 'calllog:', calllog | ||||
print 'cached value (unfiltered):', | ||||
print vars(repo).get('testcachedfoobar', 'NOCACHE') | ||||
print '' | ||||
print '= second access on unfiltered, should not do call' | ||||
print 'access', repo.testcachedfoobar | ||||
print 'calllog:', calllog | ||||
print 'cached value (unfiltered):', | ||||
print vars(repo).get('testcachedfoobar', 'NOCACHE') | ||||
print '' | ||||
print '= first access on "visible" view, should do a call' | ||||
visibleview = repo.filtered('visible') | ||||
print 'cached value ("visible" view):', | ||||
print vars(visibleview).get('testcachedfoobar', 'NOCACHE') | ||||
print 'access:', visibleview.testcachedfoobar | ||||
print 'calllog:', calllog | ||||
print 'cached value (unfiltered):', | ||||
print vars(repo).get('testcachedfoobar', 'NOCACHE') | ||||
print 'cached value ("visible" view):', | ||||
print vars(visibleview).get('testcachedfoobar', 'NOCACHE') | ||||
print '' | ||||
print '= second access on "visible view", should not do call' | ||||
print 'access:', visibleview.testcachedfoobar | ||||
print 'calllog:', calllog | ||||
print 'cached value (unfiltered):', | ||||
print vars(repo).get('testcachedfoobar', 'NOCACHE') | ||||
print 'cached value ("visible" view):', | ||||
print vars(visibleview).get('testcachedfoobar', 'NOCACHE') | ||||
print '' | ||||
print '= no effect on other view' | ||||
immutableview = repo.filtered('immutable') | ||||
print 'cached value ("immutable" view):', | ||||
print vars(immutableview).get('testcachedfoobar', 'NOCACHE') | ||||
print 'access:', immutableview.testcachedfoobar | ||||
print 'calllog:', calllog | ||||
print 'cached value (unfiltered):', | ||||
print vars(repo).get('testcachedfoobar', 'NOCACHE') | ||||
print 'cached value ("visible" view):', | ||||
print vars(visibleview).get('testcachedfoobar', 'NOCACHE') | ||||
print 'cached value ("immutable" view):', | ||||
print vars(immutableview).get('testcachedfoobar', 'NOCACHE') | ||||
Pierre-Yves David
|
r19846 | # unfiltered property cache test | ||
print '' | ||||
print '' | ||||
print '=== unfiltered property cache ===' | ||||
print '' | ||||
print 'unficalllog:', unficalllog | ||||
print 'cached value (unfiltered): ', | ||||
print vars(repo).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'cached value ("visible" view): ', | ||||
print vars(visibleview).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'cached value ("immutable" view):', | ||||
print vars(immutableview).get('testcachedunfifoobar', 'NOCACHE') | ||||
print '' | ||||
print '= first access on unfiltered, should do a call' | ||||
print 'access (unfiltered):', repo.testcachedunfifoobar | ||||
print 'unficalllog:', unficalllog | ||||
print 'cached value (unfiltered): ', | ||||
print vars(repo).get('testcachedunfifoobar', 'NOCACHE') | ||||
print '' | ||||
print '= second access on unfiltered, should not do call' | ||||
print 'access (unfiltered):', repo.testcachedunfifoobar | ||||
print 'unficalllog:', unficalllog | ||||
print 'cached value (unfiltered): ', | ||||
print vars(repo).get('testcachedunfifoobar', 'NOCACHE') | ||||
print '' | ||||
print '= access on view should use the unfiltered cache' | ||||
print 'access (unfiltered): ', repo.testcachedunfifoobar | ||||
print 'access ("visible" view): ', visibleview.testcachedunfifoobar | ||||
print 'access ("immutable" view):', immutableview.testcachedunfifoobar | ||||
print 'unficalllog:', unficalllog | ||||
print 'cached value (unfiltered): ', | ||||
print vars(repo).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'cached value ("visible" view): ', | ||||
print vars(visibleview).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'cached value ("immutable" view):', | ||||
print vars(immutableview).get('testcachedunfifoobar', 'NOCACHE') | ||||
print '' | ||||
print '= even if we clear the unfiltered cache' | ||||
del repo.__dict__['testcachedunfifoobar'] | ||||
print 'cached value (unfiltered): ', | ||||
print vars(repo).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'cached value ("visible" view): ', | ||||
print vars(visibleview).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'cached value ("immutable" view):', | ||||
print vars(immutableview).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'unficalllog:', unficalllog | ||||
print 'access ("visible" view): ', visibleview.testcachedunfifoobar | ||||
print 'unficalllog:', unficalllog | ||||
print 'cached value (unfiltered): ', | ||||
print vars(repo).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'cached value ("visible" view): ', | ||||
print vars(visibleview).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'cached value ("immutable" view):', | ||||
print vars(immutableview).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'access ("immutable" view):', immutableview.testcachedunfifoobar | ||||
print 'unficalllog:', unficalllog | ||||
print 'cached value (unfiltered): ', | ||||
print vars(repo).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'cached value ("visible" view): ', | ||||
print vars(visibleview).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'cached value ("immutable" view):', | ||||
print vars(immutableview).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'access (unfiltered): ', repo.testcachedunfifoobar | ||||
print 'unficalllog:', unficalllog | ||||
print 'cached value (unfiltered): ', | ||||
print vars(repo).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'cached value ("visible" view): ', | ||||
print vars(visibleview).get('testcachedunfifoobar', 'NOCACHE') | ||||
print 'cached value ("immutable" view):', | ||||
print vars(immutableview).get('testcachedunfifoobar', 'NOCACHE') | ||||