Show More
@@ -569,9 +569,7 def tryimportone(ui, repo, hunk, parents | |||||
569 | tmpname, message, user, date, branch, nodeid, p1, p2 = \ |
|
569 | tmpname, message, user, date, branch, nodeid, p1, p2 = \ | |
570 | patch.extract(ui, hunk) |
|
570 | patch.extract(ui, hunk) | |
571 |
|
571 | |||
572 | editor = commiteditor |
|
572 | editor = getcommiteditor(**opts) | |
573 | if opts.get('edit'): |
|
|||
574 | editor = commitforceeditor |
|
|||
575 | update = not opts.get('bypass') |
|
573 | update = not opts.get('bypass') | |
576 | strip = opts["strip"] |
|
574 | strip = opts["strip"] | |
577 | sim = float(opts.get('similarity') or 0) |
|
575 | sim = float(opts.get('similarity') or 0) | |
@@ -660,7 +658,7 def tryimportone(ui, repo, hunk, parents | |||||
660 | opts.get('user') or user, |
|
658 | opts.get('user') or user, | |
661 | opts.get('date') or date, |
|
659 | opts.get('date') or date, | |
662 | branch, files, store, |
|
660 | branch, files, store, | |
663 | editor=commiteditor) |
|
661 | editor=getcommiteditor()) | |
664 | n = memctx.commit() |
|
662 | n = memctx.commit() | |
665 | finally: |
|
663 | finally: | |
666 | store.close() |
|
664 | store.close() |
@@ -22,8 +22,10 Test --bypass with other options | |||||
22 | 0 files updated, 0 files merged, 1 files removed, 0 files unresolved |
|
22 | 0 files updated, 0 files merged, 1 files removed, 0 files unresolved | |
23 |
|
23 | |||
24 | Test importing an existing revision |
|
24 | Test importing an existing revision | |
|
25 | (this also tests that editor is not invoked for '--bypass', if the | |||
|
26 | patch contains the commit message, regardless of '--edit') | |||
25 |
|
27 | |||
26 | $ hg import --bypass --exact ../test.diff |
|
28 | $ HGEDITOR=cat hg import --bypass --exact --edit ../test.diff | |
27 | applying ../test.diff |
|
29 | applying ../test.diff | |
28 | $ shortlog |
|
30 | $ shortlog | |
29 | o 1:4e322f7ce8e3 test 0 0 - foo - changea |
|
31 | o 1:4e322f7ce8e3 test 0 0 - foo - changea | |
@@ -107,6 +109,8 Test unsupported combinations | |||||
107 | [255] |
|
109 | [255] | |
108 |
|
110 | |||
109 | Test commit editor |
|
111 | Test commit editor | |
|
112 | (this also tests that editor is invoked, if the patch doesn't contain | |||
|
113 | the commit message, regardless of '--edit') | |||
110 |
|
114 | |||
111 | $ cat > ../test.diff <<EOF |
|
115 | $ cat > ../test.diff <<EOF | |
112 | > diff -r 07f494440405 -r 4e322f7ce8e3 a |
|
116 | > diff -r 07f494440405 -r 4e322f7ce8e3 a | |
@@ -131,10 +135,12 Test commit editor | |||||
131 | [255] |
|
135 | [255] | |
132 |
|
136 | |||
133 | Test patch.eol is handled |
|
137 | Test patch.eol is handled | |
|
138 | (this also tests that editor is not invoked for '--bypass', if the | |||
|
139 | commit message is explicitly specified, regardless of '--edit') | |||
134 |
|
140 | |||
135 | $ python -c 'file("a", "wb").write("a\r\n")' |
|
141 | $ python -c 'file("a", "wb").write("a\r\n")' | |
136 | $ hg ci -m makeacrlf |
|
142 | $ hg ci -m makeacrlf | |
137 | $ hg import -m 'should fail because of eol' --bypass ../test.diff |
|
143 | $ HGEDITOR=cat hg import -m 'should fail because of eol' --edit --bypass ../test.diff | |
138 | applying ../test.diff |
|
144 | applying ../test.diff | |
139 | patching file a |
|
145 | patching file a | |
140 | Hunk #1 FAILED at 0 |
|
146 | Hunk #1 FAILED at 0 |
@@ -23,6 +23,8 generate patches for the test | |||||
23 |
|
23 | |||
24 |
|
24 | |||
25 | import exported patch |
|
25 | import exported patch | |
|
26 | (this also tests that editor is not invoked, if the patch contains the | |||
|
27 | commit message and '--edit' is not specified) | |||
26 |
|
28 | |||
27 | $ hg clone -r0 a b |
|
29 | $ hg clone -r0 a b | |
28 | adding changesets |
|
30 | adding changesets | |
@@ -31,7 +33,7 import exported patch | |||||
31 | added 1 changesets with 2 changes to 2 files |
|
33 | added 1 changesets with 2 changes to 2 files | |
32 | updating to branch default |
|
34 | updating to branch default | |
33 | 2 files updated, 0 files merged, 0 files removed, 0 files unresolved |
|
35 | 2 files updated, 0 files merged, 0 files removed, 0 files unresolved | |
34 | $ hg --cwd b import ../exported-tip.patch |
|
36 | $ HGEDITOR=cat hg --cwd b import ../exported-tip.patch | |
35 | applying ../exported-tip.patch |
|
37 | applying ../exported-tip.patch | |
36 |
|
38 | |||
37 | message and committer and date should be same |
|
39 | message and committer and date should be same | |
@@ -47,6 +49,8 message and committer and date should be | |||||
47 |
|
49 | |||
48 |
|
50 | |||
49 | import exported patch with external patcher |
|
51 | import exported patch with external patcher | |
|
52 | (this also tests that editor is invoked, if the '--edit' is specified, | |||
|
53 | regardless of the commit message in the patch) | |||
50 |
|
54 | |||
51 | $ cat > dummypatch.py <<EOF |
|
55 | $ cat > dummypatch.py <<EOF | |
52 | > print 'patching file a' |
|
56 | > print 'patching file a' | |
@@ -59,14 +63,25 import exported patch with external patc | |||||
59 | added 1 changesets with 2 changes to 2 files |
|
63 | added 1 changesets with 2 changes to 2 files | |
60 | updating to branch default |
|
64 | updating to branch default | |
61 | 2 files updated, 0 files merged, 0 files removed, 0 files unresolved |
|
65 | 2 files updated, 0 files merged, 0 files removed, 0 files unresolved | |
62 | $ hg --config ui.patch='python ../dummypatch.py' --cwd b import ../exported-tip.patch |
|
66 | $ HGEDITOR=cat hg --config ui.patch='python ../dummypatch.py' --cwd b import --edit ../exported-tip.patch | |
63 | applying ../exported-tip.patch |
|
67 | applying ../exported-tip.patch | |
|
68 | second change | |||
|
69 | ||||
|
70 | ||||
|
71 | HG: Enter commit message. Lines beginning with 'HG:' are removed. | |||
|
72 | HG: Leave message empty to abort commit. | |||
|
73 | HG: -- | |||
|
74 | HG: user: someone | |||
|
75 | HG: branch 'default' | |||
|
76 | HG: changed a | |||
64 | $ cat b/a |
|
77 | $ cat b/a | |
65 | line2 |
|
78 | line2 | |
66 | $ rm -r b |
|
79 | $ rm -r b | |
67 |
|
80 | |||
68 |
|
81 | |||
69 | import of plain diff should fail without message |
|
82 | import of plain diff should fail without message | |
|
83 | (this also tests that editor is invoked, if the patch doesn't contain | |||
|
84 | the commit message, regardless of '--edit') | |||
70 |
|
85 | |||
71 | $ hg clone -r0 a b |
|
86 | $ hg clone -r0 a b | |
72 | adding changesets |
|
87 | adding changesets | |
@@ -75,8 +90,16 import of plain diff should fail without | |||||
75 | added 1 changesets with 2 changes to 2 files |
|
90 | added 1 changesets with 2 changes to 2 files | |
76 | updating to branch default |
|
91 | updating to branch default | |
77 | 2 files updated, 0 files merged, 0 files removed, 0 files unresolved |
|
92 | 2 files updated, 0 files merged, 0 files removed, 0 files unresolved | |
78 | $ hg --cwd b import ../diffed-tip.patch |
|
93 | $ HGEDITOR=cat hg --cwd b import ../diffed-tip.patch | |
79 | applying ../diffed-tip.patch |
|
94 | applying ../diffed-tip.patch | |
|
95 | ||||
|
96 | ||||
|
97 | HG: Enter commit message. Lines beginning with 'HG:' are removed. | |||
|
98 | HG: Leave message empty to abort commit. | |||
|
99 | HG: -- | |||
|
100 | HG: user: test | |||
|
101 | HG: branch 'default' | |||
|
102 | HG: changed a | |||
80 | abort: empty commit message |
|
103 | abort: empty commit message | |
81 | [255] |
|
104 | [255] | |
82 | $ rm -r b |
|
105 | $ rm -r b | |
@@ -97,6 +120,8 import of plain diff should be ok with m | |||||
97 |
|
120 | |||
98 |
|
121 | |||
99 | import of plain diff with specific date and user |
|
122 | import of plain diff with specific date and user | |
|
123 | (this also tests that editor is not invoked, if | |||
|
124 | '--message'/'--logfile' is specified and '--edit' is not) | |||
100 |
|
125 | |||
101 | $ hg clone -r0 a b |
|
126 | $ hg clone -r0 a b | |
102 | adding changesets |
|
127 | adding changesets | |
@@ -128,6 +153,8 import of plain diff with specific date | |||||
128 |
|
153 | |||
129 |
|
154 | |||
130 | import of plain diff should be ok with --no-commit |
|
155 | import of plain diff should be ok with --no-commit | |
|
156 | (this also tests that editor is not invoked, if '--no-commit' is | |||
|
157 | specified, regardless of '--edit') | |||
131 |
|
158 | |||
132 | $ hg clone -r0 a b |
|
159 | $ hg clone -r0 a b | |
133 | adding changesets |
|
160 | adding changesets | |
@@ -136,7 +163,7 import of plain diff should be ok with - | |||||
136 | added 1 changesets with 2 changes to 2 files |
|
163 | added 1 changesets with 2 changes to 2 files | |
137 | updating to branch default |
|
164 | updating to branch default | |
138 | 2 files updated, 0 files merged, 0 files removed, 0 files unresolved |
|
165 | 2 files updated, 0 files merged, 0 files removed, 0 files unresolved | |
139 | $ hg --cwd b import --no-commit ../diffed-tip.patch |
|
166 | $ HGEDITOR=cat hg --cwd b import --no-commit --edit ../diffed-tip.patch | |
140 | applying ../diffed-tip.patch |
|
167 | applying ../diffed-tip.patch | |
141 | $ hg --cwd b diff --nodates |
|
168 | $ hg --cwd b diff --nodates | |
142 | diff -r 80971e65b431 a |
|
169 | diff -r 80971e65b431 a |
General Comments 0
You need to be logged in to leave comments.
Login now