sapling/tests/test-fb-hgext-tweakdefaults.t
Jun Wu 7fa918cefd perftweaks: move commit head detection removal logic to core
Summary: Also change the internal API so it no longer accepts the "heads" argument.

Reviewed By: ryanmce

Differential Revision: D6745865

fbshipit-source-id: 368742be49b192f7630421003552d0a10eb0b76d
2018-04-13 21:50:52 -07:00

742 lines
19 KiB
Perl

$ . "$TESTDIR/histedit-helpers.sh"
$ cat >> $HGRCPATH << EOF
> [extensions]
> tweakdefaults=
> fbamend=
> rebase=
> histedit=
> [experimental]
> updatecheck=noconflict
> EOF
Setup repo
$ hg init repo
$ cd repo
$ touch a
$ hg commit -Aqm a
$ mkdir dir
$ touch dir/b
$ hg commit -Aqm b
$ hg up -q 0
$ echo x >> a
$ hg commit -Aqm a2
Empty update fails
$ hg up -q 0
$ hg up
abort: You must specify a destination to update to, for example "hg update master".
(If you're trying to move a bookmark forward, try "hg rebase -d <destination>".)
[255]
$ hg up -q -r 1
$ hg log -r . -T '{rev}\n'
1
$ hg up -q 1
$ hg log -r . -T '{rev}\n'
1
Updating to a specific date isn't blocked by our extensions'
$ hg bookmark temp
$ hg up -d "<today"
found revision 2 from Thu Jan 01 00:00:00 1970 +0000
1 files updated, 0 files merged, 1 files removed, 0 files unresolved
(leaving bookmark temp)
$ hg up temp
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
(activating bookmark temp)
$ hg bookmark --delete temp
Log is -f by default
$ hg log -G -T '{rev} {desc}\n'
@ 1 b
|
o 0 a
$ hg log -G -T '{rev} {desc}\n' --all
o 2 a2
|
| @ 1 b
|/
o 0 a
Dirty update to different rev fails with --check
$ echo x >> a
$ hg st
M a
$ hg update ".^" --check
abort: uncommitted changes
[255]
Dirty update allowed to same rev, with no conflicts, and --clean
$ hg update .
0 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ hg update ".^"
0 files updated, 0 files merged, 1 files removed, 0 files unresolved
(hint: use 'hg prev' to move to the parent changeset)
$ hg update --clean 1
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
Log on dir's works
$ hg log -T '{rev} {desc}\n' dir
1 b
$ hg log -T '{rev} {desc}\n' -I 'dir/*'
1 b
Empty rebase fails
$ hg rebase
abort: you must specify a destination (-d) for the rebase
[255]
$ hg rebase -d 2
rebasing 1:7b4cb4e1674c "b"
saved backup bundle to $TESTTMP/repo/.hg/strip-backup/7b4cb4e1674c-f22b5b1e-rebase.hg (glob)
Empty rebase with nooprebase=True (default) succeeds
$ hg rebase -s tip -d "tip^1"
nothing to rebase
Empty rebase with nooprebase=False fails
$ hg rebase --config 'tweakdefaults.nooprebase=False' -s tip -d "tip^1"
nothing to rebase
[1]
Rebase fast forwards bookmark
$ hg book -r 1 mybook
$ hg up -q mybook
$ hg log -G -T '{rev} {desc} {bookmarks}\n'
@ 1 a2 mybook
|
o 0 a
$ hg rebase -d 2
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ hg log -G -T '{rev} {desc} {bookmarks}\n'
@ 2 b mybook
|
o 1 a2
|
o 0 a
Rebase works with hyphens
$ hg book -r 1 hyphen-book
$ hg book -r 2 hyphen-dest
$ hg up -q hyphen-book
$ hg log --all -G -T '{rev} {desc} {bookmarks}\n'
o 2 b hyphen-dest mybook
|
@ 1 a2 hyphen-book
|
o 0 a
$ hg rebase -d hyphen-dest
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ hg log --all -G -T '{rev} {desc} {bookmarks}\n'
@ 2 b hyphen-book hyphen-dest mybook
|
o 1 a2
|
o 0 a
Grep options work
$ mkdir -p dir1/subdir1
$ echo str1f1 >> dir1/f1
$ echo str1-v >> dir1/-v
$ echo str1space >> 'dir1/file with space'
$ echo str1sub >> dir1/subdir1/subf1
$ hg add -q dir1
$ hg grep x
a:x
$ hg grep -i X
a:x
$ hg grep -l x
a
$ hg grep -n x
a:1:x
#if osx
$ hg grep -V ''
#else
$ hg grep -V ''
[123]
#endif
Make sure grep works in subdirectories and with strange filenames
$ cd dir1
$ hg grep str1
-v:str1-v
f1:str1f1
file with space:str1space
subdir1/subf1:str1sub
$ hg grep str1 'relre:f[0-9]+'
f1:str1f1
subdir1/subf1:str1sub
Basic vs extended regular expressions
#if osx
$ hg grep 'str([0-9])'
[1]
#else
$ hg grep 'str([0-9])'
[123]
#endif
$ hg grep 'str\([0-9]\)'
-v:str1-v
f1:str1f1
file with space:str1space
subdir1/subf1:str1sub
#if osx
$ hg grep -F 'str[0-9]'
[1]
#else
$ hg grep -F 'str[0-9]'
[123]
#endif
$ hg grep -E 'str([0-9])'
-v:str1-v
f1:str1f1
file with space:str1space
subdir1/subf1:str1sub
Filesets
$ hg grep str1 'set:added()'
-v:str1-v
f1:str1f1
file with space:str1space
subdir1/subf1:str1sub
Crazy filenames
$ hg grep str1 -- -v
-v:str1-v
$ hg grep str1 'glob:*v'
-v:str1-v
$ hg grep str1 'file with space'
file with space:str1space
$ hg grep str1 'glob:*with*'
file with space:str1space
$ hg grep str1 'glob:*f1'
f1:str1f1
$ hg grep str1 subdir1
subdir1/subf1:str1sub
$ hg grep str1 'glob:**/*f1'
f1:str1f1
subdir1/subf1:str1sub
Test tweaked branch command
$ hg branch
default
$ hg branch foo --config tweakdefaults.allowbranch=false
abort: new named branches are disabled in this repository
[255]
$ hg branch -C
reset working directory to branch default
$ hg branch --config tweakdefaults.allowbranch=false --config tweakdefaults.branchmessage='testing' foo
abort: testing
[255]
$ hg branch --config tweakdefaults.allowbranch=false --new foo
abort: new named branches are disabled in this repository
[255]
$ hg branch foo
abort: do not use branches; use bookmarks instead
(use --new if you are certain you want a branch)
[255]
$ hg branch --new foo
marked working directory as branch foo
(branches are permanent and global, did you want a bookmark?)
$ hg branches --config tweakdefaults.branchesmessage='testing' > /dev/null
testing
Test tweaked merge command
$ hg merge | head -n1
abort: no matching bookmark to merge - please merge with an explicit rev or bookmark
(run 'hg heads' to see all heads)
$ hg merge --config tweakdefaults.allowmerge=false
abort: merging is not supported for this repository
(use rebase instead)
[255]
$ hg merge --config tweakdefaults.mergemessage='testing' --config tweakdefaults.mergehint='hint' --config tweakdefaults.allowmerge=false
abort: testing
(hint)
[255]
Test that status is default relative
$ mkdir foo
$ cd foo
$ hg status
A ../-v
A ../f1
A ../file with space
A ../subdir1/subf1
$ hg status --root-relative
A dir1/-v
A dir1/f1
A dir1/file with space
A dir1/subdir1/subf1
$ hg status .
$ hg status ../subdir1
A ../subdir1/subf1
Test that --root-relative and patterns abort
$ hg status --root-relative ""
abort: --root-relative not supported with patterns
(run from the repo root instead)
[255]
Don't break automation
$ HGPLAIN=1 hg status
A dir1/-v
A dir1/f1
A dir1/file with space
A dir1/subdir1/subf1
Test tweaked rollback command
$ hg rollback --config tweakdefaults.allowrollback=false
abort: the use of rollback is disabled
[255]
$ hg rollback --config tweakdefaults.allowrollback=false --config tweakdefaults.rollbackmessage='testing'
abort: testing
[255]
$ hg rollback --config tweakdefaults.allowrollback=false --config tweakdefaults.rollbackmessage='testing' --config tweakdefaults.rollbackhint='hint'
abort: testing
(hint)
[255]
Test tweaked tag command
$ hg tag foo
$ hg tag --config tweakdefaults.allowtags=false foo
abort: new tags are disabled in this repository
[255]
$ hg tag --config tweakdefaults.allowtags=false --config tweakdefaults.tagmessage='testing' foo
abort: testing
[255]
$ hg tags --config tweakdefaults.tagsmessage='testing' > /dev/null
testing
Test graft date when tweakdefaults.graftkeepdate is not set
$ hg revert -a -q
$ hg up -q 1
$ hg graft -q 2
$ hg log -T "{rev}\n" -d "yesterday to today"
4
Test graft date when tweakdefaults.graftkeepdate is not set and --date is provided
$ hg up -q 1
$ hg graft -q 2 --date "1 1"
$ hg log -l 1 -T "{date} {rev}\n"
1.01 5
Test graft date when tweakdefaults.graftkeepdate is set
$ hg up -q 1
$ hg graft -q 5 --config tweakdefaults.graftkeepdate=True
$ hg log -l 1 -T "{date} {rev}\n"
1.01 6
Test amend date when tweakdefaults.amendkeepdate is not set
$ hg up -q 1
$ echo x > a
$ hg commit -Aqm "commit for amend"
$ echo x > a
$ hg amend -q -m "amended message"
$ hg log -T "{rev}\n" -d "yesterday to today"
7
Test amend date when tweakdefaults.amendkeepdate is set
$ touch new_file
$ hg commit -d "0 0" -Aqm "commit for amend"
$ echo x > new_file
$ hg amend -q -m "amended message" --config tweakdefaults.amendkeepdate=True
$ hg log -l 1 -T "{date} {rev}\n"
0.00 8
Test amend --to doesn't give a flag error when tweakdefaults.amendkeepdate is set
$ echo q > new_file
$ hg amend --to 8 --config tweakdefaults.amendkeepdate=False
hg: parse error: pick "3903775176ed" changeset was not a candidate
(only use listed changesets)
[255]
$ hg log -l 1 -T "{date} {rev}\n"
0.00 9
Test commit --amend date when tweakdefaults.amendkeepdate is set
$ echo a >> new_file
$ hg commit -d "0 0" -Aqm "commit for amend"
$ echo x > new_file
$ hg commit -q --amend -m "amended message" --config tweakdefaults.amendkeepdate=True
$ hg log -l 1 -T "{date} {rev}\n"
0.00 10
Test commit --amend date when tweakdefaults.amendkeepdate is not set and --date is provided
$ echo xxx > a
$ hg commit -d "0 0" -Aqm "commit for amend"
$ echo x > a
$ hg commit -q --amend -m "amended message" --date "1 1"
$ hg log -l 1 -T "{date} {rev}\n"
1.01 11
Test rebase date when tweakdefaults.rebasekeepdate is not set
$ echo test_1 > rebase_dest
$ hg commit --date "1 1" -Aqm "dest commit for rebase"
$ hg bookmark rebase_dest_test_1
$ hg up -q ".^"
$ echo test_1 > rebase_source
$ hg commit --date "1 1" -Aqm "source commit for rebase"
$ hg bookmark rebase_source_test_1
$ hg rebase -q -s rebase_source_test_1 -d rebase_dest_test_1
$ hg log -l 1 -T "{rev}\n" -d "yesterday to today"
13
Test rebase date when tweakdefaults.rebasekeepdate is set
$ echo test_2 > rebase_dest
$ hg commit -Aqm "dest commit for rebase"
$ hg bookmark rebase_dest_test_2
$ hg up -q ".^"
$ echo test_2 > rebase_source
$ hg commit -Aqm "source commit for rebase"
$ hg bookmark rebase_source_test_2
$ hg rebase -q -s rebase_source_test_2 -d rebase_dest_test_2 --config tweakdefaults.rebasekeepdate=True
$ hg log -l 2 -T "{date} {rev}\n"
0.00 15
0.00 14
Test histedit date when tweakdefaults.histeditkeepdate is set
$ hg bookmark histedit_test
$ echo test_1 > histedit_1
$ hg commit -Aqm "commit 1 for histedit"
$ echo test_2 > histedit_2
$ hg commit -Aqm "commit 2 for histedit"
$ echo test_3 > histedit_3
$ hg commit -Aqm "commit 3 for histedit"
$ hg histedit 16 --commands - --config tweakdefaults.histeditkeepdate=True 2>&1 <<EOF| fixbundle
> pick 16
> pick 18
> pick 17
> EOF
$ hg log -l 3 -T "{date} {rev} {desc}\n"
0.00 18 commit 2 for histedit
0.00 17 commit 3 for histedit
0.00 16 commit 1 for histedit
Test histedit date when tweakdefaults.histeditkeepdate is not set
$ hg histedit 16 --commands - 2>&1 <<EOF| fixbundle
> pick 16
> pick 18
> pick 17
> EOF
$ hg log -l 2 -T "{rev} {desc}\n" -d "yesterday to today"
18 commit 3 for histedit
17 commit 2 for histedit
Test reuse message flag by taking message from previous commit
$ cd ../..
$ hg up -q hyphen-book
$ touch afile
$ hg add afile
$ hg commit -M 2
$ hg log --template {desc} -r .
b (no-eol)
$ echo 'canada rocks, eh?' > afile
$ hg commit -M . -m 'this command will fail'
abort: --reuse-message and --message are mutually exclusive
[255]
$ echo 'Super duper commit message' > ../commitmessagefile
$ hg commit -M . -l ../commitmessagefile
abort: --reuse-message and --logfile are mutually exclusive
[255]
$ hg commit -M thisrevsetdoesnotexist
abort: unknown revision 'thisrevsetdoesnotexist'!
[255]
$ HGEDITOR=cat hg commit -M . -e
b
HG: Enter commit message. Lines beginning with 'HG:' are removed.
HG: Leave message empty to abort commit.
HG: --
HG: user: test
HG: branch 'foo'
HG: bookmark 'hyphen-book'
HG: changed afile
Test non-remotenames use of pull --rebase and --update requires --dest
$ cd $TESTTMP
$ hg clone repo clone
updating to branch default
12 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ cd clone
$ hg pull --rebase
abort: you must use a bookmark with tracking or manually specify a destination for the rebase
(set up tracking with `hg book <name> -t <destination>` or manually supply --dest / -d)
[255]
$ hg pull --update
abort: you must specify a destination for the update
(use `hg pull --update --dest <destination>`)
[255]
$ echo foo > foo
$ hg commit -Am 'foo'
adding foo
$ hg pull --rebase -d default
pulling from $TESTTMP/repo (glob)
searching for changes
no changes found
nothing to rebase - working directory parent is also destination
$ hg pull --update -d default
pulling from $TESTTMP/repo (glob)
searching for changes
no changes found
0 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ hg pull --rebase --config tweakdefaults.defaultdest=default
pulling from $TESTTMP/repo (glob)
searching for changes
no changes found
nothing to rebase - working directory parent is also destination
$ hg pull --update --config tweakdefaults.defaultdest=default
pulling from $TESTTMP/repo (glob)
searching for changes
no changes found
0 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ cd $TESTTMP
Prepare a repo for testing divergence warnings with respect to inhibit extension
and allowance of prune rebases
$ hg init repodiv && cd repodiv
$ cat >> .hg/hgrc << EOF
> [experimental]
> evolution=createmarkers
> prunestrip=on
> evolution.allowdivergence=off
> [extensions]
> strip=
> fbamend=
> EOF
$ echo root > root && hg ci -Am root # rev 0
adding root
$ echo a > a && hg ci -Am a # rev 1
adding a
$ hg up 0 && echo b > b && hg ci -Am b # rev 2
0 files updated, 0 files merged, 1 files removed, 0 files unresolved
adding b
$ hg up 0 && echo c > c && hg ci -Am c # rev 3
0 files updated, 0 files merged, 1 files removed, 0 files unresolved
adding c
$ hg up 0 && echo d > d && hg ci -Am d # rev 4
0 files updated, 0 files merged, 1 files removed, 0 files unresolved
adding d
$ hg rebase -r 1 -d 2
rebasing 1:09d39afb522a "a"
Test that we show divergence warning if inhibit is disabled
$ hg rebase -r 1 -d 3 --hidden
abort: this rebase will cause divergences from: 09d39afb522a
(to force the rebase please set experimental.evolution.allowdivergence=True)
[255]
Test that we do not show divergence warning if inhibit is enabled
$ cat >> .hg/hgrc <<EOF
> inhibit=
> EOF
$ hg rebase -r 1 -d 3 --hidden
rebasing 1:09d39afb522a "a"
Test that we allow pure prune rebases
$ hg strip 4
advice: 'hg hide' provides a better UI for hiding commits
0 files updated, 0 files merged, 1 files removed, 0 files unresolved
working directory now at 1e4be0697311
1 changesets pruned
$ hg rebase -r 4 -d 3 --hidden
rebasing 4:31aefaa21905 "d"
Test diff --per-file-stat
$ echo a >> a
$ echo b > b
$ hg add a b
$ hg ci -m A
$ hg diff -r ".^" -r .
diff -r 1e4be0697311 -r d17770b7624d a
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/a Thu Jan 01 00:00:00 1970 +0000
@@ -0,0 +1,1 @@
+a
diff -r 1e4be0697311 -r d17770b7624d b
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/b Thu Jan 01 00:00:00 1970 +0000
@@ -0,0 +1,1 @@
+b
$ hg diff -r ".^" -r . --per-file-stat-json
{"a": {"adds": 1, "isbinary": false, "removes": 0}, "b": {"adds": 1, "isbinary": false, "removes": 0}}
Test rebase with showupdated=True
$ cd $TESTTMP
$ hg init showupdated
$ cd showupdated
$ cat >> .hg/hgrc <<EOF
> [tweakdefaults]
> showupdated=True
> rebasekeepdate=True
> EOF
$ touch a && hg commit -Aqm a
$ touch b && hg commit -Aqm b
$ hg up -q 0
$ touch c && hg commit -Aqm c
$ hg log -G -T '{node} {rev} {bookmarks}' -r 'all()'
@ d5e255ef74f8ec83b3a2a3f3254c699451c89e29 2
|
| o 0e067c57feba1a5694ca4844f05588bb1bf82342 1
|/
o 3903775176ed42b1458a6281db4a0ccf4d9f287a 0
$ hg rebase -r 1 -d 2
rebasing 1:0e067c57feba "b"
0e067c57feba -> a602e0d56f83 "b"
saved backup bundle to $TESTTMP/showupdated/.hg/strip-backup/0e067c57feba-ca6d05e3-rebase.hg (glob)
Test rebase with showupdate=True and a lot of source revisions
$ hg up -q 0
$ for i in `$TESTDIR/seq.py 11`; do touch "$i" && hg commit -Aqm "$i" && hg up -q 0; done
$ hg log -G -T '{node} {rev} {bookmarks}' -r 'all()'
o 6e3ddf6f49efd0a836a470a2d45e953db915c262 13
|
| o e02ec9861284762c93b8a4c9e0bac0abfbb59ac7 12
|/
| o 14218977adef919e86466c688defa3fb893a5638 11
|/
| o 6a01a2bb0a9f7a6f01c6f49ce90e60bf85de79d0 10
|/
| o e5ec40f709911f69eafada5746d3f5b969005738 9
|/
| o 73800d52e8ddab37a1f9177299d1fdfb563c061a 8
|/
| o 657f1516f142d51ba06b98413ce35a884f7f8af0 7
|/
| o 4e6ba707bdb81e60d96b84099c2d1c56530ee6f1 6
|/
| o 7ab24e484dafd1d2ebf51a4fa4523431b81b99aa 5
|/
| o ee71024c6e8c4a45ee1d3e462431bfec85ac215a 4
|/
| o 46a418a0abd225d8ad876102f495d209907b79d9 3
|/
| o a602e0d56f83e5816ebcbb78095e259ffbce94aa 2
| |
| o d5e255ef74f8ec83b3a2a3f3254c699451c89e29 1
|/
@ 3903775176ed42b1458a6281db4a0ccf4d9f287a 0
$ hg rebase -r 'all() - 0 - 12' -d 12
rebasing 1:d5e255ef74f8 "c"
rebasing 2:a602e0d56f83 "b"
rebasing 3:46a418a0abd2 "1"
rebasing 4:ee71024c6e8c "2"
rebasing 5:7ab24e484daf "3"
rebasing 6:4e6ba707bdb8 "4"
rebasing 7:657f1516f142 "5"
rebasing 8:73800d52e8dd "6"
rebasing 9:e5ec40f70991 "7"
rebasing 10:6a01a2bb0a9f "8"
rebasing 11:14218977adef "9"
rebasing 13:6e3ddf6f49ef "11" (tip)
14218977adef -> 2d12dd93bf8b "9"
46a418a0abd2 -> 645dc4557ba8 "1"
4e6ba707bdb8 -> b9598afdff23 "4"
657f1516f142 -> 906a55b270d4 "5"
6a01a2bb0a9f -> f5a7b375c4a9 "8"
6e3ddf6f49ef -> ad74bbdbdb75 "11"
73800d52e8dd -> 3145d47a5692 "6"
7ab24e484daf -> 03a9e0e4badc "3"
a602e0d56f83 -> e7a99f1fea2a "b"
d5e255ef74f8 -> 72d850a207d5 "c"
...
ee71024c6e8c -> 0c42bb4bf23f "2"
saved backup bundle to $TESTTMP/showupdated/.hg/strip-backup/6e3ddf6f49ef-4b18babd-rebase.hg (glob)
Test rebase with showupdate=True and a long commit message
$ touch longfile && hg add -q
$ hg commit -qm "This is a long commit message which will be truncated."
$ hg rebase -d 1
rebasing 14:e915a57d67db "This is a long commit message which will be truncated." (tip)
e915a57d67db -> 5444f740ff6c "This is a long commit message which will be tru..."
saved backup bundle to $TESTTMP/showupdated/.hg/strip-backup/e915a57d67db-ad3372b5-rebase.hg (glob)
Test bookmark -D
$ cd $TESTTMP
$ hg init book-D
$ cd book-D
$ cat >> .hg/hgrc <<EOF
> [extensions]
> strip=
> [experimental]
> evolution=all
> EOF
$ hg debugbuilddag '+4*2*2*2'
$ hg bookmark -i -r 1 master
$ hg bookmark -i -r 5 feature1
$ hg bookmark -i -r 6 feature2
$ hg log -G -T '{rev} {bookmarks}' -r 'all()'
o 6 feature2
|
| o 5 feature1
| |
o | 4
| |
| o 3
|/
o 2
|
o 1 master
|
o 0
$ hg bookmark -D feature1
advice: 'hg hide' provides a better UI for hiding commits
bookmark 'feature1' deleted
2 changesets pruned
$ hg log -G -T '{rev} {bookmarks}' -r 'all()' --hidden
o 6 feature2
|
| x 5
| |
o | 4
| |
| x 3
|/
o 2
|
o 1 master
|
o 0
$ hg bookmark -D feature2 --config extensions.fbamend=!
saved backup bundle to $TESTTMP/book-D/.hg/strip-backup/1c4dfc7a8985-4027cf08-backup.hg (glob)
bookmark 'feature2' deleted
$ hg log -G -T '{rev} {bookmarks}' -r 'all()' --hidden
x 4
|
x 3
|
o 2
|
o 1 master
|
o 0