test-mv-cp-st-diff
95 lines
| 1.7 KiB
| text/plain
|
TextLexer
/ tests / test-mv-cp-st-diff
Matt Mackall
|
r6278 | #!/bin/sh | ||
add() | ||||
{ | ||||
echo $2 >> $1 | ||||
} | ||||
hg init t | ||||
cd t | ||||
# set up a boring main branch | ||||
add a a | ||||
hg add a | ||||
Matt Mackall
|
r6425 | mkdir x | ||
add x/x x | ||||
hg add x/x | ||||
Matt Mackall
|
r6278 | hg ci -m0 | ||
add a m1 | ||||
hg ci -m1 | ||||
add a m2 | ||||
Matt Mackall
|
r6425 | add x/y y1 | ||
hg add x/y | ||||
Matt Mackall
|
r6278 | hg ci -m2 | ||
Benoit Boissinot
|
r8518 | cd .. | ||
Matt Mackall
|
r6278 | |||
show() | ||||
{ | ||||
echo "- $2: $1" | ||||
hg st -C $1 | ||||
echo | ||||
hg diff --git $1 | ||||
echo | ||||
} | ||||
Alexis S. L. Carvalho
|
r6282 | count=0 | ||
Matt Mackall
|
r6278 | # make a new branch and get diff/status output | ||
# $1 - first commit | ||||
# $2 - second commit | ||||
# $3 - working dir action | ||||
# $4 - test description | ||||
tb() | ||||
{ | ||||
Benoit Boissinot
|
r8518 | hg clone t t2 ; cd t2 | ||
Matt Mackall
|
r6278 | hg co -q -C 0 | ||
Alexis S. L. Carvalho
|
r6282 | add a $count | ||
count=`expr $count + 1` | ||||
hg ci -m "t0" | ||||
Matt Mackall
|
r6278 | $1 | ||
hg ci -m "t1" | ||||
$2 | ||||
hg ci -m "t2" | ||||
$3 | ||||
echo "** $4 **" | ||||
echo "** $1 / $2 / $3" | ||||
show "" "working to parent" | ||||
show "--rev 0" "working to root" | ||||
show "--rev 2" "working to branch" | ||||
show "--rev 0 --rev ." "root to parent" | ||||
show "--rev . --rev 0" "parent to root" | ||||
show "--rev 2 --rev ." "branch to parent" | ||||
show "--rev . --rev 2" "parent to branch" | ||||
echo | ||||
Benoit Boissinot
|
r8518 | cd .. | ||
rm -rf t2 | ||||
Matt Mackall
|
r6278 | } | ||
Matt Mackall
|
r6425 | |||
Matt Mackall
|
r6278 | tb "add a a1" "add a a2" "hg mv a b" "rename in working dir" | ||
tb "add a a1" "add a a2" "hg cp a b" "copy in working dir" | ||||
tb "hg mv a b" "add b b1" "add b w" "single rename" | ||||
tb "hg cp a b" "add b b1" "add a w" "single copy" | ||||
tb "hg mv a b" "hg mv b c" "hg mv c d" "rename chain" | ||||
tb "hg cp a b" "hg cp b c" "hg cp c d" "copy chain" | ||||
Alexis S. L. Carvalho
|
r6286 | tb "add a a1" "hg mv a b" "hg mv b a" "circular rename" | ||
Matt Mackall
|
r6425 | |||
tb "hg mv x y" "add y/x x1" "add y/x x2" "directory move" | ||||
Patrick Mezard
|
r10179 | |||
# Cannot implement unrelated branch with tb | ||||
echo '% testing copies with unrelated branch' | ||||
hg init unrelated | ||||
cd unrelated | ||||
add a a | ||||
hg ci -Am adda | ||||
hg mv a b | ||||
hg ci -m movea | ||||
hg up -C null | ||||
add a a | ||||
hg ci -Am addunrelateda | ||||
echo '% unrelated branch diff' | ||||
hg diff --git -r 2 -r 1 | ||||
cd .. | ||||