Mercurial > hgsubversion
view tests/fixtures/copyafterclose.sh @ 1234:d3c79072bc6a
editor: correctly import symlink copy+modify with non-empty prefix
We alwasy fail editing for symlinks, since we strip the leading 'link '
subversion includes when storing in mercurial, and then let svn
attempt to apply deltas against the stripped version. This
unsurprisingly fails, and we write the resulting empty-string to the
Filestore for the current revision, and add the symlink in question to
the missing list to handle stupidly later.
Unfortunately, this would break down because editing adds files to the
store using their absolute path whereas missing files are added
relative to our subdir. the absolut path file appears to win, which
results in us getting a symlink whose target is the empty string.
This fixes the problem by adding missing files to the fileStore using
their absolute path.
author | David Schleimer <dschleimer@fb.com> |
---|---|
date | Mon, 07 Apr 2014 18:28:35 -0700 |
parents | ba8485b9fee0 |
children |
line wrap: on
line source
#!/bin/sh rm -rf temp mkdir temp cd temp svnadmin create repo repo=file://`pwd`/repo svn co $repo wc cd wc mkdir branches trunk tags svn add * svn ci -m 'btt' cd trunk echo trunk1 > file mkdir dir echo trunk1 > dir/file svn add file dir svn ci -m 'Add file and dir.' cd .. svn up svn cp trunk branches/test svn ci -m 'Branch.' svn up cd branches/test/ echo branch1 > file echo branch1 > dir/file svn ci -m 'edit on branch.' cd ../../ svn up cd trunk echo trunk2 > file echo trunk2 > dir/file svn ci -m 'edit on trunk' cd .. svn up svn rm trunk svn ci -m 'Close trunk.' svn up cd branches/test svn rm file svn cp $repo/trunk/file@5 file svn rm dir svn cp $repo/trunk/dir@5 dir svn ci -m 'copy from trunk before close' cd ../.. svn up cd ../.. svnadmin dump temp/repo > copyafterclose.svndump echo echo 'Complete.' echo 'You probably want to clean up temp now.' echo 'Dump in copyafterclose.svndump' exit 0