test-merge-exec.t
292 lines
| 5.9 KiB
| text/troff
|
Tads3Lexer
/ tests / test-merge-exec.t
r45394 | =============================================== | |||
Testing merge involving change to the exec flag | ||||
=============================================== | ||||
#require execbit | ||||
Initial setup | ||||
============== | ||||
$ hg init base-repo | ||||
$ cd base-repo | ||||
$ cat << EOF > a | ||||
> 1 | ||||
> 2 | ||||
> 3 | ||||
> 4 | ||||
> 5 | ||||
> 6 | ||||
> 7 | ||||
> 8 | ||||
> 9 | ||||
> EOF | ||||
$ touch b | ||||
$ hg add a b | ||||
$ hg commit -m "initial commit" | ||||
$ cd .. | ||||
r45400 | $ hg init base-exec | |||
$ cd base-exec | ||||
$ cat << EOF > a | ||||
> 1 | ||||
> 2 | ||||
> 3 | ||||
> 4 | ||||
> 5 | ||||
> 6 | ||||
> 7 | ||||
> 8 | ||||
> 9 | ||||
> EOF | ||||
$ chmod +x a | ||||
$ touch b | ||||
$ hg add a b | ||||
$ hg commit -m "initial commit" | ||||
$ cd .. | ||||
r45394 | Testing merging mode change | |||
=========================== | ||||
r45400 | Adding the flag | |||
--------------- | ||||
r45394 | setup | |||
Change on one side, executable bit on the other | ||||
$ hg clone base-repo simple-merge-repo | ||||
updating to branch default | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd simple-merge-repo | ||||
$ chmod +x a | ||||
$ hg ci -m "make a executable, no change" | ||||
$ [ -x a ] || echo "executable bit not recorded" | ||||
$ hg up ".^" | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cat << EOF > a | ||||
> 1 | ||||
> 2 | ||||
> 3 | ||||
> 4 | ||||
> 5 | ||||
> 6 | ||||
> 7 | ||||
> x | ||||
> 9 | ||||
> EOF | ||||
$ hg commit -m "edit end of file" | ||||
created new head | ||||
merge them (from the update side) | ||||
$ hg merge 'desc("make a executable, no change")' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg st | ||||
M a | ||||
$ [ -x a ] || echo "executable bit lost" | ||||
merge them (from the chmod side) | ||||
$ hg up -C 'desc("make a executable, no change")' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("edit end of file")' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg st | ||||
M a | ||||
$ [ -x a ] || echo "executable bit lost" | ||||
$ cd .. | ||||
r45400 | ||||
Removing the flag | ||||
----------------- | ||||
setup | ||||
Change on one side, executable bit on the other | ||||
$ hg clone base-exec simple-merge-repo-removal | ||||
updating to branch default | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd simple-merge-repo-removal | ||||
$ chmod -x a | ||||
$ hg ci -m "make a non-executable, no change" | ||||
$ [ -x a ] && echo "executable bit not removed" | ||||
[1] | ||||
$ hg up ".^" | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cat << EOF > a | ||||
> 1 | ||||
> 2 | ||||
> 3 | ||||
> 4 | ||||
> 5 | ||||
> 6 | ||||
> 7 | ||||
> x | ||||
> 9 | ||||
> EOF | ||||
$ hg commit -m "edit end of file" | ||||
created new head | ||||
merge them (from the update side) | ||||
$ hg merge 'desc("make a non-executable, no change")' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg st | ||||
M a | ||||
$ [ -x a ] && echo "executable bit not removed" | ||||
[1] | ||||
merge them (from the chmod side) | ||||
$ hg up -C 'desc("make a non-executable, no change")' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ hg merge 'desc("edit end of file")' | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg st | ||||
M a | ||||
$ [ -x a ] && echo "executable bit not removed" | ||||
[1] | ||||
$ cd .. | ||||
r45395 | Testing merging mode change with rename | |||
======================================= | ||||
$ hg clone base-repo rename-merge-repo | ||||
updating to branch default | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd rename-merge-repo | ||||
make "a" executable on one side | ||||
$ chmod +x a | ||||
$ hg status | ||||
M a | ||||
$ hg ci -m "make a executable" | ||||
$ [ -x a ] || echo "executable bit not recorded" | ||||
$ hg up ".^" | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
make "a" renamed on the other side | ||||
$ hg mv a z | ||||
$ hg st --copies | ||||
A z | ||||
a | ||||
R a | ||||
$ hg ci -m "rename a to z" | ||||
created new head | ||||
merge them (from the rename side) | ||||
$ hg merge 'desc("make a executable")' | ||||
r45396 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | |||
r45395 | (branch merge, don't forget to commit) | |||
$ hg st --copies | ||||
r45396 | M z | |||
a | ||||
r45395 | $ [ -x z ] || echo "executable bit lost" | |||
merge them (from the chmod side) | ||||
$ hg up -C 'desc("make a executable")' | ||||
1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
$ hg merge 'desc("rename a to z")' | ||||
r45396 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | |||
r45395 | (branch merge, don't forget to commit) | |||
$ hg st --copies | ||||
M z | ||||
r45396 | a | |||
r45395 | R a | |||
$ [ -x z ] || echo "executable bit lost" | ||||
$ cd .. | ||||
r45397 | ||||
Testing merging mode change with rename + modification on both side | ||||
=================================================================== | ||||
$ hg clone base-repo rename+mod-merge-repo | ||||
updating to branch default | ||||
2 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ cd rename+mod-merge-repo | ||||
make "a" executable on one side | ||||
$ chmod +x a | ||||
$ cat << EOF > a | ||||
> 1 | ||||
> x | ||||
> 3 | ||||
> 4 | ||||
> 5 | ||||
> 6 | ||||
> 7 | ||||
> 8 | ||||
> 9 | ||||
> EOF | ||||
$ hg status | ||||
M a | ||||
$ hg ci -m "make a executable, and change start" | ||||
$ [ -x a ] || echo "executable bit not recorded" | ||||
$ hg up ".^" | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
make "a" renamed on the other side | ||||
$ hg mv a z | ||||
$ hg st --copies | ||||
A z | ||||
a | ||||
R a | ||||
$ cat << EOF > z | ||||
> 1 | ||||
> 2 | ||||
> 3 | ||||
> 4 | ||||
> 5 | ||||
> 6 | ||||
> 7 | ||||
> x | ||||
> 9 | ||||
> EOF | ||||
$ hg ci -m "rename a to z, and change end" | ||||
created new head | ||||
merge them (from the rename side) | ||||
$ hg merge 'desc("make a executable")' | ||||
merging z and a to z | ||||
0 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg st --copies | ||||
M z | ||||
a | ||||
$ [ -x z ] || echo "executable bit lost" | ||||
merge them (from the chmod side) | ||||
$ hg up -C 'desc("make a executable")' | ||||
1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
$ hg merge 'desc("rename a to z")' | ||||
merging a and z to z | ||||
0 files updated, 1 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ hg st --copies | ||||
M z | ||||
a | ||||
R a | ||||
$ [ -x z ] || echo "executable bit lost" | ||||
$ cd .. | ||||