changeset 963:64d961130a07

editor: do not record invalid path deletion
author Patrick Mezard <patrick@mezard.eu>
date Mon, 15 Oct 2012 22:24:29 +0200 (2012-10-15)
parents 8648ccfb8325
children 27fec8bf9273
files hgsubversion/editor.py tests/fixtures/copies.sh tests/fixtures/copies.svndump tests/test_fetch_mappings.py
diffstat 4 files changed, 50 insertions(+), 9 deletions(-) [+]
line wrap: on
line diff
--- a/hgsubversion/editor.py
+++ b/hgsubversion/editor.py
@@ -225,7 +225,8 @@ class HgEditor(svnwrap.Editor):
                 'opened directory: %s != %s' % (self._opendirs[-1][0], baton))
 
     def _deletefile(self, path):
-        self._deleted.add(path)
+        if self.meta.is_path_valid(path):
+            self._deleted.add(path)
         if path in self._svncopies:
             del self._svncopies[path]
         self._missing.discard(path)
--- a/tests/fixtures/copies.sh
+++ b/tests/fixtures/copies.sh
@@ -21,6 +21,9 @@ svn ci -m 'copy/edit trunk/dir/a'
 svn up
 svn cp trunk/dir2 trunk/dir3
 svn ci -m 'copy dir2 to dir3'
+svn rm trunk/dir3/a
+svn cp trunk/dir2/a trunk/dir3/a
+svn ci -m 'copy and remove'
 cd ..
 
 svnadmin dump testrepo > ../copies.svndump
--- a/tests/fixtures/copies.svndump
+++ b/tests/fixtures/copies.svndump
@@ -1,6 +1,6 @@
 SVN-fs-dump-format-version: 2
 
-UUID: f9962aa6-eec5-4335-8af9-9ae89f4b18b2
+UUID: 6f377846-a035-4244-a154-e87a9351a653
 
 Revision-number: 0
 Prop-content-length: 56
@@ -9,7 +9,7 @@ Content-length: 56
 K 8
 svn:date
 V 27
-2012-10-14T14:22:33.372222Z
+2012-10-15T19:02:56.936694Z
 PROPS-END
 
 Revision-number: 1
@@ -23,7 +23,7 @@ pmezard
 K 8
 svn:date
 V 27
-2012-10-14T14:22:33.393643Z
+2012-10-15T19:02:56.958201Z
 K 7
 svn:log
 V 4
@@ -72,7 +72,7 @@ pmezard
 K 8
 svn:date
 V 27
-2012-10-14T14:22:35.042430Z
+2012-10-15T19:02:58.046478Z
 K 7
 svn:log
 V 21
@@ -109,7 +109,7 @@ pmezard
 K 8
 svn:date
 V 27
-2012-10-14T14:22:38.041919Z
+2012-10-15T19:03:01.045897Z
 K 7
 svn:log
 V 17
@@ -123,3 +123,36 @@ Node-copyfrom-rev: 2
 Node-copyfrom-path: trunk/dir2
 
 
+Revision-number: 4
+Prop-content-length: 117
+Content-length: 117
+
+K 10
+svn:author
+V 7
+pmezard
+K 8
+svn:date
+V 27
+2012-10-15T19:03:03.046654Z
+K 7
+svn:log
+V 15
+copy and remove
+PROPS-END
+
+Node-path: trunk/dir3/a
+Node-kind: file
+Node-action: delete
+
+Node-path: trunk/dir3/a
+Node-kind: file
+Node-action: add
+Node-copyfrom-rev: 2
+Node-copyfrom-path: trunk/dir2/a
+Text-copy-source-md5: dd8c6a395b5dd36c56d23275028f526c
+Text-copy-source-sha1: 05dec960e24d918b8a73a1c53bcbbaac2ee5c2e0
+
+
+
+
--- a/tests/test_fetch_mappings.py
+++ b/tests/test_fetch_mappings.py
@@ -152,14 +152,14 @@ class MapTests(test_util.TestBase):
         # directory.
         repo = self._loadwithfilemap('copies.svndump', "exclude dir2\n",
                 failonmissing=False)
-        self.assertEqual(['dir/a', 'dir3/a'], list(repo['tip']))
+        self.assertEqual(['dir/a', 'dir3/a'], list(repo[2]))
 
     def test_file_map_exclude_copy_source_and_dest(self):
         # dir3 is excluded and copied from dir2 which is also excluded.
         # dir3 files should not be marked as missing and fetched.
         repo = self._loadwithfilemap('copies.svndump',
                 "exclude dir2\nexclude dir3\n")
-        self.assertEqual(['dir/a'], list(repo['tip']))
+        self.assertEqual(['dir/a'], list(repo[2]))
 
     def test_file_map_include_file_exclude_dir(self):
         # dir3 is excluded but we want dir3/a, which is also copied from
@@ -167,7 +167,11 @@ class MapTests(test_util.TestBase):
         repo = self._loadwithfilemap('copies.svndump',
                 "include .\nexclude dir2\nexclude dir3\ninclude dir3/a\n",
                 failonmissing=False)
-        self.assertEqual(['dir/a', 'dir3/a'], list(repo['tip']))
+        self.assertEqual(['dir/a', 'dir3/a'], list(repo[2]))
+
+    def test_file_map_delete_dest(self):
+        repo = self._loadwithfilemap('copies.svndump', 'exclude dir3\n')
+        self.assertEqual(['dir/a', 'dir2/a'], list(repo[3]))
 
     def test_branchmap(self, stupid=False):
         repo_path = self.load_svndump('branchmap.svndump')