##// END OF EJS Templates
perf: add command for measuring revlog chunk operations...
perf: add command for measuring revlog chunk operations Upcoming commits will teach revlogs to leverage the new compression engine API so that new compression formats can more easily be leveraged in revlogs. We want to be sure this refactoring doesn't regress performance. So this commit introduces "perfrevchunks" to explicitly test performance of reading, decompressing, and recompressing revlog chunks. Here is output when run on the mozilla-unified repo: $ hg perfrevlogchunks -c ! read ! wall 0.346603 comb 0.350000 user 0.340000 sys 0.010000 (best of 28) ! read w/ reused fd ! wall 0.337707 comb 0.340000 user 0.320000 sys 0.020000 (best of 30) ! read batch ! wall 0.013206 comb 0.020000 user 0.000000 sys 0.020000 (best of 221) ! read batch w/ reused fd ! wall 0.013259 comb 0.030000 user 0.010000 sys 0.020000 (best of 222) ! chunk ! wall 1.909939 comb 1.910000 user 1.900000 sys 0.010000 (best of 6) ! chunk batch ! wall 1.750677 comb 1.760000 user 1.740000 sys 0.020000 (best of 6) ! compress ! wall 5.668004 comb 5.670000 user 5.670000 sys 0.000000 (best of 3) $ hg perfrevlogchunks -m ! read ! wall 0.365834 comb 0.370000 user 0.350000 sys 0.020000 (best of 26) ! read w/ reused fd ! wall 0.350160 comb 0.350000 user 0.320000 sys 0.030000 (best of 28) ! read batch ! wall 0.024777 comb 0.020000 user 0.000000 sys 0.020000 (best of 119) ! read batch w/ reused fd ! wall 0.024895 comb 0.030000 user 0.000000 sys 0.030000 (best of 118) ! chunk ! wall 2.514061 comb 2.520000 user 2.480000 sys 0.040000 (best of 4) ! chunk batch ! wall 2.380788 comb 2.380000 user 2.360000 sys 0.020000 (best of 5) ! compress ! wall 9.815297 comb 9.820000 user 9.820000 sys 0.000000 (best of 3) We already see some interesting data, such as how much slower non-batched chunk reading is and that zlib compression appears to be >2x slower than decompression. I didn't have the data when I wrote this commit message, but I ran this on Mozilla's NFS-based Mercurial server and the time for reading with a reused file descriptor was faster. So I think it is worth testing both with and without file descriptor reuse so we can make informed decisions about recycling file descriptors.

File last commit:

r24501:8b51ec98 default
r30451:94ca0e13 default
Show More
test-git-export.t
615 lines | 11.7 KiB | text/troff | Tads3Lexer
/ tests / test-git-export.t
Adrian Buehlmann
tests: unify test-git-*
r12193 $ hg init
$ echo start > start
$ hg ci -Amstart
adding start
New file:
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 $ mkdir dir1
$ echo new > dir1/new
Adrian Buehlmann
tests: unify test-git-*
r12193 $ hg ci -Amnew
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 adding dir1/new
Adrian Buehlmann
tests: unify test-git-*
r12193 $ hg diff --git -r 0
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/dir1/new b/dir1/new
Adrian Buehlmann
tests: unify test-git-*
r12193 new file mode 100644
--- /dev/null
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 +++ b/dir1/new
Adrian Buehlmann
tests: unify test-git-*
r12193 @@ -0,0 +1,1 @@
+new
Copy:
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 $ mkdir dir2
$ hg cp dir1/new dir1/copy
$ echo copy1 >> dir1/copy
$ hg cp dir1/new dir2/copy
$ echo copy2 >> dir2/copy
Adrian Buehlmann
tests: unify test-git-*
r12193 $ hg ci -mcopy
$ hg diff --git -r 1:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/dir1/new b/dir1/copy
copy from dir1/new
copy to dir1/copy
--- a/dir1/new
+++ b/dir1/copy
@@ -1,1 +1,2 @@
new
+copy1
diff --git a/dir1/new b/dir2/copy
copy from dir1/new
copy to dir2/copy
--- a/dir1/new
+++ b/dir2/copy
@@ -1,1 +1,2 @@
new
+copy2
Cross and same-directory copies with a relative root:
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root .. -r 1:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 abort: .. not under root '$TESTTMP'
[255]
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root doesnotexist -r 1:tip
$ hg diff --git --root . -r 1:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/dir1/new b/dir1/copy
copy from dir1/new
copy to dir1/copy
--- a/dir1/new
+++ b/dir1/copy
@@ -1,1 +1,2 @@
new
+copy1
diff --git a/dir1/new b/dir2/copy
copy from dir1/new
copy to dir2/copy
--- a/dir1/new
+++ b/dir2/copy
@@ -1,1 +1,2 @@
new
+copy2
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root dir1 -r 1:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/new b/copy
copy from new
copy to copy
--- a/new
+++ b/copy
@@ -1,1 +1,2 @@
new
+copy1
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root dir2/ -r 1:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/copy b/copy
new file mode 100644
--- /dev/null
+++ b/copy
@@ -0,0 +1,2 @@
+new
+copy2
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root dir1 -r 1:tip -I '**/copy'
Adrian Buehlmann
tests: unify test-git-*
r12193 diff --git a/new b/copy
copy from new
copy to copy
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 --- a/new
+++ b/copy
@@ -1,1 +1,2 @@
new
+copy1
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root dir1 -r 1:tip dir2
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 warning: dir2 not inside relative root dir1
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root dir1 -r 1:tip 'dir2/{copy}'
Matt Harbison
test-git-export: add globs the test runner wants on Windows...
r24501 warning: dir2/{copy} not inside relative root dir1 (glob)
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432
$ cd dir1
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root .. -r 1:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/dir1/new b/dir1/copy
copy from dir1/new
copy to dir1/copy
--- a/dir1/new
+++ b/dir1/copy
@@ -1,1 +1,2 @@
new
+copy1
diff --git a/dir1/new b/dir2/copy
copy from dir1/new
copy to dir2/copy
--- a/dir1/new
+++ b/dir2/copy
@@ -1,1 +1,2 @@
new
+copy2
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root ../.. -r 1:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 abort: ../.. not under root '$TESTTMP'
[255]
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root ../doesnotexist -r 1:tip
$ hg diff --git --root .. -r 1:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/dir1/new b/dir1/copy
copy from dir1/new
copy to dir1/copy
--- a/dir1/new
+++ b/dir1/copy
@@ -1,1 +1,2 @@
new
+copy1
diff --git a/dir1/new b/dir2/copy
copy from dir1/new
copy to dir2/copy
--- a/dir1/new
+++ b/dir2/copy
@@ -1,1 +1,2 @@
new
+copy2
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root . -r 1:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/new b/copy
copy from new
copy to copy
--- a/new
+++ b/copy
@@ -1,1 +1,2 @@
new
+copy1
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root . -r 1:tip copy
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/new b/copy
copy from new
copy to copy
--- a/new
+++ b/copy
@@ -1,1 +1,2 @@
new
+copy1
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root . -r 1:tip ../dir2
Matt Harbison
test-git-export: add globs the test runner wants on Windows...
r24501 warning: ../dir2 not inside relative root . (glob)
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --git --root . -r 1:tip '../dir2/*'
Matt Harbison
test-git-export: add globs the test runner wants on Windows...
r24501 warning: ../dir2/* not inside relative root . (glob)
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 $ cd ..
Adrian Buehlmann
tests: unify test-git-*
r12193
Rename:
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 $ hg mv dir1/copy dir1/rename1
$ echo rename1 >> dir1/rename1
$ hg mv dir2/copy dir1/rename2
$ echo rename2 >> dir1/rename2
Adrian Buehlmann
tests: unify test-git-*
r12193 $ hg ci -mrename
$ hg diff --git -r 2:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/dir1/copy b/dir1/rename1
rename from dir1/copy
rename to dir1/rename1
--- a/dir1/copy
+++ b/dir1/rename1
@@ -1,2 +1,3 @@
new
copy1
+rename1
diff --git a/dir2/copy b/dir1/rename2
rename from dir2/copy
rename to dir1/rename2
--- a/dir2/copy
+++ b/dir1/rename2
@@ -1,2 +1,3 @@
new
copy2
+rename2
Cross and same-directory renames with a relative root:
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --root dir1 --git -r 2:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/copy b/rename1
Adrian Buehlmann
tests: unify test-git-*
r12193 rename from copy
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 rename to rename1
--- a/copy
+++ b/rename1
@@ -1,2 +1,3 @@
new
copy1
+rename1
diff --git a/rename2 b/rename2
new file mode 100644
--- /dev/null
+++ b/rename2
@@ -0,0 +1,3 @@
+new
+copy2
+rename2
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --root dir2 --git -r 2:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/copy b/copy
deleted file mode 100644
--- a/copy
+++ /dev/null
@@ -1,2 +0,0 @@
-new
-copy2
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --root dir1 --git -r 2:tip -I '**/copy'
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/copy b/copy
deleted file mode 100644
--- a/copy
+++ /dev/null
@@ -1,2 +0,0 @@
-new
-copy1
Sean Farley
diff: rename --relative option to --root...
r24455 $ hg diff --root dir1 --git -r 2:tip -I '**/rename*'
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/copy b/rename1
copy from copy
copy to rename1
--- a/copy
+++ b/rename1
@@ -1,2 +1,3 @@
new
copy1
+rename1
diff --git a/rename2 b/rename2
new file mode 100644
--- /dev/null
+++ b/rename2
@@ -0,0 +1,3 @@
+new
+copy2
+rename2
Adrian Buehlmann
tests: unify test-git-*
r12193
Delete:
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 $ hg rm dir1/*
Adrian Buehlmann
tests: unify test-git-*
r12193 $ hg ci -mdelete
$ hg diff --git -r 3:tip
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/dir1/new b/dir1/new
Adrian Buehlmann
tests: unify test-git-*
r12193 deleted file mode 100644
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 --- a/dir1/new
Adrian Buehlmann
tests: unify test-git-*
r12193 +++ /dev/null
@@ -1,1 +0,0 @@
-new
Siddharth Agarwal
commands.diff: add support for diffs relative to a subdirectory...
r24432 diff --git a/dir1/rename1 b/dir1/rename1
deleted file mode 100644
--- a/dir1/rename1
+++ /dev/null
@@ -1,3 +0,0 @@
-new
-copy1
-rename1
diff --git a/dir1/rename2 b/dir1/rename2
deleted file mode 100644
--- a/dir1/rename2
+++ /dev/null
@@ -1,3 +0,0 @@
-new
-copy2
-rename2
Adrian Buehlmann
tests: unify test-git-*
r12193
$ cat > src <<EOF
> 1
> 2
> 3
> 4
> 5
> EOF
$ hg ci -Amsrc
adding src
Mads Kiilerich
tests: convert some 'hghave execbit' to #if...
r16899 #if execbit
Adrian Buehlmann
tests: unify test-git-*
r12193 chmod 644:
$ chmod +x src
$ hg ci -munexec
$ hg diff --git -r 5:tip
diff --git a/src b/src
old mode 100644
new mode 100755
Rename+mod+chmod:
$ hg mv src dst
$ chmod -x dst
$ echo a >> dst
$ hg ci -mrenamemod
$ hg diff --git -r 6:tip
diff --git a/src b/dst
old mode 100755
new mode 100644
rename from src
rename to dst
--- a/src
+++ b/dst
@@ -3,3 +3,4 @@
3
4
5
+a
Nonexistent in tip+chmod:
$ hg diff --git -r 5:6
diff --git a/src b/src
old mode 100644
new mode 100755
Mads Kiilerich
tests: convert some 'hghave execbit' to #if...
r16899 #else
Dummy changes when no exec bit, mocking the execbit commit structure
$ echo change >> src
$ hg ci -munexec
$ hg mv src dst
$ hg ci -mrenamemod
#endif
Adrian Buehlmann
tests: unify test-git-*
r12193 Binary diff:
Thomas Arendsen Hein
tests: make tests work if directory contains special characters...
r16350 $ cp "$TESTDIR/binfile.bin" .
Adrian Buehlmann
tests: unify test-git-*
r12193 $ hg add binfile.bin
$ hg diff --git > b.diff
$ cat b.diff
diff --git a/binfile.bin b/binfile.bin
new file mode 100644
Johan Bjork
patch: Fix nullid for binary git diffs (issue4054)...
r19875 index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..37ba3d1c6f17137d9c5f5776fa040caf5fe73ff9
Adrian Buehlmann
tests: unify test-git-*
r12193 GIT binary patch
literal 593
zc$@)I0<QguP)<h;3K|Lk000e1NJLTq000mG000mO0ssI2kdbIM00009a7bBm000XU
z000XU0RWnu7ytkO2XskIMF-Uh9TW;VpMjwv0005-Nkl<ZD9@FWPs=e;7{<>W$NUkd
zX$nnYLt$-$V!?uy+1V%`z&Eh=ah|duER<4|QWhju3gb^nF*8iYobxWG-qqXl=2~5M
z*IoDB)sG^CfNuoBmqLTVU^<;@nwHP!1wrWd`{(mHo6VNXWtyh{alzqmsH*yYzpvLT
zLdY<T=ks|woh-`&01!ej#(xbV1f|pI*=%;d-%F*E*X#ZH`4I%6SS+$EJDE&ct=8po
ziN#{?_j|kD%Cd|oiqds`xm@;oJ-^?NG3Gdqrs?5u*zI;{nogxsx~^|Fn^Y?Gdc6<;
zfMJ+iF1J`LMx&A2?dEwNW8ClebzPTbIh{@$hS6*`kH@1d%Lo7fA#}N1)oN7`gm$~V
z+wDx#)OFqMcE{s!JN0-xhG8ItAjVkJwEcb`3WWlJfU2r?;Pd%dmR+q@mSri5q9_W-
zaR2~ECX?B2w+zELozC0s*6Z~|QG^f{3I#<`?)Q7U-JZ|q5W;9Q8i_=pBuSzunx=U;
z9C)5jBoYw9^?EHyQl(M}1OlQcCX>lXB*ODN003Z&P17_@)3Pi=i0wb04<W?v-u}7K
zXmmQA+wDgE!qR9o8jr`%=ab_&uh(l?R=r;Tjiqon91I2-hIu?57~@*4h7h9uORK#=
fQItJW-{SoTm)8|5##k|m00000NkvXXu0mjf{mKw4
Import binary diff:
$ hg revert binfile.bin
$ rm binfile.bin
$ hg import -mfoo b.diff
applying b.diff
Thomas Arendsen Hein
tests: make tests work if directory contains special characters...
r16350 $ cmp binfile.bin "$TESTDIR/binfile.bin"
Adrian Buehlmann
tests: unify test-git-*
r12193
Rename binary file:
$ hg mv binfile.bin renamed.bin
$ hg diff --git
diff --git a/binfile.bin b/renamed.bin
rename from binfile.bin
rename to renamed.bin
Diff across many revisions:
$ hg mv dst dst2
$ hg ci -m 'mv dst dst2'
$ echo >> start
$ hg ci -m 'change start'
$ hg revert -r -2 start
$ hg mv dst2 dst3
$ hg ci -m 'mv dst2 dst3; revert start'
$ hg diff --git -r 9:11
diff --git a/dst2 b/dst3
rename from dst2
rename to dst3
Reversed:
$ hg diff --git -r 11:9
diff --git a/dst3 b/dst2
rename from dst3
rename to dst2
$ echo a >> foo
$ hg add foo
$ hg ci -m 'add foo'
$ echo b >> foo
$ hg ci -m 'change foo'
$ hg mv foo bar
$ hg ci -m 'mv foo bar'
$ echo c >> bar
$ hg ci -m 'change bar'
File created before r1 and renamed before r2:
$ hg diff --git -r -3:-1
diff --git a/foo b/bar
rename from foo
rename to bar
--- a/foo
+++ b/bar
@@ -1,2 +1,3 @@
a
b
+c
Reversed:
$ hg diff --git -r -1:-3
diff --git a/bar b/foo
rename from bar
rename to foo
--- a/bar
+++ b/foo
@@ -1,3 +1,2 @@
a
b
-c
File created in r1 and renamed before r2:
$ hg diff --git -r -4:-1
diff --git a/foo b/bar
rename from foo
rename to bar
--- a/foo
+++ b/bar
@@ -1,1 +1,3 @@
a
+b
+c
Reversed:
$ hg diff --git -r -1:-4
diff --git a/bar b/foo
rename from bar
rename to foo
--- a/bar
+++ b/foo
@@ -1,3 +1,1 @@
a
-b
-c
File created after r1 and renamed before r2:
$ hg diff --git -r -5:-1
diff --git a/bar b/bar
new file mode 100644
--- /dev/null
+++ b/bar
@@ -0,0 +1,3 @@
+a
+b
+c
Reversed:
$ hg diff --git -r -1:-5
diff --git a/bar b/bar
deleted file mode 100644
--- a/bar
+++ /dev/null
@@ -1,3 +0,0 @@
-a
-b
-c
Comparing with the working dir:
$ echo >> start
$ hg ci -m 'change start again'
$ echo > created
$ hg add created
$ hg ci -m 'add created'
$ hg mv created created2
$ hg ci -m 'mv created created2'
$ hg mv created2 created3
There's a copy in the working dir:
$ hg diff --git
diff --git a/created2 b/created3
rename from created2
rename to created3
There's another copy between the original rev and the wd:
$ hg diff --git -r -2
diff --git a/created b/created3
rename from created
rename to created3
The source of the copy was created after the original rev:
$ hg diff --git -r -3
diff --git a/created3 b/created3
new file mode 100644
--- /dev/null
+++ b/created3
@@ -0,0 +1,1 @@
+
$ hg ci -m 'mv created2 created3'
$ echo > brand-new
$ hg add brand-new
$ hg ci -m 'add brand-new'
$ hg mv brand-new brand-new2
Created in parent of wd; renamed in the wd:
$ hg diff --git
diff --git a/brand-new b/brand-new2
rename from brand-new
rename to brand-new2
Created between r1 and parent of wd; renamed in the wd:
$ hg diff --git -r -2
diff --git a/brand-new2 b/brand-new2
new file mode 100644
--- /dev/null
+++ b/brand-new2
@@ -0,0 +1,1 @@
+
$ hg ci -m 'mv brand-new brand-new2'
One file is copied to many destinations and removed:
$ hg cp brand-new2 brand-new3
$ hg mv brand-new2 brand-new3-2
$ hg ci -m 'multiple renames/copies'
$ hg diff --git -r -2 -r -1
diff --git a/brand-new2 b/brand-new3
rename from brand-new2
rename to brand-new3
diff --git a/brand-new2 b/brand-new3-2
copy from brand-new2
copy to brand-new3-2
Reversed:
$ hg diff --git -r -1 -r -2
Mads Kiilerich
copies: make the loss in _backwardcopies more stable...
r18355 diff --git a/brand-new3-2 b/brand-new2
rename from brand-new3-2
Adrian Buehlmann
tests: unify test-git-*
r12193 rename to brand-new2
Mads Kiilerich
copies: make the loss in _backwardcopies more stable...
r18355 diff --git a/brand-new3 b/brand-new3
Adrian Buehlmann
tests: unify test-git-*
r12193 deleted file mode 100644
Mads Kiilerich
copies: make the loss in _backwardcopies more stable...
r18355 --- a/brand-new3
Adrian Buehlmann
tests: unify test-git-*
r12193 +++ /dev/null
@@ -1,1 +0,0 @@
-
There should be a trailing TAB if there are spaces in the file name:
$ echo foo > 'with spaces'
$ hg add 'with spaces'
$ hg diff --git
diff --git a/with spaces b/with spaces
new file mode 100644
--- /dev/null
+++ b/with spaces
@@ -0,0 +1,1 @@
+foo
$ hg ci -m 'add filename with spaces'
Johan Bjork
patch: ensure valid git diffs if source/destination file is missing (issue4046)...
r19973 Additions should be properly marked even in the middle of a merge
$ hg up -r -2
0 files updated, 0 files merged, 1 files removed, 0 files unresolved
$ echo "New File" >> inmerge
$ hg add inmerge
$ hg ci -m "file in merge"
created new head
$ hg up 23
1 files updated, 0 files merged, 1 files removed, 0 files unresolved
$ hg merge
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
$ hg diff -g
diff --git a/inmerge b/inmerge
new file mode 100644
--- /dev/null
+++ b/inmerge
@@ -0,0 +1,1 @@
+New File