##// END OF EJS Templates
archive: set date to 1980 for very old zip files...
archive: set date to 1980 for very old zip files The zip file format stores the date using "MS-DOS format" which apparently means that they use 1980 as their epoch. Python's zipfile module emits deprecation warnings of this form /usr/lib/python2.6/zipfile.py:1108: DeprecationWarning: struct integer overflow masking is deprecated self.fp.write(zinfo.FileHeader()) /usr/lib/python2.6/zipfile.py:1108: DeprecationWarning: 'H' format requires 0 <= number <= 65535 self.fp.write(zinfo.FileHeader()) /home/mg/src/mercurial-crew/mercurial/archival.py:169: DeprecationWarning: struct integer overflow masking is deprecated self.z.close() /home/mg/src/mercurial-crew/mercurial/archival.py:169: DeprecationWarning: 'H' format requires 0 <= number <= 65535 self.z.close() when it is given such old timestamps. This fixes this by silently clamping the date to 1980.

File last commit:

r11407:f5be4409 default
r12319:381f1312 stable
Show More
test-import
497 lines | 10.2 KiB | text/plain | TextLexer
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
r2513 #!/bin/sh
hg init a
"Mathieu Clabaut "
Import say a file is not tracked after patching : test case
r2773 mkdir a/d1
mkdir a/d1/d2
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
r2513 echo line 1 > a/a
"Mathieu Clabaut "
Import say a file is not tracked after patching : test case
r2773 echo line 1 > a/d1/d2/a
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg --cwd a ci -Ama
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
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
Don't use -f for rm in tests where not needed. Drop /bin/ from /bin/rm.
r3988 rm -r b
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
r2513
Patrick Mezard
patch: fix patched files records in externalpatcher()
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
import: added tests, fixed bugs found by tests and asak.
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
Don't use -f for rm in tests where not needed. Drop /bin/ from /bin/rm.
r3988 rm -r b
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
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
Don't use -f for rm in tests where not needed. Drop /bin/ from /bin/rm.
r3988 rm -r b
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
r2513
Jesse Glick
Permitting the import command to accept a --user option....
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
Test case for hg import --no-commit
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
Fix handling of paths when run outside the repo....
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
import: added tests, fixed bugs found by tests and asak.
r2513 echo % import from stdin
hg clone -r0 a b
hg --cwd a export tip | hg --cwd b import -
Thomas Arendsen Hein
Don't use -f for rm in tests where not needed. Drop /bin/ from /bin/rm.
r3988 rm -r b
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
r2513
Brendan Cully
import: import each patch in a file or stream as a separate change...
r10384 echo % import two patches in one stream
hg init b
hg --cwd a export 0:tip | hg --cwd b import -
hg --cwd a id
hg --cwd b id
rm -r b
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
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
Don't use -f for rm in tests where not needed. Drop /bin/ from /bin/rm.
r3988 rm -r b
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
r2513
cat > mkmsg.py <<EOF
import email.Message, sys
msg = email.Message.Message()
Patrick Mezard
test-import: read email payload in binary mode
r5530 msg.set_payload('email commit message\n' + open('tip.patch', 'rb').read())
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
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
Don't use -f for rm in tests where not needed. Drop /bin/ from /bin/rm.
r3988 rm -r b
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
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
Don't use -f for rm in tests where not needed. Drop /bin/ from /bin/rm.
r3988 rm -r b
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
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
Don't use -f for rm in tests where not needed. Drop /bin/ from /bin/rm.
r3988 rm -r b
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
r2513
echo % plain diff in email, no subject, no message body, should fail
hg clone -r0 a b
Danek Duvall
Fix some tests for portability.
r2843 egrep -v '^(Subject|email)' msg.patch | hg --cwd b import -
Thomas Arendsen Hein
Don't use -f for rm in tests where not needed. Drop /bin/ from /bin/rm.
r3988 rm -r b
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
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
Don't use -f for rm in tests where not needed. Drop /bin/ from /bin/rm.
r3988 rm -r b
Vadim Gelfer
import: added tests, fixed bugs found by tests and asak.
r2513
Thomas Arendsen Hein
Added import test for [PATCH] subject and message body with subject
r4779 # subject: duplicate detection, removal of [PATCH]
Patrick Mezard
patch: fix git sendmail handling without proper mail headers
r5418 # The '---' tests the gitsendmail handling without proper mail headers
Thomas Arendsen Hein
Added import test for [PATCH] subject and message body with subject
r4779 cat > mkmsg2.py <<EOF
import email.Message, sys
msg = email.Message.Message()
Patrick Mezard
patch: fix git sendmail handling without proper mail headers
r5418 msg.set_payload('email patch\n\nnext line\n---\n' + open('tip.patch').read())
Thomas Arendsen Hein
Added import test for [PATCH] subject and message body with subject
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
hg import: write the dirstate after every commit...
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
tests: replace #...# syntax with {...}
r8523 hg --cwd b parents --template 'parent: {rev}\n'
Alexis S. L. Carvalho
hg import: write the dirstate after every commit...
r5986 hg --cwd b import ../patch1 ../patch2
hg --cwd b rollback
Martin Geisler
tests: replace #...# syntax with {...}
r8523 hg --cwd b parents --template 'parent: {rev}\n'
Alexis S. L. Carvalho
hg import: write the dirstate after every commit...
r5986 rm -r b
Thomas Arendsen Hein
Added import test for [PATCH] subject and message body with subject
r4779
"Mathieu Clabaut "
Import say a file is not tracked after patching : test case
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
Fix some tests for portability.
r2843 dir=`pwd`
cd b/d1/d2 2>&1 > /dev/null
"Mathieu Clabaut "
Import say a file is not tracked after patching : test case
r2773 hg import ../../../tip.patch
Mads Kiilerich
Tests with spaces in paths...
r10775 cd "$dir"
"Mathieu Clabaut "
Import say a file is not tracked after patching : test case
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
test-import: test fuzziness, ambiguous patch locations
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
Patrick Mezard
patch: fix patching with fuzz and eol normalization
r10524 hg import --no-commit -v tip.patch
hg revert -a
echo '% test fuzziness with eol=auto'
hg --config patch.eol=auto import --no-commit -v tip.patch
Patrick Mezard
test-import: test fuzziness, ambiguous patch locations
r5548 cd ..
Patrick Mezard
patch: handle empty vs no file in git patches (issue906)
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
patch: fix iterhunks() with trailing binary file removal...
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
patch: fix corner case with update + copy patch handling (issue 937)...
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
fix import with -p0
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
Check that git patches only touch files under root
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
import: add similarity option (issue295)
r7402
Mads Kiilerich
test-import: test git patch import with strip...
r11407 echo '% test import with similarity and git and strip (issue295 et al.)'
Brendan Cully
import: add similarity option (issue295)
r7402 hg init sim
cd sim
echo 'this is a test' > a
hg ci -Ama
cat > ../rename.diff <<EOF
Mads Kiilerich
test-import: test git patch import with strip...
r11407 diff --git a/foo/a b/foo/a
Brendan Cully
import: add similarity option (issue295)
r7402 deleted file mode 100644
Mads Kiilerich
test-import: test git patch import with strip...
r11407 --- a/foo/a
Brendan Cully
import: add similarity option (issue295)
r7402 +++ /dev/null
@@ -1,1 +0,0 @@
-this is a test
Mads Kiilerich
test-import: test git patch import with strip...
r11407 diff --git a/foo/b b/foo/b
Brendan Cully
import: add similarity option (issue295)
r7402 new file mode 100644
--- /dev/null
Mads Kiilerich
test-import: test git patch import with strip...
r11407 +++ b/foo/b
Brendan Cully
import: add similarity option (issue295)
r7402 @@ -0,0 +1,2 @@
+this is a test
+foo
EOF
Mads Kiilerich
test-import: test git patch import with strip...
r11407 hg import --no-commit -v -s 1 ../rename.diff -p2
Brendan Cully
import: add similarity option (issue295)
r7402 hg st -C
hg revert -a
rm b
Mads Kiilerich
test-import: test git patch import with strip...
r11407 hg import --no-commit -v -s 100 ../rename.diff -p2
Brendan Cully
import: add similarity option (issue295)
r7402 hg st -C
cd ..
Vsevolod Solovyov
Fix issue1495, corner case of adding empty files via patching
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 ..
Patrick Mezard
patch: do not swallow header-like patch first line (issue1859)...
r9573
Brendan Cully
patch: create file even if source is not /dev/null...
r9328 echo '% create file when source is not /dev/null'
cat > create.patch <<EOF
diff -Naur proj-orig/foo proj-new/foo
--- proj-orig/foo 1969-12-31 16:00:00.000000000 -0800
+++ proj-new/foo 2009-07-17 16:50:45.801368000 -0700
@@ -0,0 +1,1 @@
+a
EOF
Benoit Boissinot
patch: try harder to find the file to patch on file creation (issue2041)...
r10745 # some people have patches like the following too
cat > create2.patch <<EOF
diff -Naur proj-orig/foo proj-new/foo
--- proj-orig/foo.orig 1969-12-31 16:00:00.000000000 -0800
+++ proj-new/foo 2009-07-17 16:50:45.801368000 -0700
@@ -0,0 +1,1 @@
+a
EOF
Brendan Cully
patch: create file even if source is not /dev/null...
r9328 hg init oddcreate
cd oddcreate
hg import --no-commit ../create.patch
cat foo
Benoit Boissinot
patch: try harder to find the file to patch on file creation (issue2041)...
r10745 rm foo
hg revert foo
hg import --no-commit ../create2.patch
cat foo
Matt Mackall
Merge with stable
r9576
Patrick Mezard
patch: do not swallow header-like patch first line (issue1859)...
r9573 echo % 'first line mistaken for email headers (issue 1859)'
hg init emailconfusion
cd emailconfusion
cat > a.patch <<EOF
module: summary
description
diff -r 000000000000 -r 9b4c1e343b55 test.txt
--- /dev/null
+++ b/a
@@ -0,0 +1,1 @@
+a
EOF
hg import -d '0 0' a.patch
hg parents -v
cd ..
Benoit Boissinot
patch: enhance diff detection regexp, allow '--- ' in patch message
r10729 echo % '--- in commit message'
hg init commitconfusion
cd commitconfusion
cat > a.patch <<EOF
module: summary
--- description
diff --git a/a b/a
new file mode 100644
--- /dev/null
+++ b/a
@@ -0,0 +1,1 @@
+a
EOF
hg import -d '0 0' a.patch
hg parents -v
cd ..
Brendan Cully
import: if in doubt, consume stream until start of diff...
r10501 echo '% tricky header splitting'
cat > trickyheaders.patch <<EOF
From: User A <user@a>
Subject: [PATCH] from: tricky!
# HG changeset patch
# User User B
# Date 1266264441 18000
# Branch stable
# Node ID f2be6a1170ac83bf31cb4ae0bad00d7678115bc0
# Parent 0000000000000000000000000000000000000000
from: tricky!
That is not a header.
diff -r 000000000000 -r f2be6a1170ac foo
--- /dev/null
+++ b/foo
@@ -0,0 +1,1 @@
+foo
EOF
hg init trickyheaders
cd trickyheaders
hg import -d '0 0' ../trickyheaders.patch
hg export --git tip
cd ..
Benoit Boissinot
patch: more precise NoHunk, raised for every file (issue2102)
r10748
echo '% issue2102'
hg init issue2102
cd issue2102
mkdir -p src/cmd/gc
touch src/cmd/gc/mksys.bash
hg ci -Am init
hg import - <<EOF
# HG changeset patch
# User Rob Pike
# Date 1216685449 25200
# Node ID 03aa2b206f499ad6eb50e6e207b9e710d6409c98
# Parent 93d10138ad8df586827ca90b4ddb5033e21a3a84
help management of empty pkg and lib directories in perforce
R=gri
DELTA=4 (4 added, 0 deleted, 0 changed)
OCL=13328
CL=13328
diff --git a/lib/place-holder b/lib/place-holder
new file mode 100644
--- /dev/null
+++ b/lib/place-holder
@@ -0,0 +1,2 @@
+perforce does not maintain empty directories.
+this file helps.
diff --git a/pkg/place-holder b/pkg/place-holder
new file mode 100644
--- /dev/null
+++ b/pkg/place-holder
@@ -0,0 +1,2 @@
+perforce does not maintain empty directories.
+this file helps.
diff --git a/src/cmd/gc/mksys.bash b/src/cmd/gc/mksys.bash
old mode 100644
new mode 100755
EOF
hg sum
hg diff --git -c tip
cd ..
Peter Arrenbrecht
patch: don't look for headers in diff lines...
r10883
echo '% diff lines looking like headers'
hg init difflineslikeheaders
cd difflineslikeheaders
echo a >a
echo b >b
echo c >c
hg ci -Am1
echo "key: value" >>a
echo "key: value" >>b
echo "foo" >>c
hg ci -m2
hg up -C 0
hg diff --git -c1 >want
hg diff -c1 | hg import --no-commit -
hg diff --git >have
diff want have
cd ..