test-removeemptydirs.t
242 lines
| 5.8 KiB
| text/troff
|
Tads3Lexer
/ tests / test-removeemptydirs.t
Kyle Lippincott
|
r38512 | Tests for experimental.removeemptydirs | ||
$ NO_RM=--config=experimental.removeemptydirs=0 | ||||
$ isdir() { if [ -d $1 ]; then echo yes; else echo no; fi } | ||||
$ isfile() { if [ -f $1 ]; then echo yes; else echo no; fi } | ||||
`hg rm` of the last file in a directory: | ||||
$ hg init hgrm | ||||
$ cd hgrm | ||||
$ mkdir somedir | ||||
$ echo hi > somedir/foo | ||||
$ hg ci -qAm foo | ||||
$ isdir somedir | ||||
yes | ||||
$ hg rm somedir/foo | ||||
$ isdir somedir | ||||
no | ||||
$ hg revert -qa | ||||
$ isdir somedir | ||||
yes | ||||
$ hg $NO_RM rm somedir/foo | ||||
$ isdir somedir | ||||
yes | ||||
$ ls somedir | ||||
$ cd $TESTTMP | ||||
`hg mv` of the last file in a directory: | ||||
$ hg init hgmv | ||||
$ cd hgmv | ||||
$ mkdir somedir | ||||
$ mkdir destdir | ||||
$ echo hi > somedir/foo | ||||
$ hg ci -qAm foo | ||||
$ isdir somedir | ||||
yes | ||||
$ hg mv somedir/foo destdir/foo | ||||
$ isdir somedir | ||||
no | ||||
$ hg revert -qa | ||||
(revert doesn't get rid of destdir/foo?) | ||||
$ rm destdir/foo | ||||
$ isdir somedir | ||||
yes | ||||
$ hg $NO_RM mv somedir/foo destdir/foo | ||||
$ isdir somedir | ||||
yes | ||||
$ ls somedir | ||||
$ cd $TESTTMP | ||||
Updating to a commit that doesn't have the directory: | ||||
$ hg init hgupdate | ||||
$ cd hgupdate | ||||
$ echo hi > r0 | ||||
$ hg ci -qAm r0 | ||||
$ mkdir somedir | ||||
$ echo hi > somedir/foo | ||||
$ hg ci -qAm r1 | ||||
$ isdir somedir | ||||
yes | ||||
$ hg co -q -r ".^" | ||||
$ isdir somedir | ||||
no | ||||
$ hg co -q tip | ||||
$ isdir somedir | ||||
yes | ||||
$ hg $NO_RM co -q -r ".^" | ||||
$ isdir somedir | ||||
yes | ||||
$ ls somedir | ||||
$ cd $TESTTMP | ||||
Rebasing across a commit that doesn't have the directory, from inside the | ||||
directory: | ||||
$ hg init hgrebase | ||||
$ cd hgrebase | ||||
$ echo hi > r0 | ||||
$ hg ci -qAm r0 | ||||
$ mkdir somedir | ||||
$ echo hi > somedir/foo | ||||
$ hg ci -qAm first_rebase_source | ||||
$ hg $NO_RM co -q -r ".^" | ||||
$ echo hi > somedir/bar | ||||
$ hg ci -qAm first_rebase_dest | ||||
$ hg $NO_RM co -q -r ".^" | ||||
$ echo hi > somedir/baz | ||||
$ hg ci -qAm second_rebase_dest | ||||
$ hg co -qr 'desc(first_rebase_source)' | ||||
$ cd $TESTTMP/hgrebase/somedir | ||||
$ hg --config extensions.rebase= rebase -qr . -d 'desc(first_rebase_dest)' | ||||
current directory was removed | ||||
(consider changing to repo root: $TESTTMP/hgrebase) | ||||
$ cd $TESTTMP/hgrebase/somedir | ||||
(The current node is the rebased first_rebase_source on top of | ||||
first_rebase_dest) | ||||
This should not output anything about current directory being removed: | ||||
$ hg $NO_RM --config extensions.rebase= rebase -qr . -d 'desc(second_rebase_dest)' | ||||
$ cd $TESTTMP | ||||
Histediting across a commit that doesn't have the directory, from inside the | ||||
directory (reordering nodes): | ||||
$ hg init hghistedit | ||||
$ cd hghistedit | ||||
$ echo hi > r0 | ||||
$ hg ci -qAm r0 | ||||
$ echo hi > r1 | ||||
$ hg ci -qAm r1 | ||||
$ echo hi > r2 | ||||
$ hg ci -qAm r2 | ||||
$ mkdir somedir | ||||
$ echo hi > somedir/foo | ||||
$ hg ci -qAm migrating_revision | ||||
$ cat > histedit_commands <<EOF | ||||
> pick 89079fab8aee 0 r0 | ||||
> pick e6d271df3142 1 r1 | ||||
> pick 89e25aa83f0f 3 migrating_revision | ||||
> pick b550aa12d873 2 r2 | ||||
> EOF | ||||
$ cd $TESTTMP/hghistedit/somedir | ||||
$ hg --config extensions.histedit= histedit -q --commands ../histedit_commands | ||||
histedit doesn't output anything when the current diretory is removed. We rely | ||||
on the tests being commonly run on machines where the current directory | ||||
disappearing from underneath us actually has an observable effect, such as an | ||||
error or no files listed | ||||
#if linuxormacos | ||||
$ isfile foo | ||||
no | ||||
#endif | ||||
$ cd $TESTTMP/hghistedit/somedir | ||||
$ isfile foo | ||||
yes | ||||
$ cd $TESTTMP/hghistedit | ||||
$ cat > histedit_commands <<EOF | ||||
> pick 89079fab8aee 0 r0 | ||||
> pick 7c7a22c6009f 3 migrating_revision | ||||
> pick e6d271df3142 1 r1 | ||||
> pick 40a53c2d4276 2 r2 | ||||
> EOF | ||||
$ cd $TESTTMP/hghistedit/somedir | ||||
$ hg $NO_RM --config extensions.histedit= histedit -q --commands ../histedit_commands | ||||
Regardless of system, we should always get a 'yes' here. | ||||
$ isfile foo | ||||
yes | ||||
$ cd $TESTTMP | ||||
This is essentially the exact test from issue5826, just cleaned up a little: | ||||
$ hg init issue5826_withrm | ||||
$ cd issue5826_withrm | ||||
$ cat >> $HGRCPATH <<EOF | ||||
> [extensions] | ||||
> histedit = | ||||
> EOF | ||||
Commit three revisions that each create a directory: | ||||
$ mkdir foo | ||||
$ touch foo/bar | ||||
$ hg commit -qAm "add foo" | ||||
$ mkdir bar | ||||
$ touch bar/bar | ||||
$ hg commit -qAm "add bar" | ||||
$ mkdir baz | ||||
$ touch baz/bar | ||||
$ hg commit -qAm "add baz" | ||||
Enter the first directory: | ||||
$ cd foo | ||||
Histedit doing 'pick, pick, fold': | ||||
$ hg histedit --commands /dev/stdin <<EOF | ||||
> pick 6274c77c93c3 1 add bar | ||||
> pick ff70a87b588f 0 add foo | ||||
> fold 9992bb0ac0db 2 add baz | ||||
> EOF | ||||
abort: $ENOENT$ | ||||
[255] | ||||
Go back to the repo root after losing it as part of that operation: | ||||
$ cd $TESTTMP/issue5826_withrm | ||||
Note the lack of a non-zero exit code from this function - it exits | ||||
successfully, but doesn't really do anything. | ||||
$ hg histedit --continue | ||||
9992bb0ac0db: cannot fold - working copy is not a descendant of previous commit 5c806432464a | ||||
saved backup bundle to $TESTTMP/issue5826_withrm/.hg/strip-backup/ff70a87b588f-e94f9789-histedit.hg | ||||
$ hg log -T '{rev}:{node|short} {desc}\n' | ||||
2:94e3f9fae1d6 fold-temp-revision 9992bb0ac0db | ||||
1:5c806432464a add foo | ||||
0:d17db4b0303a add bar | ||||
Now test that again with experimental.removeemptydirs=false: | ||||
$ hg init issue5826_norm | ||||
$ cd issue5826_norm | ||||
$ cat >> $HGRCPATH <<EOF | ||||
> [extensions] | ||||
> histedit = | ||||
> [experimental] | ||||
> removeemptydirs = false | ||||
> EOF | ||||
Commit three revisions that each create a directory: | ||||
$ mkdir foo | ||||
$ touch foo/bar | ||||
$ hg commit -qAm "add foo" | ||||
$ mkdir bar | ||||
$ touch bar/bar | ||||
$ hg commit -qAm "add bar" | ||||
$ mkdir baz | ||||
$ touch baz/bar | ||||
$ hg commit -qAm "add baz" | ||||
Enter the first directory: | ||||
$ cd foo | ||||
Histedit doing 'pick, pick, fold': | ||||
$ hg histedit --commands /dev/stdin <<EOF | ||||
> pick 6274c77c93c3 1 add bar | ||||
> pick ff70a87b588f 0 add foo | ||||
> fold 9992bb0ac0db 2 add baz | ||||
> EOF | ||||
saved backup bundle to $TESTTMP/issue5826_withrm/issue5826_norm/.hg/strip-backup/5c806432464a-cd4c8d86-histedit.hg | ||||
Note the lack of a 'cd' being necessary here, and we don't need to 'histedit | ||||
--continue' | ||||
$ hg log -T '{rev}:{node|short} {desc}\n' | ||||
1:b9eddaa97cbc add foo | ||||
*** | ||||
add baz | ||||
0:d17db4b0303a add bar | ||||