--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/test-removeemptydirs.t Thu Jun 28 18:07:22 2018 -0700
@@ -0,0 +1,242 @@
+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