##// END OF EJS Templates
dispatch: protect against malicious 'hg serve --stdio' invocations (sec)...
dispatch: protect against malicious 'hg serve --stdio' invocations (sec) Some shared-ssh installations assume that 'hg serve --stdio' is a safe command to run for minimally trusted users. Unfortunately, the messy implementation of argument parsing here meant that trying to access a repo named '--debugger' would give the user a pdb prompt, thereby sidestepping any hoped-for sandboxing. Serving repositories over HTTP(S) is unaffected. We're not currently hardening any subcommands other than 'serve'. If your service exposes other commands to users with arbitrary repository names, it is imperative that you defend against repository names of '--debugger' and anything starting with '--config'. The read-only mode of hg-ssh stopped working because it provided its hook configuration to "hg serve --stdio" via --config parameter. This is banned for security reasons now. This patch switches it to directly call ui.setconfig(). If your custom hosting infrastructure relies on passing --config to "hg serve --stdio", you'll need to find a different way to get that configuration into Mercurial, either by using ui.setconfig() as hg-ssh does in this patch, or by placing an hgrc file someplace where Mercurial will read it. mitrandir@fb.com provided some extra fixes for the dispatch code and for hg-ssh in places that I overlooked.

File last commit:

r24787:9d5c2789 default
r32050:77eaf953 4.1.3 stable
Show More
test-issue3084.t
405 lines | 9.9 KiB | text/troff | Tads3Lexer
Martin Geisler
largefiles: handle merges between normal files and largefiles (issue3084)...
r15663
$ echo "[extensions]" >> $HGRCPATH
$ echo "largefiles =" >> $HGRCPATH
Create the repository outside $HOME since largefiles write to
$HOME/.cache/largefiles.
$ hg init test
$ cd test
$ echo "root" > root
$ hg add root
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg commit -m "Root commit" --config extensions.largefiles=!
Ensure that .hg/largefiles isn't created before largefiles are added
#if unix-permissions
$ chmod 555 .hg
#endif
$ hg status
#if unix-permissions
$ chmod 755 .hg
#endif
$ test -f .hg/largefiles
[1]
Martin Geisler
largefiles: handle merges between normal files and largefiles (issue3084)...
r15663
$ echo "large" > foo
$ hg add --large foo
$ hg commit -m "Add foo as a largefile"
$ hg update -r 0
getting changed largefiles
0 largefiles updated, 1 removed
Benoit Boissinot
largefiles: fix largefiles+subrepo update (issue3752)...
r18459 0 files updated, 0 files merged, 1 files removed, 0 files unresolved
Martin Geisler
largefiles: handle merges between normal files and largefiles (issue3084)...
r15663
$ echo "normal" > foo
$ hg add foo
$ hg commit -m "Add foo as normal file"
created new head
Normal file in the working copy, keeping the normal version:
$ echo "n" | hg merge --config ui.interactive=Yes
Mads Kiilerich
largefiles: use 'remote'/'local' in merge prompts like in other merge prompts...
r19967 remote turned local normal file foo into a largefile
Mads Kiilerich
ui: show prompt choice if input is not a tty but is forced to be interactive...
r22589 use (l)argefile or keep (n)ormal file? n
Martin von Zweigbergk
largefiles: don't use 'r' action for standin that doesn't exist...
r23493 0 files updated, 0 files merged, 0 files removed, 0 files unresolved
Martin Geisler
largefiles: handle merges between normal files and largefiles (issue3084)...
r15663 (branch merge, don't forget to commit)
$ hg status
$ cat foo
normal
Normal file in the working copy, keeping the largefile version:
$ hg update -q -C
$ echo "l" | hg merge --config ui.interactive=Yes
Mads Kiilerich
largefiles: use 'remote'/'local' in merge prompts like in other merge prompts...
r19967 remote turned local normal file foo into a largefile
Mads Kiilerich
ui: show prompt choice if input is not a tty but is forced to be interactive...
r22589 use (l)argefile or keep (n)ormal file? l
getting changed largefiles
FUJIWARA Katsunori
largefiles: update largefiles even if rebase is aborted by conflict...
r22288 1 largefiles updated, 0 removed
1 files updated, 0 files merged, 1 files removed, 0 files unresolved
Martin Geisler
largefiles: handle merges between normal files and largefiles (issue3084)...
r15663 (branch merge, don't forget to commit)
$ hg status
M foo
$ hg diff --nodates
diff -r fa129ab6b5a7 .hglf/foo
--- /dev/null
+++ b/.hglf/foo
@@ -0,0 +1,1 @@
+7f7097b041ccf68cc5561e9600da4655d21c6d18
diff -r fa129ab6b5a7 foo
--- a/foo
+++ /dev/null
@@ -1,1 +0,0 @@
-normal
$ cat foo
large
Largefile in the working copy, keeping the normal version:
$ hg update -q -C -r 1
$ echo "n" | hg merge --config ui.interactive=Yes
Mads Kiilerich
largefiles: use 'remote'/'local' in merge prompts like in other merge prompts...
r19967 remote turned local largefile foo into a normal file
Mads Kiilerich
ui: show prompt choice if input is not a tty but is forced to be interactive...
r22589 keep (l)argefile or use (n)ormal file? n
getting changed largefiles
FUJIWARA Katsunori
largefiles: update largefiles even if rebase is aborted by conflict...
r22288 0 largefiles updated, 0 removed
1 files updated, 0 files merged, 1 files removed, 0 files unresolved
Martin Geisler
largefiles: handle merges between normal files and largefiles (issue3084)...
r15663 (branch merge, don't forget to commit)
$ hg status
M foo
$ hg diff --nodates
diff -r ff521236428a .hglf/foo
--- a/.hglf/foo
+++ /dev/null
@@ -1,1 +0,0 @@
-7f7097b041ccf68cc5561e9600da4655d21c6d18
diff -r ff521236428a foo
--- /dev/null
+++ b/foo
@@ -0,0 +1,1 @@
+normal
$ cat foo
normal
Largefile in the working copy, keeping the largefile version:
$ hg update -q -C -r 1
$ echo "l" | hg merge --config ui.interactive=Yes
Mads Kiilerich
largefiles: use 'remote'/'local' in merge prompts like in other merge prompts...
r19967 remote turned local largefile foo into a normal file
Mads Kiilerich
ui: show prompt choice if input is not a tty but is forced to be interactive...
r22589 keep (l)argefile or use (n)ormal file? l
Martin von Zweigbergk
largefiles: don't use 'r' action for normal file that doesn't exist...
r23492 0 files updated, 0 files merged, 0 files removed, 0 files unresolved
Martin Geisler
largefiles: handle merges between normal files and largefiles (issue3084)...
r15663 (branch merge, don't forget to commit)
$ hg status
$ cat foo
large
Mads Kiilerich
tests: add missing trailing 'cd ..'...
r16913
Mads Kiilerich
largefiles: don't prompt for normal/largefile changes when doing plain updates...
r19954 Whatever ... commit something so we can invoke merge when updating
$ hg commit -m '3: Merge'
Updating from largefile to normal - no reason to prompt
$ hg up -r 2
getting changed largefiles
0 largefiles updated, 0 removed
1 files updated, 0 files merged, 1 files removed, 0 files unresolved
$ cat foo
normal
(the update above used to leave the working dir in a very weird state - clean it
$ hg up -qr null
$ hg up -qr 2
)
Updating from normal to largefile - no reason to prompt
$ hg up -r 3
getting changed largefiles
1 largefiles updated, 0 removed
1 files updated, 0 files merged, 1 files removed, 0 files unresolved
$ cat foo
large
Mads Kiilerich
tests: add missing trailing 'cd ..'...
r16913 $ cd ..
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966
Systematic testing of merges involving largefiles:
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 Ancestor: normal Parent: normal-id Parent: large result: large
Ancestor: normal Parent: normal2 Parent: large result: ?
Ancestor: large Parent: large-id Parent: normal result: normal
Ancestor: large Parent: large2 Parent: normal result: ?
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966
All cases should try merging both ways.
Prepare test repo:
$ hg init merges
$ cd merges
Matt Harbison
largefiles: avoid unnecessary creation of .hg/largefiles when opening lfdirstate...
r21917
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 prepare cases with "normal" ancestor:
Matt Harbison
largefiles: avoid unnecessary creation of .hg/largefiles when opening lfdirstate...
r21917
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg up -qr null
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ echo normal > f
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg ci -Aqm "normal-ancestor"
$ hg tag -l "normal-ancestor"
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ touch f2
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg ci -Aqm "normal-id"
$ hg tag -l "normal-id"
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ echo normal2 > f
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg ci -m "normal2"
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ hg tag -l "normal2"
Mads Kiilerich
tests: add test-issue3084.t cases for 'changed but same' as for 'unchanged'...
r23418 $ echo normal > f
$ hg ci -Aqm "normal-same"
$ hg tag -l "normal-same"
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg up -qr "normal-ancestor"
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ hg rm f
$ echo large > f
$ hg add --large f
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg ci -qm "large"
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ hg tag -l "large"
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 prepare cases with "large" ancestor:
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg up -qr null
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ echo large > f
$ hg add --large f
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg ci -qm "large-ancestor"
$ hg tag -l "large-ancestor"
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ touch f2
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg ci -Aqm "large-id"
$ hg tag -l "large-id"
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ echo large2 > f
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg ci -m "large2"
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ hg tag -l "large2"
Mads Kiilerich
tests: add test-issue3084.t cases for 'changed but same' as for 'unchanged'...
r23418 $ echo large > f
$ hg ci -Aqm "large-same"
$ hg tag -l "large-same"
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg up -qr "large-ancestor"
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ hg rm f
$ echo normal > f
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg ci -qAm "normal"
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ hg tag -l "normal"
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg log -GT '{tags}'
@ normal tip
|
Mads Kiilerich
tests: add test-issue3084.t cases for 'changed but same' as for 'unchanged'...
r23418 | o large-same
| |
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 | o large2
| |
| o large-id
|/
o large-ancestor
o large
|
Mads Kiilerich
tests: add test-issue3084.t cases for 'changed but same' as for 'unchanged'...
r23418 | o normal-same
| |
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 | o normal2
| |
| o normal-id
|/
o normal-ancestor
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417
Ancestor: normal Parent: normal-id Parent: large result: large
$ hg up -Cqr normal-id
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ hg merge -r large
FUJIWARA Katsunori
largefiles: update largefiles even if rebase is aborted by conflict...
r22288 getting changed largefiles
1 largefiles updated, 0 removed
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 1 files updated, 0 files merged, 1 files removed, 0 files unresolved
(branch merge, don't forget to commit)
$ cat f
large
swap
$ hg up -Cqr large
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg merge -r normal-id
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
$ cat f
large
Mads Kiilerich
tests: add test-issue3084.t cases for 'changed but same' as for 'unchanged'...
r23418 Ancestor: normal Parent: normal-same Parent: large result: large
$ hg up -Cqr normal-same
$ hg merge -r large
getting changed largefiles
1 largefiles updated, 0 removed
1 files updated, 0 files merged, 1 files removed, 0 files unresolved
(branch merge, don't forget to commit)
$ cat f
large
swap
$ hg up -Cqr large
$ hg merge -r normal-same
Mads Kiilerich
merge: before cd/dc prompt, check that changed side really changed...
r23420 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
Mads Kiilerich
tests: add test-issue3084.t cases for 'changed but same' as for 'unchanged'...
r23418 (branch merge, don't forget to commit)
$ cat f
large
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 Ancestor: normal Parent: normal2 Parent: large result: ?
(annoying extra prompt ... but it do not do any serious harm)
$ hg up -Cqr normal2
$ hg merge -r large
Mads Kiilerich
largefiles: use 'remote'/'local' in merge prompts like in other merge prompts...
r19967 remote turned local normal file f into a largefile
use (l)argefile or keep (n)ormal file? l
FUJIWARA Katsunori
largefiles: update largefiles even if rebase is aborted by conflict...
r22288 getting changed largefiles
1 largefiles updated, 0 removed
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 1 files updated, 0 files merged, 1 files removed, 0 files unresolved
(branch merge, don't forget to commit)
$ cat f
large
$ hg up -Cqr normal2
Martin von Zweigbergk
merge: move cd/dc prompts after largefiles prompts...
r23541 $ echo n | hg merge -r large --config ui.interactive=Yes
Mads Kiilerich
ui: show prompt choice if input is not a tty but is forced to be interactive...
r22589 remote turned local normal file f into a largefile
use (l)argefile or keep (n)ormal file? n
Martin von Zweigbergk
largefiles: don't use 'r' action for standin that doesn't exist...
r23493 0 files updated, 0 files merged, 0 files removed, 0 files unresolved
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 (branch merge, don't forget to commit)
$ cat f
normal2
swap
$ hg up -Cqr large
$ hg merge -r normal2
Mads Kiilerich
largefiles: use 'remote'/'local' in merge prompts like in other merge prompts...
r19967 remote turned local largefile f into a normal file
keep (l)argefile or use (n)ormal file? l
Martin von Zweigbergk
largefiles: don't use 'r' action for normal file that doesn't exist...
r23492 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 (branch merge, don't forget to commit)
$ cat f
large
$ hg up -Cqr large
Martin von Zweigbergk
merge: move cd/dc prompts after largefiles prompts...
r23541 $ echo n | hg merge -r normal2 --config ui.interactive=Yes
Mads Kiilerich
ui: show prompt choice if input is not a tty but is forced to be interactive...
r22589 remote turned local largefile f into a normal file
keep (l)argefile or use (n)ormal file? n
getting changed largefiles
FUJIWARA Katsunori
largefiles: update largefiles even if rebase is aborted by conflict...
r22288 0 largefiles updated, 0 removed
2 files updated, 0 files merged, 1 files removed, 0 files unresolved
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 (branch merge, don't forget to commit)
$ cat f
normal2
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 Ancestor: large Parent: large-id Parent: normal result: normal
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg up -Cqr large-id
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 $ hg merge -r normal
FUJIWARA Katsunori
largefiles: update largefiles even if rebase is aborted by conflict...
r22288 getting changed largefiles
0 largefiles updated, 0 removed
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 1 files updated, 0 files merged, 1 files removed, 0 files unresolved
(branch merge, don't forget to commit)
$ cat f
normal
swap
$ hg up -Cqr normal
Mads Kiilerich
tests: clean-up of largefiles tests in test-issue3084.t...
r23417 $ hg merge -r large-id
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
(branch merge, don't forget to commit)
$ cat f
normal
Mads Kiilerich
tests: add test-issue3084.t cases for 'changed but same' as for 'unchanged'...
r23418 Ancestor: large Parent: large-same Parent: normal result: normal
$ hg up -Cqr large-same
$ hg merge -r normal
getting changed largefiles
Mads Kiilerich
largefiles: don't show largefile/normal prompts if one side is unchanged
r23419 0 largefiles updated, 0 removed
1 files updated, 0 files merged, 1 files removed, 0 files unresolved
Mads Kiilerich
tests: add test-issue3084.t cases for 'changed but same' as for 'unchanged'...
r23418 (branch merge, don't forget to commit)
$ cat f
Mads Kiilerich
largefiles: don't show largefile/normal prompts if one side is unchanged
r23419 normal
Mads Kiilerich
tests: add test-issue3084.t cases for 'changed but same' as for 'unchanged'...
r23418
swap
$ hg up -Cqr normal
$ hg merge -r large-same
Mads Kiilerich
merge: before cd/dc prompt, check that changed side really changed...
r23420 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
Mads Kiilerich
tests: add test-issue3084.t cases for 'changed but same' as for 'unchanged'...
r23418 (branch merge, don't forget to commit)
$ cat f
Mads Kiilerich
largefiles: don't show largefile/normal prompts if one side is unchanged
r23419 normal
Mads Kiilerich
tests: add test-issue3084.t cases for 'changed but same' as for 'unchanged'...
r23418
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 Ancestor: large Parent: large2 Parent: normal result: ?
(annoying extra prompt ... but it do not do any serious harm)
$ hg up -Cqr large2
$ hg merge -r normal
Mads Kiilerich
largefiles: use 'remote'/'local' in merge prompts like in other merge prompts...
r19967 remote turned local largefile f into a normal file
keep (l)argefile or use (n)ormal file? l
Martin von Zweigbergk
largefiles: don't use 'r' action for normal file that doesn't exist...
r23492 0 files updated, 0 files merged, 0 files removed, 0 files unresolved
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 (branch merge, don't forget to commit)
$ cat f
large2
$ hg up -Cqr large2
Martin von Zweigbergk
merge: move cd/dc prompts after largefiles prompts...
r23541 $ echo n | hg merge -r normal --config ui.interactive=Yes
remote turned local largefile f into a normal file
keep (l)argefile or use (n)ormal file? n
Mads Kiilerich
ui: show prompt choice if input is not a tty but is forced to be interactive...
r22589 getting changed largefiles
FUJIWARA Katsunori
largefiles: update largefiles even if rebase is aborted by conflict...
r22288 0 largefiles updated, 0 removed
1 files updated, 0 files merged, 1 files removed, 0 files unresolved
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 (branch merge, don't forget to commit)
$ cat f
normal
swap
$ hg up -Cqr normal
$ hg merge -r large2
Mads Kiilerich
largefiles: use 'remote'/'local' in merge prompts like in other merge prompts...
r19967 remote turned local normal file f into a largefile
use (l)argefile or keep (n)ormal file? l
FUJIWARA Katsunori
largefiles: update largefiles even if rebase is aborted by conflict...
r22288 getting changed largefiles
1 largefiles updated, 0 removed
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 2 files updated, 0 files merged, 1 files removed, 0 files unresolved
(branch merge, don't forget to commit)
$ cat f
large2
$ hg up -Cqr normal
Martin von Zweigbergk
merge: move cd/dc prompts after largefiles prompts...
r23541 $ echo n | hg merge -r large2 --config ui.interactive=Yes
remote turned local normal file f into a largefile
use (l)argefile or keep (n)ormal file? n
Mads Kiilerich
ui: show prompt choice if input is not a tty but is forced to be interactive...
r22589 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
Mads Kiilerich
largefiles: systematic testing of merges to/from largefiles...
r19966 (branch merge, don't forget to commit)
$ cat f
normal
$ cd ..