test-merge-changedelete.t
1043 lines
| 34.2 KiB
| text/troff
|
Tads3Lexer
/ tests / test-merge-changedelete.t
Siddharth Agarwal
|
r27137 | Tests for change/delete conflicts, including: | ||
Siddharth Agarwal
|
r26947 | b5605d88dc27: Make ui.prompt repeat on "unrecognized response" again | ||
(issue897) | ||||
840e2b315c1f: Fix misleading error and prompts during update/merge | ||||
(issue556) | ||||
Make sure HGMERGE doesn't interfere with the test | ||||
$ unset HGMERGE | ||||
$ status() { | ||||
> echo "--- status ---" | ||||
Siddharth Agarwal
|
r27125 | > hg st -A file1 file2 file3 | ||
Siddharth Agarwal
|
r27126 | > echo "--- resolve --list ---" | ||
> hg resolve --list file1 file2 file3 | ||||
Siddharth Agarwal
|
r27136 | > echo "--- debugmergestate ---" | ||
> hg debugmergestate | ||||
Siddharth Agarwal
|
r27125 | > for file in file1 file2 file3; do | ||
Siddharth Agarwal
|
r26947 | > if [ -f $file ]; then | ||
> echo "--- $file ---" | ||||
> cat $file | ||||
> else | ||||
> echo "*** $file does not exist" | ||||
> fi | ||||
> done | ||||
> } | ||||
Siddharth Agarwal
|
r27137 | $ hg init repo | ||
$ cd repo | ||||
Siddharth Agarwal
|
r26947 | |||
$ echo 1 > file1 | ||||
$ echo 2 > file2 | ||||
Siddharth Agarwal
|
r27125 | $ echo 3 > file3 | ||
$ hg ci -Am 'added files' | ||||
Siddharth Agarwal
|
r26947 | adding file1 | ||
adding file2 | ||||
Siddharth Agarwal
|
r27125 | adding file3 | ||
Siddharth Agarwal
|
r26947 | |||
$ hg rm file1 | ||||
$ echo changed >> file2 | ||||
Siddharth Agarwal
|
r27125 | $ echo changed1 >> file3 | ||
$ hg ci -m 'removed file1, changed file2, changed file3' | ||||
Siddharth Agarwal
|
r26947 | |||
$ hg co 0 | ||||
Siddharth Agarwal
|
r27125 | 3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Siddharth Agarwal
|
r26947 | |||
$ echo changed >> file1 | ||||
$ hg rm file2 | ||||
Siddharth Agarwal
|
r27125 | $ echo changed2 >> file3 | ||
$ hg ci -m 'changed file1, removed file2, changed file3' | ||||
Siddharth Agarwal
|
r26947 | created new head | ||
Non-interactive merge: | ||||
$ hg merge -y | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27599 | use (c)hanged version, (d)elete, or leave (u)nresolved? u | ||
Siddharth Agarwal
|
r26947 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27599 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? u | ||
Siddharth Agarwal
|
r27125 | merging file3 | ||
warning: conflicts while merging file3! (edit, then use 'hg resolve --mark') | ||||
Siddharth Agarwal
|
r27599 | 0 files updated, 0 files merged, 0 files removed, 3 files unresolved | ||
Siddharth Agarwal
|
r27125 | use 'hg resolve' to retry unresolved file merges or 'hg update -C .' to abandon | ||
[1] | ||||
Siddharth Agarwal
|
r26947 | |||
$ status | ||||
--- status --- | ||||
M file2 | ||||
Siddharth Agarwal
|
r27125 | M file3 | ||
Siddharth Agarwal
|
r26947 | C file1 | ||
Siddharth Agarwal
|
r27126 | --- resolve --list --- | ||
Siddharth Agarwal
|
r27599 | U file1 | ||
U file2 | ||||
Siddharth Agarwal
|
r27126 | U file3 | ||
Siddharth Agarwal
|
r27136 | --- debugmergestate --- | ||
* version 2 records | ||||
local: 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27599 | file: file1 (record type "C", state "u", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
Siddharth Agarwal
|
r27137 | local path: file1 (flags "") | ||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27599 | file: file2 (record type "C", state "u", hash null) | ||
Siddharth Agarwal
|
r27137 | local path: file2 (flags "") | ||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Durham Goode
|
r28011 | file extras: file3 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27136 | file: file3 (record type "F", state "u", hash d5b0a58bc47161b1b8a831084b366f757c4f0b11) | ||
local path: file3 (flags "") | ||||
ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Siddharth Agarwal
|
r26947 | --- file1 --- | ||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
Siddharth Agarwal
|
r27125 | --- file3 --- | ||
3 | ||||
<<<<<<< local: 13910f48cf7b - test: changed file1, removed file2, changed file3 | ||||
changed2 | ||||
======= | ||||
changed1 | ||||
>>>>>>> other: 10f9a0a634e8 - test: removed file1, changed file2, changed file3 | ||||
Siddharth Agarwal
|
r26947 | |||
Interactive merge: | ||||
$ hg co -C | ||||
Siddharth Agarwal
|
r27125 | 1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r26947 | |||
$ hg merge --config ui.interactive=true <<EOF | ||||
> c | ||||
> d | ||||
> EOF | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? c | ||
Siddharth Agarwal
|
r26947 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27163 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? d | ||
Siddharth Agarwal
|
r27125 | merging file3 | ||
warning: conflicts while merging file3! (edit, then use 'hg resolve --mark') | ||||
Siddharth Agarwal
|
r27137 | 0 files updated, 2 files merged, 0 files removed, 1 files unresolved | ||
Siddharth Agarwal
|
r27125 | use 'hg resolve' to retry unresolved file merges or 'hg update -C .' to abandon | ||
[1] | ||||
Siddharth Agarwal
|
r26947 | |||
$ status | ||||
--- status --- | ||||
file2: * (glob) | ||||
Siddharth Agarwal
|
r27125 | M file3 | ||
Siddharth Agarwal
|
r26947 | C file1 | ||
Siddharth Agarwal
|
r27126 | --- resolve --list --- | ||
Siddharth Agarwal
|
r27137 | R file1 | ||
R file2 | ||||
Siddharth Agarwal
|
r27126 | U file3 | ||
Siddharth Agarwal
|
r27136 | --- debugmergestate --- | ||
* version 2 records | ||||
local: 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file1 (record type "C", state "r", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
local path: file1 (flags "") | ||||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file2 (record type "C", state "r", hash null) | ||
local path: file2 (flags "") | ||||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Durham Goode
|
r28011 | file extras: file3 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27136 | file: file3 (record type "F", state "u", hash d5b0a58bc47161b1b8a831084b366f757c4f0b11) | ||
local path: file3 (flags "") | ||||
ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Siddharth Agarwal
|
r26947 | --- file1 --- | ||
1 | ||||
changed | ||||
*** file2 does not exist | ||||
Siddharth Agarwal
|
r27125 | --- file3 --- | ||
3 | ||||
<<<<<<< local: 13910f48cf7b - test: changed file1, removed file2, changed file3 | ||||
changed2 | ||||
======= | ||||
changed1 | ||||
>>>>>>> other: 10f9a0a634e8 - test: removed file1, changed file2, changed file3 | ||||
Siddharth Agarwal
|
r26947 | |||
Interactive merge with bad input: | ||||
$ hg co -C | ||||
Siddharth Agarwal
|
r27125 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r26947 | |||
$ hg merge --config ui.interactive=true <<EOF | ||||
> foo | ||||
> bar | ||||
> d | ||||
> baz | ||||
> c | ||||
> EOF | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? foo | ||
Siddharth Agarwal
|
r26947 | unrecognized response | ||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? bar | ||
Siddharth Agarwal
|
r26947 | unrecognized response | ||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? d | ||
Siddharth Agarwal
|
r26947 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27163 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? baz | ||
Siddharth Agarwal
|
r26947 | unrecognized response | ||
remote changed file2 which local deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? c | ||
Siddharth Agarwal
|
r27125 | merging file3 | ||
warning: conflicts while merging file3! (edit, then use 'hg resolve --mark') | ||||
Siddharth Agarwal
|
r27137 | 0 files updated, 1 files merged, 1 files removed, 1 files unresolved | ||
Siddharth Agarwal
|
r27125 | use 'hg resolve' to retry unresolved file merges or 'hg update -C .' to abandon | ||
[1] | ||||
Siddharth Agarwal
|
r26947 | |||
$ status | ||||
--- status --- | ||||
M file2 | ||||
Siddharth Agarwal
|
r27125 | M file3 | ||
Siddharth Agarwal
|
r26947 | R file1 | ||
Siddharth Agarwal
|
r27126 | --- resolve --list --- | ||
Siddharth Agarwal
|
r27137 | R file1 | ||
R file2 | ||||
Siddharth Agarwal
|
r27126 | U file3 | ||
Siddharth Agarwal
|
r27136 | --- debugmergestate --- | ||
* version 2 records | ||||
local: 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file1 (record type "C", state "r", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
local path: file1 (flags "") | ||||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file2 (record type "C", state "r", hash null) | ||
local path: file2 (flags "") | ||||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Durham Goode
|
r28011 | file extras: file3 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27136 | file: file3 (record type "F", state "u", hash d5b0a58bc47161b1b8a831084b366f757c4f0b11) | ||
local path: file3 (flags "") | ||||
ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Siddharth Agarwal
|
r26947 | *** file1 does not exist | ||
--- file2 --- | ||||
2 | ||||
changed | ||||
Siddharth Agarwal
|
r27125 | --- file3 --- | ||
3 | ||||
<<<<<<< local: 13910f48cf7b - test: changed file1, removed file2, changed file3 | ||||
changed2 | ||||
======= | ||||
changed1 | ||||
>>>>>>> other: 10f9a0a634e8 - test: removed file1, changed file2, changed file3 | ||||
Siddharth Agarwal
|
r26947 | |||
Interactive merge with not enough input: | ||||
$ hg co -C | ||||
Siddharth Agarwal
|
r27125 | 2 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r26947 | |||
$ hg merge --config ui.interactive=true <<EOF | ||||
> d | ||||
> EOF | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? d | ||
Siddharth Agarwal
|
r26947 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27163 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | merging file3 | ||
warning: conflicts while merging file3! (edit, then use 'hg resolve --mark') | ||||
0 files updated, 0 files merged, 1 files removed, 2 files unresolved | ||||
use 'hg resolve' to retry unresolved file merges or 'hg update -C .' to abandon | ||||
[1] | ||||
Siddharth Agarwal
|
r26947 | |||
$ status | ||||
--- status --- | ||||
Siddharth Agarwal
|
r27137 | M file2 | ||
M file3 | ||||
R file1 | ||||
--- resolve --list --- | ||||
R file1 | ||||
U file2 | ||||
U file3 | ||||
--- debugmergestate --- | ||||
* version 2 records | ||||
local: 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file1 (record type "C", state "r", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
local path: file1 (flags "") | ||||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file2 (record type "C", state "u", hash null) | ||
local path: file2 (flags "") | ||||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Durham Goode
|
r28011 | file extras: file3 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file3 (record type "F", state "u", hash d5b0a58bc47161b1b8a831084b366f757c4f0b11) | ||
local path: file3 (flags "") | ||||
ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
*** file1 does not exist | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
<<<<<<< local: 13910f48cf7b - test: changed file1, removed file2, changed file3 | ||||
changed2 | ||||
======= | ||||
changed1 | ||||
>>>>>>> other: 10f9a0a634e8 - test: removed file1, changed file2, changed file3 | ||||
Choose local versions of files | ||||
$ hg co -C | ||||
2 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r27137 | |||
$ hg merge --tool :local | ||||
0 files updated, 3 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ status 2>&1 | tee $TESTTMP/local.status | ||||
--- status --- | ||||
Siddharth Agarwal
|
r26947 | file2: * (glob) | ||
Siddharth Agarwal
|
r27137 | M file3 | ||
Siddharth Agarwal
|
r26947 | C file1 | ||
Siddharth Agarwal
|
r27126 | --- resolve --list --- | ||
Siddharth Agarwal
|
r27137 | R file1 | ||
R file2 | ||||
R file3 | ||||
Siddharth Agarwal
|
r27136 | --- debugmergestate --- | ||
Siddharth Agarwal
|
r27137 | * version 2 records | ||
local: 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file1 (record type "C", state "r", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
local path: file1 (flags "") | ||||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file2 (record type "C", state "r", hash null) | ||
local path: file2 (flags "") | ||||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Durham Goode
|
r28011 | file extras: file3 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file3 (record type "F", state "r", hash d5b0a58bc47161b1b8a831084b366f757c4f0b11) | ||
local path: file3 (flags "") | ||||
ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Siddharth Agarwal
|
r26947 | --- file1 --- | ||
1 | ||||
changed | ||||
*** file2 does not exist | ||||
Siddharth Agarwal
|
r27125 | --- file3 --- | ||
3 | ||||
changed2 | ||||
Siddharth Agarwal
|
r26947 | |||
Siddharth Agarwal
|
r27137 | Choose other versions of files | ||
$ hg co -C | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r27137 | |||
$ hg merge --tool :other | ||||
0 files updated, 2 files merged, 1 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ status 2>&1 | tee $TESTTMP/other.status | ||||
--- status --- | ||||
M file2 | ||||
M file3 | ||||
R file1 | ||||
--- resolve --list --- | ||||
R file1 | ||||
R file2 | ||||
R file3 | ||||
--- debugmergestate --- | ||||
* version 2 records | ||||
local: 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file1 (record type "C", state "r", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
local path: file1 (flags "") | ||||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file2 (record type "C", state "r", hash null) | ||
local path: file2 (flags "") | ||||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Durham Goode
|
r28011 | file extras: file3 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file3 (record type "F", state "r", hash d5b0a58bc47161b1b8a831084b366f757c4f0b11) | ||
local path: file3 (flags "") | ||||
ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
*** file1 does not exist | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed1 | ||||
Fail | ||||
$ hg co -C | ||||
2 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r27137 | |||
$ hg merge --tool :fail | ||||
0 files updated, 0 files merged, 0 files removed, 3 files unresolved | ||||
use 'hg resolve' to retry unresolved file merges or 'hg update -C .' to abandon | ||||
[1] | ||||
$ status 2>&1 | tee $TESTTMP/fail.status | ||||
--- status --- | ||||
M file2 | ||||
M file3 | ||||
C file1 | ||||
--- resolve --list --- | ||||
U file1 | ||||
U file2 | ||||
U file3 | ||||
--- debugmergestate --- | ||||
* version 2 records | ||||
local: 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file1 (record type "C", state "u", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
local path: file1 (flags "") | ||||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file2 (record type "C", state "u", hash null) | ||
local path: file2 (flags "") | ||||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Durham Goode
|
r28011 | file extras: file3 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file3 (record type "F", state "u", hash d5b0a58bc47161b1b8a831084b366f757c4f0b11) | ||
local path: file3 (flags "") | ||||
ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
--- file1 --- | ||||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed2 | ||||
Force prompts with no input (should be similar to :fail) | ||||
$ hg co -C | ||||
1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r27137 | |||
$ hg merge --config ui.interactive=True --tool :prompt | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27163 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | no tool found to merge file3 | ||
Siddharth Agarwal
|
r27162 | keep (l)ocal, take (o)ther, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | 0 files updated, 0 files merged, 0 files removed, 3 files unresolved | ||
use 'hg resolve' to retry unresolved file merges or 'hg update -C .' to abandon | ||||
[1] | ||||
$ status 2>&1 | tee $TESTTMP/prompt.status | ||||
--- status --- | ||||
M file2 | ||||
M file3 | ||||
C file1 | ||||
--- resolve --list --- | ||||
U file1 | ||||
U file2 | ||||
U file3 | ||||
--- debugmergestate --- | ||||
* version 2 records | ||||
local: 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file1 (record type "C", state "u", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
local path: file1 (flags "") | ||||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file2 (record type "C", state "u", hash null) | ||
local path: file2 (flags "") | ||||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Durham Goode
|
r28011 | file extras: file3 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file3 (record type "F", state "u", hash d5b0a58bc47161b1b8a831084b366f757c4f0b11) | ||
local path: file3 (flags "") | ||||
ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
--- file1 --- | ||||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed2 | ||||
Danek Duvall
|
r27557 | $ cmp $TESTTMP/fail.status $TESTTMP/prompt.status || diff -U8 $TESTTMP/fail.status $TESTTMP/prompt.status | ||
Siddharth Agarwal
|
r27137 | |||
Force prompts | ||||
$ hg co -C | ||||
1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r27137 | |||
$ hg merge --tool :prompt | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27599 | use (c)hanged version, (d)elete, or leave (u)nresolved? u | ||
Siddharth Agarwal
|
r27137 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27599 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? u | ||
Siddharth Agarwal
|
r27137 | no tool found to merge file3 | ||
Siddharth Agarwal
|
r27164 | keep (l)ocal, take (o)ther, or leave (u)nresolved? u | ||
Siddharth Agarwal
|
r27599 | 0 files updated, 0 files merged, 0 files removed, 3 files unresolved | ||
Siddharth Agarwal
|
r27164 | use 'hg resolve' to retry unresolved file merges or 'hg update -C .' to abandon | ||
[1] | ||||
Siddharth Agarwal
|
r27137 | $ status | ||
--- status --- | ||||
M file2 | ||||
M file3 | ||||
C file1 | ||||
--- resolve --list --- | ||||
Siddharth Agarwal
|
r27599 | U file1 | ||
U file2 | ||||
Siddharth Agarwal
|
r27164 | U file3 | ||
Siddharth Agarwal
|
r27137 | --- debugmergestate --- | ||
* version 2 records | ||||
local: 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27599 | file: file1 (record type "C", state "u", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
Siddharth Agarwal
|
r27137 | local path: file1 (flags "") | ||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27599 | file: file2 (record type "C", state "u", hash null) | ||
Siddharth Agarwal
|
r27137 | local path: file2 (flags "") | ||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Durham Goode
|
r28011 | file extras: file3 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27164 | file: file3 (record type "F", state "u", hash d5b0a58bc47161b1b8a831084b366f757c4f0b11) | ||
Siddharth Agarwal
|
r27137 | local path: file3 (flags "") | ||
ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
--- file1 --- | ||||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed2 | ||||
Choose to merge all files | ||||
$ hg co -C | ||||
1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r27137 | |||
$ hg merge --tool :merge3 | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27599 | use (c)hanged version, (d)elete, or leave (u)nresolved? u | ||
Siddharth Agarwal
|
r27137 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27599 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? u | ||
Siddharth Agarwal
|
r27137 | merging file3 | ||
warning: conflicts while merging file3! (edit, then use 'hg resolve --mark') | ||||
Siddharth Agarwal
|
r27599 | 0 files updated, 0 files merged, 0 files removed, 3 files unresolved | ||
Siddharth Agarwal
|
r27137 | use 'hg resolve' to retry unresolved file merges or 'hg update -C .' to abandon | ||
[1] | ||||
$ status | ||||
--- status --- | ||||
M file2 | ||||
M file3 | ||||
C file1 | ||||
--- resolve --list --- | ||||
Siddharth Agarwal
|
r27599 | U file1 | ||
U file2 | ||||
Siddharth Agarwal
|
r27137 | U file3 | ||
--- debugmergestate --- | ||||
* version 2 records | ||||
local: 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27599 | file: file1 (record type "C", state "u", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
Siddharth Agarwal
|
r27137 | local path: file1 (flags "") | ||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27599 | file: file2 (record type "C", state "u", hash null) | ||
Siddharth Agarwal
|
r27137 | local path: file2 (flags "") | ||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Durham Goode
|
r28011 | file extras: file3 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file3 (record type "F", state "u", hash d5b0a58bc47161b1b8a831084b366f757c4f0b11) | ||
local path: file3 (flags "") | ||||
ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
--- file1 --- | ||||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
<<<<<<< local: 13910f48cf7b - test: changed file1, removed file2, changed file3 | ||||
changed2 | ||||
||||||| base | ||||
======= | ||||
changed1 | ||||
>>>>>>> other: 10f9a0a634e8 - test: removed file1, changed file2, changed file3 | ||||
Exercise transitions between local, other, fail and prompt, and make sure the | ||||
dirstate stays consistent. (Compare with each other and to the above | ||||
invocations.) | ||||
$ testtransitions() { | ||||
> # this traversal order covers every transition | ||||
> tools="local other prompt local fail other local prompt other fail prompt fail local" | ||||
> lasttool="merge3" | ||||
> for tool in $tools; do | ||||
> echo "=== :$lasttool -> :$tool ===" | ||||
> ref="$TESTTMP/$tool.status" | ||||
> hg resolve --unmark --all | ||||
> hg resolve --tool ":$tool" --all --config ui.interactive=True | ||||
> status > "$TESTTMP/compare.status" 2>&1 | ||||
> echo '--- diff of status ---' | ||||
Danek Duvall
|
r27557 | > if cmp "$TESTTMP/$tool.status" "$TESTTMP/compare.status" || diff -U8 "$TESTTMP/$tool.status" "$TESTTMP/compare.status"; then | ||
Siddharth Agarwal
|
r27137 | > echo '(status identical)' | ||
> fi | ||||
> lasttool="$tool" | ||||
> echo | ||||
> done | ||||
> } | ||||
$ testtransitions | ||||
=== :merge3 -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :local -> :other === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :other -> :prompt === | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27163 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | no tool found to merge file3 | ||
Siddharth Agarwal
|
r27162 | keep (l)ocal, take (o)ther, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | --- diff of status --- | ||
(status identical) | ||||
=== :prompt -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :local -> :fail === | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :fail -> :other === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :other -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :local -> :prompt === | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27163 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | no tool found to merge file3 | ||
Siddharth Agarwal
|
r27162 | keep (l)ocal, take (o)ther, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | --- diff of status --- | ||
(status identical) | ||||
=== :prompt -> :other === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :other -> :fail === | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :fail -> :prompt === | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27163 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | no tool found to merge file3 | ||
Siddharth Agarwal
|
r27162 | keep (l)ocal, take (o)ther, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | --- diff of status --- | ||
(status identical) | ||||
=== :prompt -> :fail === | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :fail -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
Siddharth Agarwal
|
r26947 | Non-interactive linear update | ||
$ hg co -C 0 | ||||
Siddharth Agarwal
|
r27125 | 3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Siddharth Agarwal
|
r26947 | $ echo changed >> file1 | ||
$ hg rm file2 | ||||
$ hg update 1 -y | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27599 | use (c)hanged version, (d)elete, or leave (u)nresolved? u | ||
Siddharth Agarwal
|
r26947 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27599 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? u | ||
1 files updated, 0 files merged, 0 files removed, 2 files unresolved | ||||
use 'hg resolve' to retry unresolved file merges | ||||
[1] | ||||
Siddharth Agarwal
|
r26947 | $ status | ||
--- status --- | ||||
A file1 | ||||
C file2 | ||||
Siddharth Agarwal
|
r27125 | C file3 | ||
Siddharth Agarwal
|
r27126 | --- resolve --list --- | ||
Siddharth Agarwal
|
r27599 | U file1 | ||
U file2 | ||||
Siddharth Agarwal
|
r27136 | --- debugmergestate --- | ||
Siddharth Agarwal
|
r27137 | * version 2 records | ||
local: ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27599 | file: file1 (record type "C", state "u", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
Siddharth Agarwal
|
r27137 | local path: file1 (flags "") | ||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27599 | file: file2 (record type "C", state "u", hash null) | ||
Siddharth Agarwal
|
r27137 | local path: file2 (flags "") | ||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
--- file1 --- | ||||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed1 | ||||
Choose local versions of files | ||||
$ hg co -C 0 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo changed >> file1 | ||||
$ hg rm file2 | ||||
$ hg update 1 --tool :local | ||||
1 files updated, 2 files merged, 0 files removed, 0 files unresolved | ||||
$ status 2>&1 | tee $TESTTMP/local.status | ||||
--- status --- | ||||
file2: * (glob) | ||||
A file1 | ||||
C file3 | ||||
--- resolve --list --- | ||||
R file1 | ||||
R file2 | ||||
--- debugmergestate --- | ||||
* version 2 records | ||||
local: ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file1 (record type "C", state "r", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
local path: file1 (flags "") | ||||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file2 (record type "C", state "r", hash null) | ||
local path: file2 (flags "") | ||||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
--- file1 --- | ||||
1 | ||||
changed | ||||
*** file2 does not exist | ||||
--- file3 --- | ||||
3 | ||||
changed1 | ||||
Choose other versions of files | ||||
$ hg co -C 0 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo changed >> file1 | ||||
$ hg rm file2 | ||||
$ hg update 1 --tool :other | ||||
1 files updated, 1 files merged, 1 files removed, 0 files unresolved | ||||
$ status 2>&1 | tee $TESTTMP/other.status | ||||
--- status --- | ||||
file1: * (glob) | ||||
C file2 | ||||
C file3 | ||||
--- resolve --list --- | ||||
R file1 | ||||
R file2 | ||||
--- debugmergestate --- | ||||
* version 2 records | ||||
local: ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file1 (record type "C", state "r", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
local path: file1 (flags "") | ||||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file2 (record type "C", state "r", hash null) | ||
local path: file2 (flags "") | ||||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
*** file1 does not exist | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed1 | ||||
Fail | ||||
$ hg co -C 0 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo changed >> file1 | ||||
$ hg rm file2 | ||||
$ hg update 1 --tool :fail | ||||
1 files updated, 0 files merged, 0 files removed, 2 files unresolved | ||||
use 'hg resolve' to retry unresolved file merges | ||||
[1] | ||||
$ status 2>&1 | tee $TESTTMP/fail.status | ||||
--- status --- | ||||
A file1 | ||||
C file2 | ||||
C file3 | ||||
--- resolve --list --- | ||||
U file1 | ||||
U file2 | ||||
--- debugmergestate --- | ||||
* version 2 records | ||||
local: ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file1 (record type "C", state "u", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
local path: file1 (flags "") | ||||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file2 (record type "C", state "u", hash null) | ||
local path: file2 (flags "") | ||||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Siddharth Agarwal
|
r26947 | --- file1 --- | ||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
Siddharth Agarwal
|
r27125 | --- file3 --- | ||
3 | ||||
changed1 | ||||
Siddharth Agarwal
|
r27137 | |||
Force prompts with no input | ||||
$ hg co -C 0 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo changed >> file1 | ||||
$ hg rm file2 | ||||
$ hg update 1 --config ui.interactive=True --tool :prompt | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27163 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | 1 files updated, 0 files merged, 0 files removed, 2 files unresolved | ||
use 'hg resolve' to retry unresolved file merges | ||||
[1] | ||||
$ status 2>&1 | tee $TESTTMP/prompt.status | ||||
--- status --- | ||||
A file1 | ||||
C file2 | ||||
C file3 | ||||
--- resolve --list --- | ||||
U file1 | ||||
U file2 | ||||
--- debugmergestate --- | ||||
* version 2 records | ||||
local: ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file1 (record type "C", state "u", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
local path: file1 (flags "") | ||||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27137 | file: file2 (record type "C", state "u", hash null) | ||
local path: file2 (flags "") | ||||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
--- file1 --- | ||||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed1 | ||||
Danek Duvall
|
r27557 | $ cmp $TESTTMP/fail.status $TESTTMP/prompt.status || diff -U8 $TESTTMP/fail.status $TESTTMP/prompt.status | ||
Siddharth Agarwal
|
r27137 | |||
Choose to merge all files | ||||
$ hg co -C 0 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo changed >> file1 | ||||
$ hg rm file2 | ||||
$ hg update 1 --tool :merge3 | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27599 | use (c)hanged version, (d)elete, or leave (u)nresolved? u | ||
Siddharth Agarwal
|
r27137 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27599 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? u | ||
1 files updated, 0 files merged, 0 files removed, 2 files unresolved | ||||
use 'hg resolve' to retry unresolved file merges | ||||
[1] | ||||
Siddharth Agarwal
|
r27137 | $ status | ||
--- status --- | ||||
A file1 | ||||
C file2 | ||||
C file3 | ||||
--- resolve --list --- | ||||
Siddharth Agarwal
|
r27599 | U file1 | ||
U file2 | ||||
Siddharth Agarwal
|
r27137 | --- debugmergestate --- | ||
* version 2 records | ||||
local: ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
other: 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
Durham Goode
|
r28011 | file extras: file1 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27599 | file: file1 (record type "C", state "u", hash 60b27f004e454aca81b0480209cce5081ec52390) | ||
Siddharth Agarwal
|
r27137 | local path: file1 (flags "") | ||
ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||||
other path: file1 (node null) | ||||
Durham Goode
|
r28011 | file extras: file2 (ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff) | ||
Siddharth Agarwal
|
r27599 | file: file2 (record type "C", state "u", hash null) | ||
Siddharth Agarwal
|
r27137 | local path: file2 (flags "") | ||
ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
--- file1 --- | ||||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed1 | ||||
Test transitions between different merge tools | ||||
$ testtransitions | ||||
=== :merge3 -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :local -> :other === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :other -> :prompt === | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27163 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | --- diff of status --- | ||
(status identical) | ||||
=== :prompt -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :local -> :fail === | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :fail -> :other === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :other -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :local -> :prompt === | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27163 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | --- diff of status --- | ||
(status identical) | ||||
=== :prompt -> :other === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :other -> :fail === | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :fail -> :prompt === | ||||
local changed file1 which remote deleted | ||||
Siddharth Agarwal
|
r27163 | use (c)hanged version, (d)elete, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | remote changed file2 which local deleted | ||
Siddharth Agarwal
|
r27163 | use (c)hanged version, leave (d)eleted, or leave (u)nresolved? | ||
Siddharth Agarwal
|
r27137 | --- diff of status --- | ||
(status identical) | ||||
=== :prompt -> :fail === | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :fail -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||