Mercurial > hgsubversion
comparison tests/test_push_renames.py @ 84:01e747937d35
test_util: add commitchanges() to TestBase
| author | Patrick Mezard <pmezard@gmail.com> |
|---|---|
| date | Fri, 14 Nov 2008 16:18:24 -0600 |
| parents | 71de43e9f614 |
| children | 9b5e528f67f8 |
comparison
equal
deleted
inserted
replaced
| 83:6c9b7cf1c5aa | 84:01e747937d35 |
|---|---|
| 1 import os | |
| 2 import sys | 1 import sys |
| 3 import tempfile | |
| 4 import unittest | 2 import unittest |
| 5 | 3 |
| 6 from mercurial import context | |
| 7 from mercurial import commands | |
| 8 from mercurial import hg | |
| 9 from mercurial import node | |
| 10 from mercurial import ui | |
| 11 from mercurial import revlog | |
| 12 | |
| 13 import fetch_command | |
| 14 import push_cmd | |
| 15 import test_util | 4 import test_util |
| 16 | 5 |
| 17 class TestPushRenames(test_util.TestBase): | 6 class TestPushRenames(test_util.TestBase): |
| 18 def setUp(self): | 7 def setUp(self): |
| 19 test_util.TestBase.setUp(self) | 8 test_util.TestBase.setUp(self) |
| 20 test_util.load_fixture_and_fetch('pushrenames.svndump', | 9 test_util.load_fixture_and_fetch('pushrenames.svndump', |
| 21 self.repo_path, | 10 self.repo_path, |
| 22 self.wc_path, | 11 self.wc_path, |
| 23 True) | 12 True) |
| 24 | |
| 25 def _commitchanges(self, repo, changes): | |
| 26 parentctx = repo['tip'] | |
| 27 | |
| 28 changed, removed = [], [] | |
| 29 for source, dest, newdata in changes: | |
| 30 if dest is None: | |
| 31 removed.append(source) | |
| 32 else: | |
| 33 changed.append(dest) | |
| 34 | |
| 35 def filectxfn(repo, memctx, path): | |
| 36 if path in removed: | |
| 37 raise IOError() | |
| 38 entry = [e for e in changes if path == e[1]][0] | |
| 39 source, dest, newdata = entry | |
| 40 if newdata is None: | |
| 41 newdata = parentctx[source].data() | |
| 42 copied = None | |
| 43 if source != dest: | |
| 44 copied = source | |
| 45 return context.memfilectx(path=dest, | |
| 46 data=newdata, | |
| 47 islink=False, | |
| 48 isexec=False, | |
| 49 copied=copied) | |
| 50 | |
| 51 ctx = context.memctx(repo, | |
| 52 (parentctx.node(), node.nullid), | |
| 53 'automated test', | |
| 54 changed + removed, | |
| 55 filectxfn, | |
| 56 'an_author', | |
| 57 '2008-10-07 20:59:48 -0500') | |
| 58 return repo.commitctx(ctx) | |
| 59 | 13 |
| 60 def _debug_print_copies(self, ctx): | 14 def _debug_print_copies(self, ctx): |
| 61 w = sys.stderr.write | 15 w = sys.stderr.write |
| 62 for f in ctx.files(): | 16 for f in ctx.files(): |
| 63 if f not in ctx: | 17 if f not in ctx: |
| 78 self.assertEqual(data, ctx[dest].data()) | 32 self.assertEqual(data, ctx[dest].data()) |
| 79 if dest != source: | 33 if dest != source: |
| 80 copy = ctx[dest].renamed() | 34 copy = ctx[dest].renamed() |
| 81 self.assertEqual(copy[0], source) | 35 self.assertEqual(copy[0], source) |
| 82 | 36 |
| 83 def test_push_renames(self, commit=True): | 37 def test_push_renames(self): |
| 84 repo = self.repo | 38 repo = self.repo |
| 85 | 39 |
| 86 changes = [ | 40 changes = [ |
| 87 # Regular copy of a single file | 41 # Regular copy of a single file |
| 88 ('a', 'a2', None), | 42 ('a', 'a2', None), |
| 100 # Double copy and removal (aka copy and move) | 54 # Double copy and removal (aka copy and move) |
| 101 ('e', 'e2', 'e\ne2\n'), | 55 ('e', 'e2', 'e\ne2\n'), |
| 102 ('e', 'e3', 'e\ne3\n'), | 56 ('e', 'e3', 'e\ne3\n'), |
| 103 ('e', None, None), | 57 ('e', None, None), |
| 104 ] | 58 ] |
| 105 self._commitchanges(repo, changes) | 59 self.commitchanges(changes) |
| 106 | 60 self.pushrevisions() |
| 107 hg.update(repo, repo['tip'].node()) | |
| 108 push_cmd.push_revisions_to_subversion( | |
| 109 ui.ui(), repo=self.repo, hg_repo_path=self.wc_path, | |
| 110 svn_url=test_util.fileurl(self.repo_path)) | |
| 111 tip = self.repo['tip'] | 61 tip = self.repo['tip'] |
| 112 # self._debug_print_copies(tip) | 62 # self._debug_print_copies(tip) |
| 113 self.assertchanges(changes, tip) | 63 self.assertchanges(changes, tip) |
| 114 | 64 |
| 115 def suite(): | 65 def suite(): |
