mirror of
https://github.com/facebook/sapling.git
synced 2024-10-11 17:27:53 +03:00
cf13706ccb
Summary: With 'narrow-heads', repoview filtering is bypassed. So we need another way to make 'invisible' commits disapper from 'all'. Reviewed By: sfilipco Differential Revision: D17244549 fbshipit-source-id: 6fd4d4ff5ca96f300a5d79a796fb643060662e9b
132 lines
2.1 KiB
Perl
132 lines
2.1 KiB
Perl
'narrow-heads' requires remotenames and visibility
|
|
|
|
$ enable remotenames amend
|
|
$ setconfig experimental.narrow-heads=true visibility.enabled=true mutation.record=true mutation.enabled=true mutation.date="0 0" experimental.evolution= remotenames.rename.default=remote
|
|
$ shorttraceback
|
|
|
|
Prepare the server repo
|
|
|
|
$ newrepo server
|
|
$ setconfig treemanifest.server=true
|
|
$ drawdag << 'EOS'
|
|
> B
|
|
> |
|
|
> A
|
|
> EOS
|
|
|
|
$ hg bookmark -r $B master
|
|
$ hg bookmark -r $A stable
|
|
|
|
Prepare the client repo
|
|
('--pull' during clone is required to get visibility requirement set)
|
|
|
|
$ hg clone $TESTTMP/server $TESTTMP/client -q --pull
|
|
$ cd $TESTTMP/client
|
|
|
|
Verify the commits
|
|
|
|
$ hg bookmarks --remote
|
|
remote/master 1:112478962961
|
|
remote/stable 0:426bada5c675
|
|
|
|
Revsets after the initial clone
|
|
|
|
$ hg log -Gr 'all()' -T '{desc} {remotenames} {phase}'
|
|
@ B remote/master public
|
|
|
|
|
o A remote/stable public
|
|
|
|
$ hg log -Gr 'head()' -T '{desc} {remotenames}'
|
|
@ B remote/master
|
|
|
|
|
~
|
|
|
|
Make some client-side commits based on A
|
|
|
|
$ drawdag << 'EOS'
|
|
> D
|
|
> |
|
|
> C
|
|
> |
|
|
> A
|
|
> EOS
|
|
$ hg up -r $D -q
|
|
$ hg up -r $C -q
|
|
$ hg metaedit -m C2
|
|
|
|
Revsets after the local edits
|
|
|
|
head() should include one 'D' commit, and one 'B'
|
|
|
|
$ hg log -Gr 'head()' -T '{desc}'
|
|
o D
|
|
|
|
|
~
|
|
o B
|
|
|
|
|
~
|
|
|
|
all() should not show C
|
|
Commits under ::master should be public
|
|
|
|
$ hg log -Gr 'all()' -T '{desc} {phase} {remotebookmarks}'
|
|
o D draft
|
|
|
|
|
@ C2 draft
|
|
|
|
|
| o B public remote/master
|
|
|/
|
|
o A public remote/stable
|
|
|
|
draft() should not show C
|
|
|
|
$ hg log -Gr 'draft()' -T '{desc}'
|
|
o D
|
|
|
|
|
@ C2
|
|
|
|
|
~
|
|
not public() should not show C
|
|
|
|
$ hg log -Gr 'not public()' -T '{desc}'
|
|
o D
|
|
|
|
|
@ C2
|
|
|
|
|
~
|
|
A:: should not show C
|
|
|
|
$ hg log -Gr "$A::" -T '{desc}'
|
|
o D
|
|
|
|
|
@ C2
|
|
|
|
|
| o B
|
|
|/
|
|
o A
|
|
|
|
children(A) should not show C
|
|
|
|
$ hg log -Gr "children($A)" -T '{desc}'
|
|
@ C2
|
|
|
|
|
~
|
|
o B
|
|
|
|
|
~
|
|
|
|
predecessors(C2) should include C
|
|
|
|
$ hg log -Gr "predecessors(desc('C2'))" -T '{desc}'
|
|
@ C2
|
|
|
|
|
~
|
|
x C
|
|
|
|
|
~
|
|
|
|
Using commit hash to access C should be allowed
|
|
|
|
$ hg log -r $C -T '{desc}'
|
|
C (no-eol)
|