test-import
334 lines
| 6.9 KiB
| text/plain
|
TextLexer
/ tests / test-import
Vadim Gelfer
|
r2513 | #!/bin/sh | ||
hg init a | ||||
"Mathieu Clabaut "
|
r2773 | mkdir a/d1 | ||
mkdir a/d1/d2 | ||||
Vadim Gelfer
|
r2513 | echo line 1 > a/a | ||
"Mathieu Clabaut "
|
r2773 | echo line 1 > a/d1/d2/a | ||
Martin Geisler
|
r8167 | hg --cwd a ci -Ama | ||
Vadim Gelfer
|
r2513 | |||
echo line 2 >> a/a | ||||
hg --cwd a ci -u someone -d '1 0' -m'second change' | ||||
echo % import exported patch | ||||
hg clone -r0 a b | ||||
hg --cwd a export tip > tip.patch | ||||
hg --cwd b import ../tip.patch | ||||
echo % message should be same | ||||
hg --cwd b tip | grep 'second change' | ||||
echo % committer should be same | ||||
hg --cwd b tip | grep someone | ||||
Thomas Arendsen Hein
|
r3988 | rm -r b | ||
Vadim Gelfer
|
r2513 | |||
Patrick Mezard
|
r7247 | echo % import exported patch with external patcher | ||
cat > dummypatch.py <<EOF | ||||
print 'patching file a' | ||||
file('a', 'wb').write('line2\n') | ||||
EOF | ||||
chmod +x dummypatch.py | ||||
hg clone -r0 a b | ||||
hg --cwd a export tip > tip.patch | ||||
hg --config ui.patch='python ../dummypatch.py' --cwd b import ../tip.patch | ||||
cat b/a | ||||
rm -r b | ||||
Vadim Gelfer
|
r2513 | echo % import of plain diff should fail without message | ||
hg clone -r0 a b | ||||
hg --cwd a diff -r0:1 > tip.patch | ||||
hg --cwd b import ../tip.patch | ||||
Thomas Arendsen Hein
|
r3988 | rm -r b | ||
Vadim Gelfer
|
r2513 | |||
echo % import of plain diff should be ok with message | ||||
hg clone -r0 a b | ||||
hg --cwd a diff -r0:1 > tip.patch | ||||
hg --cwd b import -mpatch ../tip.patch | ||||
Thomas Arendsen Hein
|
r3988 | rm -r b | ||
Vadim Gelfer
|
r2513 | |||
Jesse Glick
|
r5953 | echo % import of plain diff with specific date and user | ||
hg clone -r0 a b | ||||
hg --cwd a diff -r0:1 > tip.patch | ||||
hg --cwd b import -mpatch -d '1 0' -u 'user@nowhere.net' ../tip.patch | ||||
hg -R b tip -pv | ||||
rm -r b | ||||
Thomas Arendsen Hein
|
r5937 | echo % import of plain diff should be ok with --no-commit | ||
hg clone -r0 a b | ||||
hg --cwd a diff -r0:1 > tip.patch | ||||
hg --cwd b import --no-commit ../tip.patch | ||||
hg --cwd b diff --nodates | ||||
rm -r b | ||||
Alexis S. L. Carvalho
|
r4230 | echo % hg -R repo import | ||
# put the clone in a subdir - having a directory named "a" | ||||
# used to hide a bug. | ||||
mkdir dir | ||||
hg clone -r0 a dir/b | ||||
hg --cwd a export tip > dir/tip.patch | ||||
cd dir | ||||
hg -R b import tip.patch | ||||
cd .. | ||||
rm -r dir | ||||
Vadim Gelfer
|
r2513 | echo % import from stdin | ||
hg clone -r0 a b | ||||
hg --cwd a export tip | hg --cwd b import - | ||||
Thomas Arendsen Hein
|
r3988 | rm -r b | ||
Vadim Gelfer
|
r2513 | |||
echo % override commit message | ||||
hg clone -r0 a b | ||||
hg --cwd a export tip | hg --cwd b import -m 'override' - | ||||
hg --cwd b tip | grep override | ||||
Thomas Arendsen Hein
|
r3988 | rm -r b | ||
Vadim Gelfer
|
r2513 | |||
cat > mkmsg.py <<EOF | ||||
import email.Message, sys | ||||
msg = email.Message.Message() | ||||
Patrick Mezard
|
r5530 | msg.set_payload('email commit message\n' + open('tip.patch', 'rb').read()) | ||
Vadim Gelfer
|
r2513 | msg['Subject'] = 'email patch' | ||
msg['From'] = 'email patcher' | ||||
sys.stdout.write(msg.as_string()) | ||||
EOF | ||||
echo % plain diff in email, subject, message body | ||||
hg clone -r0 a b | ||||
hg --cwd a diff -r0:1 > tip.patch | ||||
python mkmsg.py > msg.patch | ||||
hg --cwd b import ../msg.patch | ||||
hg --cwd b tip | grep email | ||||
Thomas Arendsen Hein
|
r3988 | rm -r b | ||
Vadim Gelfer
|
r2513 | |||
echo % plain diff in email, no subject, message body | ||||
hg clone -r0 a b | ||||
grep -v '^Subject:' msg.patch | hg --cwd b import - | ||||
Thomas Arendsen Hein
|
r3988 | rm -r b | ||
Vadim Gelfer
|
r2513 | |||
echo % plain diff in email, subject, no message body | ||||
hg clone -r0 a b | ||||
grep -v '^email ' msg.patch | hg --cwd b import - | ||||
Thomas Arendsen Hein
|
r3988 | rm -r b | ||
Vadim Gelfer
|
r2513 | |||
echo % plain diff in email, no subject, no message body, should fail | ||||
hg clone -r0 a b | ||||
Danek Duvall
|
r2843 | egrep -v '^(Subject|email)' msg.patch | hg --cwd b import - | ||
Thomas Arendsen Hein
|
r3988 | rm -r b | ||
Vadim Gelfer
|
r2513 | |||
echo % hg export in email, should use patch header | ||||
hg clone -r0 a b | ||||
hg --cwd a export tip > tip.patch | ||||
python mkmsg.py | hg --cwd b import - | ||||
hg --cwd b tip | grep second | ||||
Thomas Arendsen Hein
|
r3988 | rm -r b | ||
Vadim Gelfer
|
r2513 | |||
Thomas Arendsen Hein
|
r4779 | # subject: duplicate detection, removal of [PATCH] | ||
Patrick Mezard
|
r5418 | # The '---' tests the gitsendmail handling without proper mail headers | ||
Thomas Arendsen Hein
|
r4779 | cat > mkmsg2.py <<EOF | ||
import email.Message, sys | ||||
msg = email.Message.Message() | ||||
Patrick Mezard
|
r5418 | msg.set_payload('email patch\n\nnext line\n---\n' + open('tip.patch').read()) | ||
Thomas Arendsen Hein
|
r4779 | msg['Subject'] = '[PATCH] email patch' | ||
msg['From'] = 'email patcher' | ||||
sys.stdout.write(msg.as_string()) | ||||
EOF | ||||
echo '% plain diff in email, [PATCH] subject, message body with subject' | ||||
hg clone -r0 a b | ||||
hg --cwd a diff -r0:1 > tip.patch | ||||
python mkmsg2.py | hg --cwd b import - | ||||
hg --cwd b tip --template '{desc}\n' | ||||
rm -r b | ||||
Alexis S. L. Carvalho
|
r5986 | # We weren't backing up the correct dirstate file when importing many patches | ||
# (issue963) | ||||
echo '% import patch1 patch2; rollback' | ||||
echo line 3 >> a/a | ||||
hg --cwd a ci -m'third change' | ||||
hg --cwd a export -o '../patch%R' 1 2 | ||||
hg clone -qr0 a b | ||||
Martin Geisler
|
r8523 | hg --cwd b parents --template 'parent: {rev}\n' | ||
Alexis S. L. Carvalho
|
r5986 | hg --cwd b import ../patch1 ../patch2 | ||
hg --cwd b rollback | ||||
Martin Geisler
|
r8523 | hg --cwd b parents --template 'parent: {rev}\n' | ||
Alexis S. L. Carvalho
|
r5986 | rm -r b | ||
Thomas Arendsen Hein
|
r4779 | |||
"Mathieu Clabaut "
|
r2773 | # bug non regression test | ||
# importing a patch in a subdirectory failed at the commit stage | ||||
echo line 2 >> a/d1/d2/a | ||||
hg --cwd a ci -u someoneelse -d '1 0' -m'subdir change' | ||||
echo % hg import in a subdirectory | ||||
hg clone -r0 a b | ||||
hg --cwd a export tip | sed -e 's/d1\/d2\///' > tip.patch | ||||
Danek Duvall
|
r2843 | dir=`pwd` | ||
cd b/d1/d2 2>&1 > /dev/null | ||||
"Mathieu Clabaut "
|
r2773 | hg import ../../../tip.patch | ||
Danek Duvall
|
r2843 | cd $dir | ||
"Mathieu Clabaut "
|
r2773 | echo "% message should be 'subdir change'" | ||
hg --cwd b tip | grep 'subdir change' | ||||
echo "% committer should be 'someoneelse'" | ||||
hg --cwd b tip | grep someoneelse | ||||
echo "% should be empty" | ||||
hg --cwd b status | ||||
Patrick Mezard
|
r5548 | |||
# Test fuzziness (ambiguous patch location, fuzz=2) | ||||
echo % test fuzziness | ||||
hg init fuzzy | ||||
cd fuzzy | ||||
echo line1 > a | ||||
echo line0 >> a | ||||
echo line3 >> a | ||||
hg ci -Am adda | ||||
echo line1 > a | ||||
echo line2 >> a | ||||
echo line0 >> a | ||||
echo line3 >> a | ||||
hg ci -m change a | ||||
hg export tip > tip.patch | ||||
hg up -C 0 | ||||
echo line1 > a | ||||
echo line0 >> a | ||||
echo line1 >> a | ||||
echo line0 >> a | ||||
hg ci -m brancha | ||||
hg import -v tip.patch | ||||
cd .. | ||||
Patrick Mezard
|
r5852 | |||
# Test hunk touching empty files (issue906) | ||||
hg init empty | ||||
cd empty | ||||
touch a | ||||
touch b1 | ||||
touch c1 | ||||
echo d > d | ||||
hg ci -Am init | ||||
echo a > a | ||||
echo b > b1 | ||||
hg mv b1 b2 | ||||
echo c > c1 | ||||
hg copy c1 c2 | ||||
rm d | ||||
touch d | ||||
hg diff --git | ||||
hg ci -m empty | ||||
hg export --git tip > empty.diff | ||||
hg up -C 0 | ||||
hg import empty.diff | ||||
for name in a b1 b2 c1 c2 d; | ||||
do | ||||
echo % $name file | ||||
test -f $name && cat $name | ||||
done | ||||
cd .. | ||||
Patrick Mezard
|
r6179 | # Test importing a patch ending with a binary file removal | ||
echo % test trailing binary removal | ||||
hg init binaryremoval | ||||
cd binaryremoval | ||||
echo a > a | ||||
python -c "file('b', 'wb').write('a\x00b')" | ||||
hg ci -Am addall | ||||
hg rm a | ||||
hg rm b | ||||
hg st | ||||
hg ci -m remove | ||||
hg export --git . > remove.diff | ||||
cat remove.diff | grep git | ||||
hg up -C 0 | ||||
hg import remove.diff | ||||
hg manifest | ||||
cd .. | ||||
Patrick Mezard
|
r6295 | echo % 'test update+rename with common name (issue 927)' | ||
hg init t | ||||
cd t | ||||
touch a | ||||
hg ci -Am t | ||||
echo a > a | ||||
# Here, bfile.startswith(afile) | ||||
hg copy a a2 | ||||
hg ci -m copya | ||||
hg export --git tip > copy.diff | ||||
hg up -C 0 | ||||
hg import copy.diff | ||||
echo % view a | ||||
# a should contain an 'a' | ||||
cat a | ||||
echo % view a2 | ||||
# and a2 should have duplicated it | ||||
cat a2 | ||||
cd .. | ||||
Benoit Boissinot
|
r6520 | |||
echo % 'test -p0' | ||||
hg init p0 | ||||
cd p0 | ||||
echo a > a | ||||
hg ci -Am t | ||||
hg import -p0 - << EOF | ||||
foobar | ||||
--- a Sat Apr 12 22:43:58 2008 -0400 | ||||
+++ a Sat Apr 12 22:44:05 2008 -0400 | ||||
@@ -1,1 +1,1 @@ | ||||
-a | ||||
+bb | ||||
EOF | ||||
hg status | ||||
cat a | ||||
cd .. | ||||
Brendan Cully
|
r6758 | |||
echo % 'test paths outside repo root' | ||||
mkdir outside | ||||
touch outside/foo | ||||
hg init inside | ||||
cd inside | ||||
hg import - <<EOF | ||||
diff --git a/a b/b | ||||
rename from ../outside/foo | ||||
rename to bar | ||||
EOF | ||||
cd .. | ||||
Brendan Cully
|
r7402 | |||
echo '% test import with similarity (issue295)' | ||||
hg init sim | ||||
cd sim | ||||
echo 'this is a test' > a | ||||
hg ci -Ama | ||||
cat > ../rename.diff <<EOF | ||||
diff --git a/a b/a | ||||
deleted file mode 100644 | ||||
--- a/a | ||||
+++ /dev/null | ||||
@@ -1,1 +0,0 @@ | ||||
-this is a test | ||||
diff --git a/b b/b | ||||
new file mode 100644 | ||||
--- /dev/null | ||||
+++ b/b | ||||
@@ -0,0 +1,2 @@ | ||||
+this is a test | ||||
+foo | ||||
EOF | ||||
hg import --no-commit -v -s 1 ../rename.diff | ||||
hg st -C | ||||
hg revert -a | ||||
rm b | ||||
hg import --no-commit -v -s 100 ../rename.diff | ||||
hg st -C | ||||
cd .. | ||||
Vsevolod Solovyov
|
r7971 | |||
echo '% add empty file from the end of patch (issue 1495)' | ||||
hg init addemptyend | ||||
cd addemptyend | ||||
touch a | ||||
hg addremove | ||||
hg ci -m "commit" | ||||
cat > a.patch <<EOF | ||||
diff --git a/a b/a | ||||
--- a/a | ||||
+++ b/a | ||||
@@ -0,0 +1,1 @@ | ||||
+a | ||||
diff --git a/b b/b | ||||
new file mode 100644 | ||||
EOF | ||||
hg import --no-commit a.patch | ||||
cd .. | ||||