Commit 26d762d0 authored by maruel@chromium.org's avatar maruel@chromium.org

Add code to FakeReposBase to revert changes committed by a unit tests.

This enables seamless unit tests that check-in files without side-effects on the
remaining unit tests.

BUG=none
TEST=none
TBR=dpranke

Review URL: http://codereview.chromium.org/6250073

git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@73456 0039d316-1c4b-4281-b951-d872f2087c98
parent bf1a7ba9
...@@ -246,6 +246,12 @@ class FakeReposBase(object): ...@@ -246,6 +246,12 @@ class FakeReposBase(object):
self.svnserve = None self.svnserve = None
self.gitdaemon = None self.gitdaemon = None
self.common_init = False self.common_init = False
self.repos_dir = None
self.git_root = None
self.svn_checkout = None
self.svn_repo = None
self.git_dirty = False
self.svn_dirty = False
def trial_dir(self): def trial_dir(self):
if not self.TRIAL_DIR: if not self.TRIAL_DIR:
...@@ -256,17 +262,43 @@ class FakeReposBase(object): ...@@ -256,17 +262,43 @@ class FakeReposBase(object):
def setUp(self): def setUp(self):
"""All late initialization comes here. """All late initialization comes here.
Note that it deletes all trial_dir() and not only repos_dir.""" Note that it deletes all trial_dir() and not only repos_dir.
"""
self.cleanup_dirt()
if not self.common_init: if not self.common_init:
self.common_init = True self.common_init = True
self.repos_dir = os.path.join(self.trial_dir(), 'repos') self.repos_dir = os.path.join(self.trial_dir(), 'repos')
self.git_root = join(self.repos_dir, 'git') self.git_root = join(self.repos_dir, 'git')
self.svn_root = join(self.repos_dir, 'svn_checkout') self.svn_checkout = join(self.repos_dir, 'svn_checkout')
self.svn_repo = join(self.repos_dir, 'svn')
addKill() addKill()
rmtree(self.trial_dir()) rmtree(self.trial_dir())
os.makedirs(self.repos_dir) os.makedirs(self.repos_dir)
atexit.register(self.tearDown) atexit.register(self.tearDown)
def cleanup_dirt(self):
"""For each dirty repository, regenerate it."""
if self.svnserve and self.svn_dirty:
logging.debug('Killing svnserve pid %s' % self.svnserve.pid)
self.svnserve.kill()
self.svnserve = None
if not self.SHOULD_LEAK:
logging.debug('Removing dirty %s' % self.svn_repo)
rmtree(self.svn_repo)
logging.debug('Removing dirty %s' % self.svn_checkout)
rmtree(self.svn_checkout)
else:
logging.warning('Using both leaking checkout and dirty checkout')
if self.gitdaemon and self.git_dirty:
logging.debug('Killing git-daemon pid %s' % self.gitdaemon.pid)
self.gitdaemon.kill()
self.gitdaemon = None
if not self.SHOULD_LEAK:
logging.debug('Removing dirty %s' % self.git_root)
rmtree(self.git_root)
else:
logging.warning('Using both leaking checkout and dirty checkout')
def tearDown(self): def tearDown(self):
if self.svnserve: if self.svnserve:
logging.debug('Killing svnserve pid %s' % self.svnserve.pid) logging.debug('Killing svnserve pid %s' % self.svnserve.pid)
...@@ -299,36 +331,36 @@ class FakeReposBase(object): ...@@ -299,36 +331,36 @@ class FakeReposBase(object):
def setUpSVN(self): def setUpSVN(self):
"""Creates subversion repositories and start the servers.""" """Creates subversion repositories and start the servers."""
self.setUp()
if self.svnserve: if self.svnserve:
return True return True
self.setUp()
root = join(self.repos_dir, 'svn')
try: try:
check_call(['svnadmin', 'create', root]) check_call(['svnadmin', 'create', self.svn_repo])
except OSError: except OSError:
return False return False
write(join(root, 'conf', 'svnserve.conf'), write(join(self.svn_repo, 'conf', 'svnserve.conf'),
'[general]\n' '[general]\n'
'anon-access = read\n' 'anon-access = read\n'
'auth-access = write\n' 'auth-access = write\n'
'password-db = passwd\n') 'password-db = passwd\n')
text = '[users]\n' text = '[users]\n'
text += ''.join('%s = %s\n' % (usr, pwd) for usr, pwd in self.USERS) text += ''.join('%s = %s\n' % (usr, pwd) for usr, pwd in self.USERS)
write(join(root, 'conf', 'passwd'), text) write(join(self.svn_repo, 'conf', 'passwd'), text)
# Start the daemon. # Start the daemon.
cmd = ['svnserve', '-d', '--foreground', '-r', self.repos_dir] cmd = ['svnserve', '-d', '--foreground', '-r', self.repos_dir]
if self.HOST == '127.0.0.1': if self.HOST == '127.0.0.1':
cmd.append('--listen-host=127.0.0.1') cmd.append('--listen-host=127.0.0.1')
self.svnserve = Popen(cmd, cwd=root) self.svnserve = Popen(cmd, cwd=self.svn_repo)
self.populateSvn() self.populateSvn()
self.svn_dirty = False
return True return True
def setUpGIT(self): def setUpGIT(self):
"""Creates git repositories and start the servers.""" """Creates git repositories and start the servers."""
self.setUp()
if self.gitdaemon: if self.gitdaemon:
return True return True
self.setUp()
if sys.platform == 'win32': if sys.platform == 'win32':
return False return False
for repo in ['repo_%d' % r for r in range(1, self.NB_GIT_REPOS + 1)]: for repo in ['repo_%d' % r for r in range(1, self.NB_GIT_REPOS + 1)]:
...@@ -341,11 +373,12 @@ class FakeReposBase(object): ...@@ -341,11 +373,12 @@ class FakeReposBase(object):
cmd.append('--listen=127.0.0.1') cmd.append('--listen=127.0.0.1')
logging.debug(cmd) logging.debug(cmd)
self.gitdaemon = Popen(cmd, cwd=self.repos_dir) self.gitdaemon = Popen(cmd, cwd=self.repos_dir)
self.git_dirty = False
return True return True
def _commit_svn(self, tree): def _commit_svn(self, tree):
self._genTree(self.svn_root, tree) self._genTree(self.svn_checkout, tree)
commit_svn(self.svn_root, self.USERS[0][0], self.USERS[0][1]) commit_svn(self.svn_checkout, self.USERS[0][0], self.USERS[0][1])
if self.svn_revs and self.svn_revs[-1]: if self.svn_revs and self.svn_revs[-1]:
new_tree = self.svn_revs[-1].copy() new_tree = self.svn_revs[-1].copy()
new_tree.update(tree) new_tree.update(tree)
...@@ -378,10 +411,10 @@ class FakeRepos(FakeReposBase): ...@@ -378,10 +411,10 @@ class FakeRepos(FakeReposBase):
def populateSvn(self): def populateSvn(self):
"""Creates a few revisions of changes including DEPS files.""" """Creates a few revisions of changes including DEPS files."""
# Repos # Repos
check_call(['svn', 'checkout', 'svn://127.0.0.1/svn', self.svn_root, '-q', check_call(['svn', 'checkout', 'svn://127.0.0.1/svn', self.svn_checkout,
'--non-interactive', '--no-auth-cache', '-q', '--non-interactive', '--no-auth-cache',
'--username', self.USERS[0][0], '--password', self.USERS[0][1]]) '--username', self.USERS[0][0], '--password', self.USERS[0][1]])
assert os.path.isdir(join(self.svn_root, '.svn')) assert os.path.isdir(join(self.svn_checkout, '.svn'))
def file_system(rev, DEPS): def file_system(rev, DEPS):
fs = { fs = {
'origin': 'svn@%(rev)d\n', 'origin': 'svn@%(rev)d\n',
...@@ -694,7 +727,8 @@ def main(argv): ...@@ -694,7 +727,8 @@ def main(argv):
# Kind of hack. # Kind of hack.
if '-l' in sys.argv: if '-l' in sys.argv:
FakeRepos.SHOULD_LEAK = True FakeReposBase.SHOULD_LEAK = True
print 'Leaking!'
sys.argv.remove('-l') sys.argv.remove('-l')
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment