##// END OF EJS Templates
wireprotov2: define and implement "manifestdata" command...
wireprotov2: define and implement "manifestdata" command The added command can be used for obtaining manifest data. Given a manifest path and set of manifest nodes, data about manifests can be retrieved. Unlike changeset data, we wish to emit deltas to describe manifest revisions. So the command uses the relatively new API for building delta requests and emitting them. The code calls into deltaparent(), which I'm not very keen of. There's still work to be done in delta generation land so implementation details of storage (e.g. exactly one delta is stored/available) don't creep into higher levels. But we can worry about this later (there is already a TODO on imanifestorage tracking this). On the subject of parent deltas, the server assumes parent revisions exist on the receiving end. This is obviously wrong for shallow clone. I've added TODOs to add a mechanism to the command to allow clients to specify desired behavior. This shouldn't be too difficult to implement. Another big change is that the client must explicitly request manifest nodes to retrieve. This is a major departure from "getbundle," where the server derives relevant manifests as it iterates changesets and sends them automatically. As implemented, the client must transmit each requested node to the server. At 20 bytes per node, we're looking at 2 MB per 100,000 nodes. Plus wire encoding overhead. This isn't ideal for clients with limited upload bandwidth. I plan to address this in the future by allowing alternate mechanisms for defining the revisions to retrieve. One idea is to define a range of changeset revisions whose manifest revisions to retrieve (similar to how "changesetdata" works). We almost certainly want an API to look up an individual manifest by node. And that's where I've chosen to start with the implementation. Again, a theme of this early exchangev2 work is I want to start by building primitives for accessing raw repository data first and see how far we can get with those before we need more complexity. Differential Revision: https://phab.mercurial-scm.org/D4488

File last commit:

r39442:cb70501d default
r39673:c7a7c7e8 default
Show More
test-import.t
1978 lines | 43.0 KiB | text/troff | Tads3Lexer
Nicolas Dumazet
tests: unify test-import
r11807 $ hg init a
$ mkdir a/d1
$ mkdir a/d1/d2
$ echo line 1 > a/a
$ echo line 1 > a/d1/d2/a
$ hg --cwd a ci -Ama
adding a
adding d1/d2/a
$ echo line 2 >> a/a
$ hg --cwd a ci -u someone -d '1 0' -m'second change'
Kevin Bullock
import: abort usefully if no patch name given
r15327 import with no args:
$ hg --cwd a import
abort: need at least one patch to import
[255]
Nicolas Dumazet
tests: unify test-import
r11807
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 generate patches for the test
$ hg --cwd a export tip > exported-tip.patch
$ hg --cwd a diff -r0:1 > diffed-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807 import exported patch
FUJIWARA Katsunori
import: use "getcommiteditor()" instead of explicit editor choice...
r21417 (this also tests that editor is not invoked, if the patch contains the
commit message and '--edit' is not specified)
Nicolas Dumazet
tests: unify test-import
r11807
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
FUJIWARA Katsunori
import: use "getcommiteditor()" instead of explicit editor choice...
r21417 $ HGEDITOR=cat hg --cwd b import ../exported-tip.patch
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 applying ../exported-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807
Mads Kiilerich
export: show 'Date' header in a format that also is readable for humans...
r18648 message and committer and date should be same
Nicolas Dumazet
tests: unify test-import
r11807
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ hg --cwd b tip
changeset: 1:1d4bd90af0e4
tag: tip
user: someone
date: Thu Jan 01 00:00:01 1970 +0000
Nicolas Dumazet
tests: unify test-import
r11807 summary: second change
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125
Nicolas Dumazet
tests: unify test-import
r11807 $ rm -r b
import exported patch with external patcher
FUJIWARA Katsunori
import: use "getcommiteditor()" instead of explicit editor choice...
r21417 (this also tests that editor is invoked, if the '--edit' is specified,
regardless of the commit message in the patch)
Nicolas Dumazet
tests: unify test-import
r11807
$ cat > dummypatch.py <<EOF
Pulkit Goyal
py3: make files use absolute_import and print_function...
r29485 > from __future__ import print_function
> print('patching file a')
Pulkit Goyal
py3: replace file() with open() in test-import.t...
r36041 > open('a', 'wb').write(b'line2\n')
Nicolas Dumazet
tests: unify test-import
r11807 > EOF
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
Matt Harbison
tests: adjust quoting to keep Windows happy with recent $PYTHON change...
r32976 $ HGEDITOR=cat hg --config ui.patch="$PYTHON ../dummypatch.py" --cwd b import --edit ../exported-tip.patch
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 applying ../exported-tip.patch
FUJIWARA Katsunori
import: use "getcommiteditor()" instead of explicit editor choice...
r21417 second change
HG: Enter commit message. Lines beginning with 'HG:' are removed.
HG: Leave message empty to abort commit.
HG: --
HG: user: someone
HG: branch 'default'
HG: changed a
Nicolas Dumazet
tests: unify test-import
r11807 $ cat b/a
line2
$ rm -r b
import of plain diff should fail without message
FUJIWARA Katsunori
import: use "getcommiteditor()" instead of explicit editor choice...
r21417 (this also tests that editor is invoked, if the patch doesn't contain
the commit message, regardless of '--edit')
Nicolas Dumazet
tests: unify test-import
r11807
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
FUJIWARA Katsunori
import: change "editform" to distinguish merge commits from others...
r22250 $ cat > $TESTTMP/editor.sh <<EOF
> env | grep HGEDITFORM
> cat \$1
> EOF
$ HGEDITOR="sh $TESTTMP/editor.sh" hg --cwd b import ../diffed-tip.patch
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 applying ../diffed-tip.patch
FUJIWARA Katsunori
import: change "editform" to distinguish merge commits from others...
r22250 HGEDITFORM=import.normal.normal
FUJIWARA Katsunori
import: use "getcommiteditor()" instead of explicit editor choice...
r21417
HG: Enter commit message. Lines beginning with 'HG:' are removed.
HG: Leave message empty to abort commit.
HG: --
HG: user: test
HG: branch 'default'
HG: changed a
Nicolas Dumazet
tests: unify test-import
r11807 abort: empty commit message
Matt Mackall
tests: add exit codes to unified tests
r12316 [255]
FUJIWARA Katsunori
import: avoid editor invocation when importing with "--exact" for exact-ness...
r22278
Test avoiding editor invocation at applying the patch with --exact,
even if commit message is empty
$ echo a >> b/a
$ hg --cwd b commit -m ' '
$ hg --cwd b tip -T "{node}\n"
d8804f3f5396d800812f579c8452796a5993bdb2
$ hg --cwd b export -o ../empty-log.diff .
$ hg --cwd b update -q -C ".^1"
$ hg --cwd b --config extensions.strip= strip -q tip
$ HGEDITOR=cat hg --cwd b import --exact ../empty-log.diff
applying ../empty-log.diff
$ hg --cwd b tip -T "{node}\n"
d8804f3f5396d800812f579c8452796a5993bdb2
Nicolas Dumazet
tests: unify test-import
r11807 $ rm -r b
import of plain diff should be ok with message
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ hg --cwd b import -mpatch ../diffed-tip.patch
applying ../diffed-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807 $ rm -r b
import of plain diff with specific date and user
FUJIWARA Katsunori
import: use "getcommiteditor()" instead of explicit editor choice...
r21417 (this also tests that editor is not invoked, if
'--message'/'--logfile' is specified and '--edit' is not)
Nicolas Dumazet
tests: unify test-import
r11807
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ hg --cwd b import -mpatch -d '1 0' -u 'user@nowhere.net' ../diffed-tip.patch
applying ../diffed-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807 $ hg -R b tip -pv
changeset: 1:ca68f19f3a40
tag: tip
user: user@nowhere.net
date: Thu Jan 01 00:00:01 1970 +0000
files: a
description:
patch
diff -r 80971e65b431 -r ca68f19f3a40 a
--- a/a Thu Jan 01 00:00:00 1970 +0000
+++ b/a Thu Jan 01 00:00:01 1970 +0000
@@ -1,1 +1,2 @@
line 1
+line 2
$ rm -r b
import of plain diff should be ok with --no-commit
FUJIWARA Katsunori
import: use "getcommiteditor()" instead of explicit editor choice...
r21417 (this also tests that editor is not invoked, if '--no-commit' is
specified, regardless of '--edit')
Nicolas Dumazet
tests: unify test-import
r11807
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
FUJIWARA Katsunori
import: use "getcommiteditor()" instead of explicit editor choice...
r21417 $ HGEDITOR=cat hg --cwd b import --no-commit --edit ../diffed-tip.patch
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 applying ../diffed-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807 $ hg --cwd b diff --nodates
diff -r 80971e65b431 a
--- a/a
+++ b/a
@@ -1,1 +1,2 @@
line 1
+line 2
$ rm -r b
Patrick Mezard
patch: fails immediately upon malformed hunk...
r12675 import of malformed plain diff should fail
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Patrick Mezard
patch: fails immediately upon malformed hunk...
r12675 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ sed 's/1,1/foo/' < diffed-tip.patch > broken.patch
Patrick Mezard
patch: fails immediately upon malformed hunk...
r12675 $ hg --cwd b import -mpatch ../broken.patch
applying ../broken.patch
abort: bad hunk #1
[255]
$ rm -r b
Nicolas Dumazet
tests: unify test-import
r11807 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
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ cd dir
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ hg -R b import ../exported-tip.patch
applying ../exported-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807 $ cd ..
$ rm -r dir
import from stdin
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ hg --cwd b import - < exported-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807 applying patch from stdin
$ rm -r b
import two patches in one stream
$ hg init b
$ hg --cwd a export 0:tip | hg --cwd b import -
applying patch from stdin
$ hg --cwd a id
1d4bd90af0e4 tip
$ hg --cwd b id
1d4bd90af0e4 tip
$ rm -r b
override commit message
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ hg --cwd b import -m 'override' - < exported-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807 applying patch from stdin
$ hg --cwd b tip | grep override
summary: override
$ rm -r b
$ cat > mkmsg.py <<EOF
Yuya Nishihara
py3: use lower-cased module 'email.message' in test-import.t
r37484 > import email.message, sys
> msg = email.message.Message()
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 > patch = open(sys.argv[1], 'rb').read()
Yuya Nishihara
py3: fix string issues of email message in test-import.t...
r37485 > msg.set_payload(b'email commit message\n' + patch)
Nicolas Dumazet
tests: unify test-import
r11807 > msg['Subject'] = 'email patch'
> msg['From'] = 'email patcher'
Yuya Nishihara
py3: fix string issues of email message in test-import.t...
r37485 > open(sys.argv[2], 'wb').write(bytes(msg))
Nicolas Dumazet
tests: unify test-import
r11807 > EOF
plain diff in email, subject, message body
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
Augie Fackler
cleanup: use $PYTHON to run python in many more tests...
r32940 $ $PYTHON mkmsg.py diffed-tip.patch msg.patch
Nicolas Dumazet
tests: unify test-import
r11807 $ hg --cwd b import ../msg.patch
applying ../msg.patch
$ hg --cwd b tip | grep email
user: email patcher
summary: email patch
$ rm -r b
plain diff in email, no subject, message body
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ grep -v '^Subject:' msg.patch | hg --cwd b import -
applying patch from stdin
$ rm -r b
plain diff in email, subject, no message body
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ grep -v '^email ' msg.patch | hg --cwd b import -
applying patch from stdin
$ rm -r b
plain diff in email, no subject, no message body, should fail
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ egrep -v '^(Subject|email)' msg.patch | hg --cwd b import -
applying patch from stdin
abort: empty commit message
Matt Mackall
tests: add exit codes to unified tests
r12316 [255]
Nicolas Dumazet
tests: unify test-import
r11807 $ rm -r b
hg export in email, should use patch header
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
Augie Fackler
cleanup: use $PYTHON to run python in many more tests...
r32940 $ $PYTHON mkmsg.py exported-tip.patch msg.patch
Mads Kiilerich
tests: don't use stdout redirection for test data...
r15522 $ cat msg.patch | hg --cwd b import -
Nicolas Dumazet
tests: unify test-import
r11807 applying patch from stdin
$ hg --cwd b tip | grep second
summary: second change
$ rm -r b
subject: duplicate detection, removal of [PATCH]
The '---' tests the gitsendmail handling without proper mail headers
$ cat > mkmsg2.py <<EOF
Yuya Nishihara
py3: use lower-cased module 'email.message' in test-import.t
r37484 > import email.message, sys
> msg = email.message.Message()
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 > patch = open(sys.argv[1], 'rb').read()
Yuya Nishihara
py3: fix string issues of email message in test-import.t...
r37485 > msg.set_payload(b'email patch\n\nnext line\n---\n' + patch)
Nicolas Dumazet
tests: unify test-import
r11807 > msg['Subject'] = '[PATCH] email patch'
> msg['From'] = 'email patcher'
Yuya Nishihara
py3: fix string issues of email message in test-import.t...
r37485 > open(sys.argv[2], 'wb').write(bytes(msg))
Nicolas Dumazet
tests: unify test-import
r11807 > EOF
plain diff in email, [PATCH] subject, message body with subject
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
Augie Fackler
cleanup: use $PYTHON to run python in many more tests...
r32940 $ $PYTHON mkmsg2.py diffed-tip.patch msg.patch
Mads Kiilerich
tests: don't use stdout redirection for test data...
r15522 $ cat msg.patch | hg --cwd b import -
Nicolas Dumazet
tests: unify test-import
r11807 applying patch from stdin
$ hg --cwd b tip --template '{desc}\n'
email patch
next line
$ rm -r b
Martin Geisler
tests: added a short description to issue numbers...
r12399 Issue963: Parent of working dir incorrect after import of multiple
patches and rollback
We weren't backing up the correct dirstate file when importing many
patches: import patch1 patch2; rollback
Nicolas Dumazet
tests: unify test-import
r11807
$ 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
$ hg --cwd b parents --template 'parent: {rev}\n'
parent: 0
Greg Ward
import: simplify status reporting logic (and make it more I18N-friendly)...
r15194 $ hg --cwd b import -v ../patch1 ../patch2
Nicolas Dumazet
tests: unify test-import
r11807 applying ../patch1
Greg Ward
import: simplify status reporting logic (and make it more I18N-friendly)...
r15194 patching file a
Mads Kiilerich
localrepo: show headline notes in commitctx before showing filenames...
r23749 committing files:
Greg Ward
import: simplify status reporting logic (and make it more I18N-friendly)...
r15194 a
Mads Kiilerich
localrepo: show headline notes in commitctx before showing filenames...
r23749 committing manifest
committing changelog
Greg Ward
import: simplify status reporting logic (and make it more I18N-friendly)...
r15194 created 1d4bd90af0e4
Nicolas Dumazet
tests: unify test-import
r11807 applying ../patch2
Greg Ward
import: simplify status reporting logic (and make it more I18N-friendly)...
r15194 patching file a
Mads Kiilerich
localrepo: show headline notes in commitctx before showing filenames...
r23749 committing files:
Greg Ward
import: simplify status reporting logic (and make it more I18N-friendly)...
r15194 a
Mads Kiilerich
localrepo: show headline notes in commitctx before showing filenames...
r23749 committing manifest
committing changelog
Greg Ward
import: simplify status reporting logic (and make it more I18N-friendly)...
r15194 created 6d019af21222
Nicolas Dumazet
tests: unify test-import
r11807 $ hg --cwd b rollback
Greg Ward
import: wrap a transaction around the whole command...
r15198 repository tip rolled back to revision 0 (undo import)
working directory now based on revision 0
Nicolas Dumazet
tests: unify test-import
r11807 $ hg --cwd b parents --template 'parent: {rev}\n'
Greg Ward
import: wrap a transaction around the whole command...
r15198 parent: 0
FUJIWARA Katsunori
localrepo: restore dirstate to one before rollbacking if not parent-gone...
r26631
Test that "hg rollback" doesn't restore dirstate to one at the
Mads Kiilerich
spelling: fixes of non-dictionary words
r30332 beginning of the rolled back transaction in not-"parent-gone" case.
FUJIWARA Katsunori
localrepo: restore dirstate to one before rollbacking if not parent-gone...
r26631
invoking pretxncommit hook will cause marking '.hg/dirstate' as a file
Mads Kiilerich
spelling: fixes of non-dictionary words
r30332 to be restored when rolling back, after DirstateTransactionPlan (see wiki
FUJIWARA Katsunori
localrepo: restore dirstate to one before rollbacking if not parent-gone...
r26631 page for detail).
$ hg --cwd b branch -q foobar
$ hg --cwd b commit -m foobar
$ hg --cwd b update 0 -q
$ hg --cwd b import ../patch1 ../patch2 --config hooks.pretxncommit=true
applying ../patch1
applying ../patch2
$ hg --cwd b update -q 1
$ hg --cwd b rollback -q
$ hg --cwd b parents --template 'parent: {rev}\n'
parent: 1
FUJIWARA Katsunori
cmdutil: make in-memory changes visible to external editor (issue4378)...
r26750 $ hg --cwd b update -q -C 0
$ hg --cwd b --config extensions.strip= strip -q 1
Mads Kiilerich
spelling: fixes of non-dictionary words
r30332 Test visibility of in-memory dirstate changes inside transaction to
FUJIWARA Katsunori
cmdutil: make in-memory changes visible to external editor (issue4378)...
r26750 external process
$ echo foo > a/foo
$ hg --cwd a commit -A -m 'adding foo' foo
$ hg --cwd a export -o '../patch%R' 3
$ cat > $TESTTMP/checkvisibility.sh <<EOF
> echo "===="
> hg parents --template "VISIBLE {rev}:{node|short}\n"
> hg status -amr
> # test that pending changes are hidden
> unset HG_PENDING
> hg parents --template "ACTUAL {rev}:{node|short}\n"
> hg status -amr
> echo "===="
> EOF
== test visibility to external editor
$ (cd b && sh "$TESTTMP/checkvisibility.sh")
====
VISIBLE 0:80971e65b431
ACTUAL 0:80971e65b431
====
$ HGEDITOR="sh $TESTTMP/checkvisibility.sh" hg --cwd b import -v --edit ../patch1 ../patch2 ../patch3
applying ../patch1
patching file a
====
VISIBLE 0:80971e65b431
M a
ACTUAL 0:80971e65b431
M a
====
committing files:
a
committing manifest
committing changelog
created 1d4bd90af0e4
applying ../patch2
patching file a
====
VISIBLE 1:1d4bd90af0e4
M a
ACTUAL 0:80971e65b431
M a
====
committing files:
a
committing manifest
committing changelog
created 6d019af21222
applying ../patch3
patching file foo
adding foo
====
VISIBLE 2:6d019af21222
A foo
ACTUAL 0:80971e65b431
M a
====
committing files:
foo
committing manifest
committing changelog
created 55e3f75b2378
$ hg --cwd b rollback -q
(content of file "a" is already changed and it should be recognized as
"M", even though dirstate is restored to one before "hg import")
$ (cd b && sh "$TESTTMP/checkvisibility.sh")
====
VISIBLE 0:80971e65b431
M a
ACTUAL 0:80971e65b431
M a
====
$ hg --cwd b revert --no-backup a
$ rm -f b/foo
FUJIWARA Katsunori
hook: centralize passing HG_PENDING to external hook process...
r26751 == test visibility to precommit external hook
$ cat >> b/.hg/hgrc <<EOF
> [hooks]
> precommit.visibility = sh $TESTTMP/checkvisibility.sh
> EOF
$ (cd b && sh "$TESTTMP/checkvisibility.sh")
====
VISIBLE 0:80971e65b431
ACTUAL 0:80971e65b431
====
$ hg --cwd b import ../patch1 ../patch2 ../patch3
applying ../patch1
====
VISIBLE 0:80971e65b431
M a
ACTUAL 0:80971e65b431
M a
====
applying ../patch2
====
VISIBLE 1:1d4bd90af0e4
M a
ACTUAL 0:80971e65b431
M a
====
applying ../patch3
====
VISIBLE 2:6d019af21222
A foo
ACTUAL 0:80971e65b431
M a
====
$ hg --cwd b rollback -q
$ (cd b && sh "$TESTTMP/checkvisibility.sh")
====
VISIBLE 0:80971e65b431
M a
ACTUAL 0:80971e65b431
M a
====
$ hg --cwd b revert --no-backup a
$ rm -f b/foo
$ cat >> b/.hg/hgrc <<EOF
> [hooks]
> precommit.visibility =
> EOF
== test visibility to pretxncommit external hook
$ cat >> b/.hg/hgrc <<EOF
> [hooks]
> pretxncommit.visibility = sh $TESTTMP/checkvisibility.sh
> EOF
$ (cd b && sh "$TESTTMP/checkvisibility.sh")
====
VISIBLE 0:80971e65b431
ACTUAL 0:80971e65b431
====
$ hg --cwd b import ../patch1 ../patch2 ../patch3
applying ../patch1
====
VISIBLE 0:80971e65b431
M a
ACTUAL 0:80971e65b431
M a
====
applying ../patch2
====
VISIBLE 1:1d4bd90af0e4
M a
ACTUAL 0:80971e65b431
M a
====
applying ../patch3
====
VISIBLE 2:6d019af21222
A foo
ACTUAL 0:80971e65b431
M a
====
$ hg --cwd b rollback -q
$ (cd b && sh "$TESTTMP/checkvisibility.sh")
====
VISIBLE 0:80971e65b431
M a
ACTUAL 0:80971e65b431
M a
====
$ hg --cwd b revert --no-backup a
$ rm -f b/foo
$ cat >> b/.hg/hgrc <<EOF
> [hooks]
> pretxncommit.visibility =
> EOF
Nicolas Dumazet
tests: unify test-import
r11807 $ rm -r b
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'
hg import in a subdirectory
$ hg clone -r0 a b
adding changesets
adding manifests
adding file changes
added 1 changesets with 2 changes to 2 files
Denis Laxalde
transaction-summary: show the range of new revisions upon pull/unbundle (BC)...
r34662 new changesets 80971e65b431
Nicolas Dumazet
tests: unify test-import
r11807 updating to branch default
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
Matt Mackall
tests: drop a bunch of sed calls from unified tests
r12366 $ hg --cwd a export tip > tmp
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ sed -e 's/d1\/d2\///' < tmp > subdir-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807 $ dir=`pwd`
$ cd b/d1/d2 2>&1 > /dev/null
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ hg import ../../../subdir-tip.patch
applying ../../../subdir-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807 $ cd "$dir"
message should be 'subdir change'
committer should be 'someoneelse'
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ hg --cwd b tip
changeset: 1:3577f5aea227
tag: tip
Nicolas Dumazet
tests: unify test-import
r11807 user: someoneelse
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 date: Thu Jan 01 00:00:01 1970 +0000
summary: subdir change
Nicolas Dumazet
tests: unify test-import
r11807
should be empty
$ hg --cwd b status
Test fuzziness (ambiguous patch location, fuzz=2)
$ hg init fuzzy
$ cd fuzzy
$ echo line1 > a
$ echo line0 >> a
$ echo line3 >> a
$ hg ci -Am adda
adding a
$ echo line1 > a
$ echo line2 >> a
$ echo line0 >> a
$ echo line3 >> a
$ hg ci -m change a
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ hg export tip > fuzzy-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807 $ hg up -C 0
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ echo line1 > a
$ echo line0 >> a
$ echo line1 >> a
$ echo line0 >> a
$ hg ci -m brancha
created new head
Matt Mackall
patch: add fuzz config flag (issue4697)
r25631 $ hg import --config patch.fuzz=0 -v fuzzy-tip.patch
applying fuzzy-tip.patch
patching file a
Hunk #1 FAILED at 0
1 out of 1 hunks FAILED -- saving rejects to file a.rej
abort: patch failed to apply
[255]
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ hg import --no-commit -v fuzzy-tip.patch
applying fuzzy-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807 patching file a
Patrick Mezard
patch: fuzz more aggressively to match patch(1) behaviour...
r16124 Hunk #1 succeeded at 2 with fuzz 1 (offset 0 lines).
Greg Ward
import: simplify status reporting logic (and make it more I18N-friendly)...
r15194 applied to working directory
Nicolas Dumazet
tests: unify test-import
r11807 $ hg revert -a
reverting a
Yuya Nishihara
import: fix crash on --exact check of empty commit (issue5702)
r37833 Test --exact failure
$ sed 's/^# Parent .*/# Parent '"`hg log -r. -T '{node}'`"'/' \
> < fuzzy-tip.patch > fuzzy-reparent.patch
$ hg import --config patch.fuzz=0 --exact fuzzy-reparent.patch
applying fuzzy-reparent.patch
patching file a
Hunk #1 FAILED at 0
1 out of 1 hunks FAILED -- saving rejects to file a.rej
abort: patch failed to apply
[255]
$ hg up -qC
$ hg import --config patch.fuzz=2 --exact fuzzy-reparent.patch
applying fuzzy-reparent.patch
patching file a
Hunk #1 succeeded at 2 with fuzz 1 (offset 0 lines).
transaction abort!
rollback completed
abort: patch is damaged or loses information
[255]
$ hg up -qC
$ grep '^#' fuzzy-tip.patch > empty.patch
$ cat <<'EOF' >> empty.patch
> change
>
> diff -r bb90ef1daa38 -r 0e9b883378d4 a
> --- a/a Thu Jan 01 00:00:00 1970 +0000
> --- b/a Thu Jan 01 00:00:00 1970 +0000
> EOF
$ hg import --exact empty.patch
applying empty.patch
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
abort: patch is damaged or loses information
[255]
$ hg up -qC
Steve Borho
import: --no-commit should update .hg/last-message.txt...
r12913
import with --no-commit should have written .hg/last-message.txt
Mads Kiilerich
test-import: workaround for missing newline is no longer needed
r12945 $ cat .hg/last-message.txt
change (no-eol)
Steve Borho
import: --no-commit should update .hg/last-message.txt...
r12913
Nicolas Dumazet
tests: unify test-import
r11807 test fuzziness with eol=auto
Nicolas Dumazet
tests: do not export several times the same patch/diff in test-import
r14125 $ hg --config patch.eol=auto import --no-commit -v fuzzy-tip.patch
applying fuzzy-tip.patch
Nicolas Dumazet
tests: unify test-import
r11807 patching file a
Patrick Mezard
patch: fuzz more aggressively to match patch(1) behaviour...
r16124 Hunk #1 succeeded at 2 with fuzz 1 (offset 0 lines).
Greg Ward
import: simplify status reporting logic (and make it more I18N-friendly)...
r15194 applied to working directory
Nicolas Dumazet
tests: unify test-import
r11807 $ cd ..
Test hunk touching empty files (issue906)
$ hg init empty
$ cd empty
$ touch a
$ touch b1
$ touch c1
$ echo d > d
$ hg ci -Am init
adding a
adding b1
adding c1
adding d
$ echo a > a
$ echo b > b1
$ hg mv b1 b2
$ echo c > c1
$ hg copy c1 c2
$ rm d
$ touch d
$ hg diff --git
diff --git a/a b/a
--- a/a
+++ b/a
@@ -0,0 +1,1 @@
+a
diff --git a/b1 b/b2
rename from b1
rename to b2
--- a/b1
+++ b/b2
@@ -0,0 +1,1 @@
+b
diff --git a/c1 b/c1
--- a/c1
+++ b/c1
@@ -0,0 +1,1 @@
+c
diff --git a/c1 b/c2
copy from c1
copy to c2
--- a/c1
+++ b/c2
@@ -0,0 +1,1 @@
+c
diff --git a/d b/d
--- a/d
+++ b/d
@@ -1,1 +0,0 @@
-d
$ hg ci -m empty
$ hg export --git tip > empty.diff
$ hg up -C 0
4 files updated, 0 files merged, 2 files removed, 0 files unresolved
$ hg import empty.diff
applying empty.diff
$ for name in a b1 b2 c1 c2 d; do
> echo % $name file
> test -f $name && cat $name
> done
% a file
a
% b1 file
% b2 file
b
% c1 file
c
% c2 file
c
% d file
$ cd ..
Test importing a patch ending with a binary file removal
$ hg init binaryremoval
$ cd binaryremoval
$ echo a > a
Pulkit Goyal
py3: replace file() with open() in test-import.t...
r36041 $ $PYTHON -c "open('b', 'wb').write(b'a\x00b')"
Nicolas Dumazet
tests: unify test-import
r11807 $ hg ci -Am addall
adding a
adding b
$ hg rm a
$ hg rm b
$ hg st
R a
R b
$ hg ci -m remove
$ hg export --git . > remove.diff
$ cat remove.diff | grep git
diff --git a/a b/a
diff --git a/b b/b
$ hg up -C 0
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ hg import remove.diff
applying remove.diff
$ hg manifest
$ cd ..
Martin Geisler
tests: added a short description to issue numbers...
r12399 Issue927: test update+rename with common name
Nicolas Dumazet
tests: unify test-import
r11807
$ hg init t
$ cd t
$ touch a
$ hg ci -Am t
adding a
$ 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
1 files updated, 0 files merged, 1 files removed, 0 files unresolved
$ hg import copy.diff
applying copy.diff
a should contain an 'a'
$ cat a
a
and a2 should have duplicated it
$ cat a2
a
$ cd ..
test -p0
$ hg init p0
$ cd p0
$ echo a > a
$ hg ci -Am t
adding a
Idan Kamara
fancyopts: don't show a traceback on invalid integer values
r17712 $ hg import -p foo
abort: invalid value 'foo' for option -p, expected int
[255]
Nicolas Dumazet
tests: unify test-import
r11807 $ 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
applying patch from stdin
$ hg status
$ cat a
bb
Siddharth Agarwal
cmdutil.tryimportone: allow importing relative patches into the working dir...
r24259
test --prefix
$ mkdir -p dir/dir2
$ echo b > dir/dir2/b
$ hg ci -Am b
adding dir/dir2/b
$ hg import -p2 --prefix dir - << EOF
> foobar
> --- drop1/drop2/dir2/b
> +++ drop1/drop2/dir2/b
> @@ -1,1 +1,1 @@
> -b
> +cc
> EOF
applying patch from stdin
$ hg status
$ cat dir/dir2/b
cc
Nicolas Dumazet
tests: unify test-import
r11807 $ cd ..
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
applying patch from stdin
Matt Harbison
tests: remove (glob) annotations that were only for '\' matches...
r35394 abort: path contains illegal component: ../outside/foo
Matt Mackall
tests: add exit codes to unified tests
r12316 [255]
Nicolas Dumazet
tests: unify test-import
r11807 $ cd ..
test import with similarity and git and strip (issue295 et al.)
$ hg init sim
$ cd sim
$ echo 'this is a test' > a
$ hg ci -Ama
adding a
$ cat > ../rename.diff <<EOF
> diff --git a/foo/a b/foo/a
> deleted file mode 100644
> --- a/foo/a
> +++ /dev/null
> @@ -1,1 +0,0 @@
> -this is a test
> diff --git a/foo/b b/foo/b
> new file mode 100644
> --- /dev/null
> +++ b/foo/b
> @@ -0,0 +1,2 @@
> +this is a test
> +foo
> EOF
$ hg import --no-commit -v -s 1 ../rename.diff -p2
applying ../rename.diff
patching file a
patching file b
adding b
recording removal of a as rename to b (88% similar)
Greg Ward
import: simplify status reporting logic (and make it more I18N-friendly)...
r15194 applied to working directory
Matt Harbison
test-largefiles: demonstrate problems with renaming and reverting a directory...
r35174 $ echo 'mod b' > b
Nicolas Dumazet
tests: unify test-import
r11807 $ hg st -C
A b
a
R a
$ hg revert -a
Sushil khanchi
revert: fix the inconsistency of status msgs in --interactive mode...
r39442 forgetting b
Nicolas Dumazet
tests: unify test-import
r11807 undeleting a
Matt Harbison
test-largefiles: demonstrate problems with renaming and reverting a directory...
r35174 $ cat b
mod b
Nicolas Dumazet
tests: unify test-import
r11807 $ rm b
$ hg import --no-commit -v -s 100 ../rename.diff -p2
applying ../rename.diff
patching file a
patching file b
adding b
Greg Ward
import: simplify status reporting logic (and make it more I18N-friendly)...
r15194 applied to working directory
Nicolas Dumazet
tests: unify test-import
r11807 $ hg st -C
A b
R a
$ cd ..
Martin Geisler
tests: added a short description to issue numbers...
r12399 Issue1495: add empty file from the end of patch
Nicolas Dumazet
tests: unify test-import
r11807
$ hg init addemptyend
$ cd addemptyend
$ touch a
$ hg addremove
adding a
$ hg ci -m "commit"
$ cat > a.patch <<EOF
Greg Ward
import: wrap a transaction around the whole command...
r15198 > add a, b
Nicolas Dumazet
tests: unify test-import
r11807 > 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
applying a.patch
Greg Ward
import: wrap a transaction around the whole command...
r15198
apply a good patch followed by an empty patch (mainly to ensure
that dirstate is *not* updated when import crashes)
$ hg update -q -C .
$ rm b
$ touch empty.patch
$ hg import a.patch empty.patch
applying a.patch
applying empty.patch
transaction abort!
rollback completed
abort: empty.patch: no diffs found
[255]
$ hg tip --template '{rev} {desc|firstline}\n'
0 commit
$ hg -q status
M a
Nicolas Dumazet
tests: unify test-import
r11807 $ cd ..
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
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
$ hg init oddcreate
$ cd oddcreate
$ hg import --no-commit ../create.patch
applying ../create.patch
$ cat foo
a
$ rm foo
$ hg revert foo
$ hg import --no-commit ../create2.patch
applying ../create2.patch
$ cat foo
a
Mads Kiilerich
tests: cleanup of tests that got lost in their own nested directories...
r16912 $ cd ..
Nicolas Dumazet
tests: unify test-import
r11807
Martin Geisler
tests: added a short description to issue numbers...
r12399 Issue1859: first line mistaken for email headers
Nicolas Dumazet
tests: unify test-import
r11807
$ 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
applying a.patch
$ hg parents -v
changeset: 0:5a681217c0ad
tag: tip
user: test
date: Thu Jan 01 00:00:00 1970 +0000
files: a
description:
module: summary
description
$ cd ..
Mads Kiilerich
tests: cleanup of tests that got lost in their own nested directories...
r16912 in commit message
Nicolas Dumazet
tests: unify test-import
r11807
$ 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 ..
>
> 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
applying a.patch
changeset: 0:f34d9187897d
tag: tip
user: test
date: Thu Jan 01 00:00:00 1970 +0000
files: a
description:
module: summary
% tricky header splitting
$ hg init trickyheaders
$ cd trickyheaders
$ hg import -d '0 0' ../trickyheaders.patch
applying ../trickyheaders.patch
$ hg export --git tip
# HG changeset patch
# User User B
# Date 0 0
Mads Kiilerich
export: show 'Date' header in a format that also is readable for humans...
r18648 # Thu Jan 01 00:00:00 1970 +0000
Nicolas Dumazet
tests: unify test-import
r11807 # Node ID eb56ab91903632294ac504838508cb370c0901d2
# Parent 0000000000000000000000000000000000000000
from: tricky!
That is not a header.
diff --git a/foo b/foo
new file mode 100644
--- /dev/null
+++ b/foo
@@ -0,0 +1,1 @@
+foo
$ cd ..
Martin Geisler
tests: added a short description to issue numbers...
r12399 Issue2102: hg export and hg import speak different languages
Nicolas Dumazet
tests: unify test-import
r11807
$ hg init issue2102
$ cd issue2102
$ mkdir -p src/cmd/gc
$ touch src/cmd/gc/mksys.bash
$ hg ci -Am init
adding src/cmd/gc/mksys.bash
$ 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
applying patch from stdin
Adrian Buehlmann
test-import: enable for Windows
r16889
#if execbit
Nicolas Dumazet
tests: unify test-import
r11807 $ hg sum
parent: 1:d59915696727 tip
help management of empty pkg and lib directories in perforce
branch: default
commit: (clean)
update: (current)
Gilles Moris
summary: move the parents phase marker to commit line (issue4688)...
r25382 phases: 2 draft
Adrian Buehlmann
test-import: enable for Windows
r16889
Nicolas Dumazet
tests: unify test-import
r11807 $ hg diff --git -c tip
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
Adrian Buehlmann
test-import: enable for Windows
r16889
#else
$ hg sum
parent: 1:28f089cc9ccc tip
help management of empty pkg and lib directories in perforce
branch: default
commit: (clean)
update: (current)
Matt Harbison
test-import: sync with 6084926366b9 for platforms without execbit
r25397 phases: 2 draft
Adrian Buehlmann
test-import: enable for Windows
r16889
$ hg diff --git -c tip
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.
/* The mode change for mksys.bash is missing here, because on platforms */
/* that don't support execbits, mode changes in patches are ignored when */
/* they are imported. This is obviously also the reason for why the hash */
/* in the created changeset is different to the one you see above the */
/* #else clause */
#endif
Nicolas Dumazet
tests: unify test-import
r11807 $ cd ..
diff lines looking like headers
$ hg init difflineslikeheaders
$ cd difflineslikeheaders
$ echo a >a
$ echo b >b
$ echo c >c
$ hg ci -Am1
adding a
adding b
adding c
$ echo "key: value" >>a
$ echo "key: value" >>b
$ echo "foo" >>c
$ hg ci -m2
$ hg up -C 0
3 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ hg diff --git -c1 >want
$ hg diff -c1 | hg import --no-commit -
applying patch from stdin
$ hg diff --git >have
$ diff want have
$ cd ..
Nicolas Venegas
mdiff/patch: fix bad hunk handling for unified diffs with zero context...
r15462 import a unified diff with no lines of context (diff -U0)
$ hg init diffzero
$ cd diffzero
$ cat > f << EOF
> c2
> c4
> c5
> EOF
$ hg commit -Am0
adding f
$ hg import --no-commit - << EOF
> # HG changeset patch
> # User test
> # Date 0 0
> # Node ID f4974ab632f3dee767567b0576c0ec9a4508575c
> # Parent 8679a12a975b819fae5f7ad3853a2886d143d794
> 1
> diff -r 8679a12a975b -r f4974ab632f3 f
> --- a/f Thu Jan 01 00:00:00 1970 +0000
> +++ b/f Thu Jan 01 00:00:00 1970 +0000
> @@ -0,0 +1,1 @@
> +c1
> @@ -1,0 +3,1 @@
> +c3
> @@ -3,1 +4,0 @@
> -c5
> EOF
applying patch from stdin
$ cat f
c1
c2
c3
c4
Patrick Mezard
patch: fix fuzzing of hunks without previous lines (issue3264)...
r16123
Mads Kiilerich
tests: cleanup of tests that got lost in their own nested directories...
r16912 $ cd ..
Yuya Nishihara
patch: improve heuristics to not take the word "diff" as header (issue1879)...
r34965 commit message that looks like a diff header (issue1879)
$ hg init headerlikemsg
$ cd headerlikemsg
$ touch empty
$ echo nonempty >> nonempty
$ hg ci -qAl - <<EOF
> blah blah
> diff blah
> blah blah
> EOF
$ hg --config diff.git=1 log -pv
changeset: 0:c6ef204ef767
tag: tip
user: test
date: Thu Jan 01 00:00:00 1970 +0000
files: empty nonempty
description:
blah blah
diff blah
blah blah
diff --git a/empty b/empty
new file mode 100644
diff --git a/nonempty b/nonempty
new file mode 100644
--- /dev/null
+++ b/nonempty
@@ -0,0 +1,1 @@
+nonempty
(without --git, empty file is lost, but commit message should be preserved)
$ hg init plain
$ hg export 0 | hg -R plain import -
applying patch from stdin
$ hg --config diff.git=1 -R plain log -pv
changeset: 0:60a2d231e71f
tag: tip
user: test
date: Thu Jan 01 00:00:00 1970 +0000
files: nonempty
description:
blah blah
diff blah
blah blah
diff --git a/nonempty b/nonempty
new file mode 100644
--- /dev/null
+++ b/nonempty
@@ -0,0 +1,1 @@
+nonempty
(with --git, patch contents should be fully preserved)
$ hg init git
$ hg --config diff.git=1 export 0 | hg -R git import -
applying patch from stdin
$ hg --config diff.git=1 -R git log -pv
changeset: 0:c6ef204ef767
tag: tip
user: test
date: Thu Jan 01 00:00:00 1970 +0000
files: empty nonempty
description:
blah blah
diff blah
blah blah
diff --git a/empty b/empty
new file mode 100644
diff --git a/nonempty b/nonempty
new file mode 100644
--- /dev/null
+++ b/nonempty
@@ -0,0 +1,1 @@
+nonempty
$ cd ..
Yuya Nishihara
patch: fix segfault against unified diffs which start line is zero...
r16650 no segfault while importing a unified diff which start line is zero but chunk
size is non-zero
$ hg init startlinezero
$ cd startlinezero
$ echo foo > foo
$ hg commit -Amfoo
adding foo
$ hg import --no-commit - << EOF
> diff a/foo b/foo
> --- a/foo
> +++ b/foo
> @@ -0,1 +0,1 @@
> foo
> EOF
applying patch from stdin
$ cd ..
Patrick Mezard
patch: fix fuzzing of hunks without previous lines (issue3264)...
r16123 Test corner case involving fuzz and skew
$ hg init morecornercases
$ cd morecornercases
$ cat > 01-no-context-beginning-of-file.diff <<EOF
> diff --git a/a b/a
> --- a/a
> +++ b/a
> @@ -1,0 +1,1 @@
> +line
> EOF
$ cat > 02-no-context-middle-of-file.diff <<EOF
> diff --git a/a b/a
> --- a/a
> +++ b/a
> @@ -1,1 +1,1 @@
> -2
> +add some skew
> @@ -2,0 +2,1 @@
> +line
> EOF
$ cat > 03-no-context-end-of-file.diff <<EOF
> diff --git a/a b/a
> --- a/a
> +++ b/a
> @@ -10,0 +10,1 @@
> +line
> EOF
Patrick Mezard
patch: fuzz more aggressively to match patch(1) behaviour...
r16124 $ cat > 04-middle-of-file-completely-fuzzed.diff <<EOF
> diff --git a/a b/a
> --- a/a
> +++ b/a
> @@ -1,1 +1,1 @@
> -2
> +add some skew
> @@ -2,2 +2,3 @@
> not matching, should fuzz
> ... a bit
> +line
> EOF
Patrick Mezard
patch: fix fuzzing of hunks without previous lines (issue3264)...
r16123 $ cat > a <<EOF
> 1
> 2
> 3
> 4
> EOF
$ hg ci -Am adda a
$ for p in *.diff; do
> hg import -v --no-commit $p
> cat a
> hg revert -aqC a
> # patch -p1 < $p
> # cat a
> # hg revert -aC a
> done
applying 01-no-context-beginning-of-file.diff
patching file a
applied to working directory
1
line
2
3
4
applying 02-no-context-middle-of-file.diff
patching file a
Hunk #1 succeeded at 2 (offset 1 lines).
Hunk #2 succeeded at 4 (offset 1 lines).
applied to working directory
1
add some skew
3
line
4
applying 03-no-context-end-of-file.diff
patching file a
Hunk #1 succeeded at 5 (offset -6 lines).
applied to working directory
1
2
3
4
line
Patrick Mezard
patch: fuzz more aggressively to match patch(1) behaviour...
r16124 applying 04-middle-of-file-completely-fuzzed.diff
patching file a
Hunk #1 succeeded at 2 (offset 1 lines).
Hunk #2 succeeded at 5 with fuzz 2 (offset 1 lines).
applied to working directory
1
add some skew
3
4
line
Pierre-Yves David
import: add --partial flag to create a changeset despite failed hunks...
r21553 $ cd ..
Patrick Mezard
patch: fix fuzzing of hunks without previous lines (issue3264)...
r16123
Pierre-Yves David
import: add --partial flag to create a changeset despite failed hunks...
r21553 Test partial application
------------------------
prepare a stack of patches depending on each other
$ hg init partial
$ cd partial
$ cat << EOF > a
> one
> two
> three
> four
> five
> six
> seven
> EOF
$ hg add a
$ echo 'b' > b
$ hg add b
$ hg commit -m 'initial' -u Babar
$ cat << EOF > a
> one
> two
> 3
> four
> five
> six
> seven
> EOF
$ hg commit -m 'three' -u Celeste
$ cat << EOF > a
> one
> two
> 3
> 4
> five
> six
> seven
> EOF
$ hg commit -m 'four' -u Rataxes
$ cat << EOF > a
> one
> two
> 3
> 4
> 5
> six
> seven
> EOF
$ echo bb >> b
$ hg commit -m 'five' -u Arthur
$ echo 'Babar' > jungle
$ hg add jungle
$ hg ci -m 'jungle' -u Zephir
$ echo 'Celeste' >> jungle
$ hg ci -m 'extended jungle' -u Cornelius
$ hg log -G --template '{desc|firstline} [{author}] {diffstat}\n'
@ extended jungle [Cornelius] 1: +1/-0
|
o jungle [Zephir] 1: +1/-0
|
o five [Arthur] 2: +2/-1
|
o four [Rataxes] 1: +1/-1
|
o three [Celeste] 1: +1/-1
|
o initial [Babar] 2: +8/-0
Matthieu Laneuville
templatekw: force noprefix=False to insure diffstat consistency (issue4755)...
r30811 Adding those config options should not change the output of diffstat. Bugfix #4755.
$ hg log -r . --template '{diffstat}\n'
1: +1/-0
$ hg log -r . --template '{diffstat}\n' --config diff.git=1 \
> --config diff.noprefix=1
1: +1/-0
Pierre-Yves David
import: add --partial flag to create a changeset despite failed hunks...
r21553
Importing with some success and some errors:
$ hg update --rev 'desc(initial)'
2 files updated, 0 files merged, 1 files removed, 0 files unresolved
$ hg export --rev 'desc(five)' | hg import --partial -
applying patch from stdin
patching file a
Hunk #1 FAILED at 1
1 out of 1 hunks FAILED -- saving rejects to file a.rej
patch applied partially
(fix the .rej files and run `hg commit --amend`)
[1]
$ hg log -G --template '{desc|firstline} [{author}] {diffstat}\n'
@ five [Arthur] 1: +1/-0
|
| o extended jungle [Cornelius] 1: +1/-0
| |
| o jungle [Zephir] 1: +1/-0
| |
| o five [Arthur] 2: +2/-1
| |
| o four [Rataxes] 1: +1/-1
| |
| o three [Celeste] 1: +1/-1
|/
o initial [Babar] 2: +8/-0
$ hg export
# HG changeset patch
# User Arthur
# Date 0 0
# Thu Jan 01 00:00:00 1970 +0000
# Node ID 26e6446bb2526e2be1037935f5fca2b2706f1509
# Parent 8e4f0351909eae6b9cf68c2c076cb54c42b54b2e
five
diff -r 8e4f0351909e -r 26e6446bb252 b
--- a/b Thu Jan 01 00:00:00 1970 +0000
+++ b/b Thu Jan 01 00:00:00 1970 +0000
@@ -1,1 +1,2 @@
b
+bb
$ hg status -c .
C a
C b
$ ls
a
a.rej
b
Importing with zero success:
$ hg update --rev 'desc(initial)'
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ hg export --rev 'desc(four)' | hg import --partial -
applying patch from stdin
patching file a
Hunk #1 FAILED at 0
1 out of 1 hunks FAILED -- saving rejects to file a.rej
patch applied partially
(fix the .rej files and run `hg commit --amend`)
[1]
$ hg log -G --template '{desc|firstline} [{author}] {diffstat}\n'
@ four [Rataxes] 0: +0/-0
|
| o five [Arthur] 1: +1/-0
|/
| o extended jungle [Cornelius] 1: +1/-0
| |
| o jungle [Zephir] 1: +1/-0
| |
| o five [Arthur] 2: +2/-1
| |
| o four [Rataxes] 1: +1/-1
| |
| o three [Celeste] 1: +1/-1
|/
o initial [Babar] 2: +8/-0
$ hg export
# HG changeset patch
# User Rataxes
# Date 0 0
# Thu Jan 01 00:00:00 1970 +0000
# Node ID cb9b1847a74d9ad52e93becaf14b98dbcc274e1e
# Parent 8e4f0351909eae6b9cf68c2c076cb54c42b54b2e
four
$ hg status -c .
C a
C b
$ ls
a
a.rej
b
Importing with unknown file:
$ hg update --rev 'desc(initial)'
0 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ hg export --rev 'desc("extended jungle")' | hg import --partial -
applying patch from stdin
unable to find 'jungle' for patching
liscju
import: report directory-relative paths in error messages (issue5224)...
r29900 (use '--prefix' to apply patch relative to the current directory)
Pierre-Yves David
import: add --partial flag to create a changeset despite failed hunks...
r21553 1 out of 1 hunks FAILED -- saving rejects to file jungle.rej
patch applied partially
(fix the .rej files and run `hg commit --amend`)
[1]
$ hg log -G --template '{desc|firstline} [{author}] {diffstat}\n'
@ extended jungle [Cornelius] 0: +0/-0
|
| o four [Rataxes] 0: +0/-0
|/
| o five [Arthur] 1: +1/-0
|/
| o extended jungle [Cornelius] 1: +1/-0
| |
| o jungle [Zephir] 1: +1/-0
| |
| o five [Arthur] 2: +2/-1
| |
| o four [Rataxes] 1: +1/-1
| |
| o three [Celeste] 1: +1/-1
|/
o initial [Babar] 2: +8/-0
$ hg export
# HG changeset patch
# User Cornelius
# Date 0 0
# Thu Jan 01 00:00:00 1970 +0000
# Node ID 1fb1f86bef43c5a75918178f8d23c29fb0a7398d
# Parent 8e4f0351909eae6b9cf68c2c076cb54c42b54b2e
extended jungle
$ hg status -c .
C a
C b
$ ls
a
a.rej
b
jungle.rej
Importing multiple failing patches:
$ hg update --rev 'desc(initial)'
0 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ echo 'B' > b # just to make another commit
$ hg commit -m "a new base"
created new head
Pierre-Yves David
test-import.t: use proper revset order...
r22858 $ hg export --rev 'desc("four") + desc("extended jungle")' | hg import --partial -
Pierre-Yves David
import: add --partial flag to create a changeset despite failed hunks...
r21553 applying patch from stdin
patching file a
Hunk #1 FAILED at 0
1 out of 1 hunks FAILED -- saving rejects to file a.rej
patch applied partially
(fix the .rej files and run `hg commit --amend`)
[1]
$ hg log -G --template '{desc|firstline} [{author}] {diffstat}\n'
@ four [Rataxes] 0: +0/-0
|
o a new base [test] 1: +1/-1
|
| o extended jungle [Cornelius] 0: +0/-0
|/
| o four [Rataxes] 0: +0/-0
|/
| o five [Arthur] 1: +1/-0
|/
| o extended jungle [Cornelius] 1: +1/-0
| |
| o jungle [Zephir] 1: +1/-0
| |
| o five [Arthur] 2: +2/-1
| |
| o four [Rataxes] 1: +1/-1
| |
| o three [Celeste] 1: +1/-1
|/
o initial [Babar] 2: +8/-0
$ hg export
# HG changeset patch
# User Rataxes
# Date 0 0
# Thu Jan 01 00:00:00 1970 +0000
# Node ID a9d7b6d0ffbb4eb12b7d5939250fcd42e8930a1d
# Parent f59f8d2e95a8ca5b1b4ca64320140da85f3b44fd
four
$ hg status -c .
C a
C b
Pierre-Yves David
import: allow processing of extra part header during import...
r26561
Importing some extra header
===========================
$ cat > $TESTTMP/parseextra.py <<EOF
> import mercurial.patch
> import mercurial.cmdutil
>
> def processfoo(repo, data, extra, opts):
Yuya Nishihara
py3: byte-stringify test-import.t...
r37475 > if b'foo' in data:
> extra[b'foo'] = data[b'foo']
Pierre-Yves David
import: allow processing of extra part header after import...
r26562 > def postimport(ctx):
Yuya Nishihara
py3: byte-stringify test-import.t...
r37475 > if b'foo' in ctx.extra():
> ctx.repo().ui.write(b'imported-foo: %s\n' % ctx.extra()[b'foo'])
Pierre-Yves David
import: allow processing of extra part header during import...
r26561 >
Yuya Nishihara
py3: byte-stringify test-import.t...
r37475 > mercurial.patch.patchheadermap.append((b'Foo', b'foo'))
> mercurial.cmdutil.extrapreimport.append(b'foo')
> mercurial.cmdutil.extrapreimportmap[b'foo'] = processfoo
> mercurial.cmdutil.extrapostimport.append(b'foo')
> mercurial.cmdutil.extrapostimportmap[b'foo'] = postimport
Pierre-Yves David
import: allow processing of extra part header during import...
r26561 > EOF
Matt Harbison
test-import: don't use printf to append an extension to $HGRCPATH...
r27054 $ cat >> $HGRCPATH <<EOF
> [extensions]
> parseextra=$TESTTMP/parseextra.py
> EOF
Pierre-Yves David
import: allow processing of extra part header during import...
r26561 $ hg up -C tip
0 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ cat > $TESTTMP/foo.patch <<EOF
> # HG changeset patch
> # User Rataxes
> # Date 0 0
> # Thu Jan 01 00:00:00 1970 +0000
> # Foo bar
> height
>
> --- a/a Thu Jan 01 00:00:00 1970 +0000
> +++ b/a Wed Oct 07 09:17:44 2015 +0000
> @@ -5,3 +5,4 @@
> five
> six
> seven
> +heigt
> EOF
$ hg import $TESTTMP/foo.patch
applying $TESTTMP/foo.patch
Pierre-Yves David
import: allow processing of extra part header after import...
r26562 imported-foo: bar
Pierre-Yves David
import: allow processing of extra part header during import...
r26561 $ hg log --debug -r . | grep extra
extra: branch=default
extra: foo=bar
liscju
import: report directory-relative paths in error messages (issue5224)...
r29900
Warn the user that paths are relative to the root of
repository when file not found for patching
$ mkdir filedir
$ echo "file1" >> filedir/file1
$ hg add filedir/file1
$ hg commit -m "file1"
$ cd filedir
$ hg import -p 2 - <<EOF
> # HG changeset patch
> # User test
> # Date 0 0
> file2
>
> diff --git a/filedir/file1 b/filedir/file1
> --- a/filedir/file1
> +++ b/filedir/file1
> @@ -1,1 +1,2 @@
> file1
> +file2
> EOF
applying patch from stdin
unable to find 'file1' for patching
(use '--prefix' to apply patch relative to the current directory)
1 out of 1 hunks FAILED -- saving rejects to file file1.rej
abort: patch failed to apply
[255]
Ryan McElroy
import: abort instead of crashing when copy source does not exist (issue5375)...
r30078
test import crash (issue5375)
$ cd ..
$ hg init repo
$ cd repo
$ printf "diff --git a/a b/b\nrename from a\nrename to b" | hg import -
applying patch from stdin
a not tracked!
abort: source file 'a' does not exist
[255]
Yuya Nishihara
patch: error out if reached to EOF while reading hunk...
r37591
test immature end of hunk
$ hg import - <<'EOF'
> diff --git a/foo b/foo
> --- a/foo
> --- b/foo
> @@ -0,0 +1,1 @@
> EOF
applying patch from stdin
abort: bad hunk #1: incomplete hunk
[255]
$ hg import - <<'EOF'
> diff --git a/foo b/foo
> --- a/foo
> --- b/foo
> @@ -0,0 +1,1 @@
> \ No newline at end of file
> EOF
applying patch from stdin
abort: bad hunk #1: incomplete hunk
[255]