Mercurial > hgsubversion
comparison tests/test_pull.py @ 283:521d9c1bb11d
Implement -u/--update support when pulling.
Status messages now more closely follow standard hg pull. Added generic pull
tests as well as specific tests for this change.
| author | Martijn Pieters <mj@zopatista.com> |
|---|---|
| date | Mon, 27 Apr 2009 09:39:39 -0500 |
| parents | |
| children | 75f082b5897e |
comparison
equal
deleted
inserted
replaced
| 282:77892f67b1cd | 283:521d9c1bb11d |
|---|---|
| 1 import test_util | |
| 2 | |
| 3 import os.path | |
| 4 import subprocess | |
| 5 from mercurial import ui | |
| 6 | |
| 7 import wrappers | |
| 8 | |
| 9 | |
| 10 class TestPull(test_util.TestBase): | |
| 11 def setUp(self): | |
| 12 super(TestPull, self).setUp() | |
| 13 self.svn_wc = None | |
| 14 | |
| 15 def _load_fixture_and_fetch(self, fixture_name): | |
| 16 return test_util.load_fixture_and_fetch(fixture_name, self.repo_path, | |
| 17 self.wc_path, stupid=False, | |
| 18 noupdate=False) | |
| 19 | |
| 20 def _add_svn_rev(self, changes): | |
| 21 # changes is a dict of filename -> contents | |
| 22 if self.svn_wc is None: | |
| 23 self.svn_wc = os.path.join(self.tmpdir, 'testsvn_wc') | |
| 24 subprocess.call([ | |
| 25 'svn', 'co', '-q', test_util.fileurl(self.repo_path), | |
| 26 self.svn_wc | |
| 27 ]) | |
| 28 | |
| 29 for filename, contents in changes.iteritems(): | |
| 30 # filenames are / separated | |
| 31 filename = filename.replace('/', os.path.sep) | |
| 32 filename = os.path.join(self.svn_wc, filename) | |
| 33 open(filename, 'w').write(contents) | |
| 34 subprocess.call(['svn', 'add', '-q', filename]) # may be redundant | |
| 35 subprocess.call([ | |
| 36 'svn', 'commit', '-q', self.svn_wc, '-m', 'test changes']) | |
| 37 | |
| 38 def test_nochanges(self): | |
| 39 repo = self._load_fixture_and_fetch('single_rev.svndump') | |
| 40 state = repo.parents() | |
| 41 wrappers.pull(None, ui.ui(), repo) | |
| 42 self.assertEqual(state, repo.parents()) | |
| 43 | |
| 44 def test_onerevision_noupdate(self): | |
| 45 repo = self._load_fixture_and_fetch('single_rev.svndump') | |
| 46 state = repo.parents() | |
| 47 self._add_svn_rev({'trunk/alpha': 'Changed'}) | |
| 48 wrappers.pull(None, ui.ui(), repo) | |
| 49 self.assertEqual(state, repo.parents()) | |
| 50 self.assertTrue('tip' not in repo[None].tags()) | |
| 51 | |
| 52 def test_onerevision_doupdate(self): | |
| 53 repo = self._load_fixture_and_fetch('single_rev.svndump') | |
| 54 state = repo.parents() | |
| 55 self._add_svn_rev({'trunk/alpha': 'Changed'}) | |
| 56 wrappers.pull(None, ui.ui(), repo, update=True) | |
| 57 self.failIfEqual(state, repo.parents()) | |
| 58 self.assertTrue('tip' in repo[None].tags()) | |
| 59 | |
| 60 def test_onerevision_divergent(self): | |
| 61 repo = self._load_fixture_and_fetch('single_rev.svndump') | |
| 62 self.commitchanges((('alpha', 'alpha', 'Changed another way'),)) | |
| 63 state = repo.parents() | |
| 64 self._add_svn_rev({'trunk/alpha': 'Changed one way'}) | |
| 65 wrappers.pull(None, ui.ui(), repo, update=True) | |
| 66 self.assertEqual(state, repo.parents()) | |
| 67 self.assertTrue('tip' not in repo[None].tags()) | |
| 68 self.assertEqual(len(repo.heads()), 2) | |
| 69 | |
| 70 def suite(): | |
| 71 import unittest, sys | |
| 72 return unittest.findTestCases(sys.modules[__name__]) |
