sapling/eden/scm/tests/test-bundle2-multiple-changegroups.t
Michael Bolin ba00990cdc rename update to goto in hints/messages/etc.
Summary:
Created this diff by running:

```
find eden/scm/edenscm -name \*.py | xargs sed -i -e 's#update --clean#goto --clean#g'
find eden/scm/tests -name \*.t | xargs sed -i -e 's#update --clean#goto --clean#g'
find eden/scm/tests -name \*.t | xargs sed -i -e 's#update --continue#goto --continue#g'
find eden/scm/edenscm -name \*.py | xargs sed -i -e 's#update --continue#goto --continue#g'
find eden/scm/edenscm -name \*.py | xargs sed -i -e 's#prog@ update#prog@ goto#g'
find eden/scm/tests -name \*.t | xargs sed -i -e 's# hg update # hg goto #g'
find eden/scm/tests -name \*.t | xargs sed -i -e 's#hg update -C#hg goto -C#g'
find eden/scm/tests -name \*.t | xargs sed -i -e 's# hg update$# hg goto#g'
find eden/scm/tests -name \*.t | xargs sed -i -e 's# update HASH# goto HASH#g'
find eden/scm/tests -name \*.t | xargs sed -i -e 's#hg update 1#hg goto 1#g'
find eden/scm/tests -name \*.t | xargs sed -i -e "s#'hg update'#'hg goto'#g"
find eden/scm/edenscm -name \*.py | xargs sed -i -e 's#:prog:`update`#:prog:`goto`#g'
find eden/scm/edenscm -name \*.py | xargs sed -i -e 's#:prog:`update .::`#:prog:`goto .::`#g'
sed -i -e 's#commit or update#commit or goto#' eden/integration/hg/update_test.py
arc f
```

Though then I had to manually update `eden/integration/hg/update_test.py`
to use `assertRegex()` instead of `assertEqual()`, but as noted,
that is a temporary issue due to how we run that
test for EdenFS for Windows internally.

Fixes https://github.com/facebook/sapling/issues/149
Fixes https://github.com/facebook/sapling/issues/293

Reviewed By: zzl0, yancouto

Differential Revision: D41859668

fbshipit-source-id: 3bdf4e342fc1a751335960a3216651a5ce35225f
2022-12-09 13:16:27 -08:00

216 lines
5.7 KiB
Perl

#chg-compatible
#debugruntest-compatible
#inprocess-hg-incompatible
$ configure modernclient
Create an extension to test bundle2 with multiple changegroups
$ cat > bundle2.py <<EOF
> """
> """
> from edenscm import changegroup, discovery, exchange
>
> def _getbundlechangegrouppart(bundler, repo, source, bundlecaps=None,
> b2caps=None, heads=None, common=None,
> **kwargs):
> # Create two changegroups given the common changesets and heads for the
> # changegroup part we are being requested. Use the parent of each head
> # in 'heads' as intermediate heads for the first changegroup.
> intermediates = [repo[r].p1().node() for r in heads]
> outgoing = discovery.outgoing(repo, common, intermediates)
> cg = changegroup.makechangegroup(repo, outgoing, '02',
> source, bundlecaps=bundlecaps)
> bundler.newpart('output', data=b'changegroup1')
> part = bundler.newpart('changegroup', data=cg.getchunks())
> part.addparam('version', '02')
> outgoing = discovery.outgoing(repo, common + intermediates, heads)
> cg = changegroup.makechangegroup(repo, outgoing, '02',
> source, bundlecaps=bundlecaps)
> bundler.newpart('output', data=b'changegroup2')
> part = bundler.newpart('changegroup', data=cg.getchunks())
> part.addparam('version', '02')
>
> def _pull(repo, *args, **kwargs):
> pullop = _orig_pull(repo, *args, **kwargs)
> repo.ui.write('pullop.cgresult is %d\n' % pullop.cgresult)
> return pullop
>
> _orig_pull = exchange.pull
> exchange.pull = _pull
> exchange.getbundle2partsmapping['changegroup'] = _getbundlechangegrouppart
> EOF
$ cat >> $HGRCPATH << EOF
> [ui]
> logtemplate={node|short} {phase} {author} {bookmarks} {desc|firstline}
> EOF
Start with a simple repository with a single commit
$ newclientrepo repo
$ cat >> .hg/hgrc << EOF
> [extensions]
> bundle2=$TESTTMP/bundle2.py
> EOF
$ echo A > A
$ hg commit -A -m A -q
$ hg push -q -r . --to head1 --create
$ cd ..
Clone
$ newclientrepo clone test:repo_server head1
Add two linear commits
$ cd ../repo
$ echo B > B
$ hg commit -A -m B -q
$ echo C > C
$ hg commit -A -m C -q
$ hg push -q -r . --to head1
$ cd ../clone
$ cat >> .hg/hgrc <<EOF
> [hooks]
> pretxnchangegroup = sh -c "printenv.py pretxnchangegroup"
> changegroup = sh -c "printenv.py changegroup"
> EOF
Pull the new commits in the clone
$ hg pull
pulling from test:repo_server
searching for changes
$ hg goto
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
$ hg log -G
@ f838bfaca5c7 public test C
o 27547f69f254 public test B
o 4a2df7238c3b public test A
Add more changesets with multiple heads to the original repository
$ cd ../repo
$ echo D > D
$ hg commit -A -m D -q
$ hg push -q -r . --to head1
$ hg up -r 'desc(B)'
0 files updated, 0 files merged, 2 files removed, 0 files unresolved
$ echo E > E
$ hg commit -A -m E -q
$ echo F > F
$ hg commit -A -m F -q
$ hg push -q -r . --to head2 --create
$ hg up -r 'desc(B)'
0 files updated, 0 files merged, 2 files removed, 0 files unresolved
$ echo G > G
$ hg commit -A -m G -q
$ hg push -q -r . --to head3 --create
$ hg up -r 'desc(D)'
2 files updated, 0 files merged, 1 files removed, 0 files unresolved
$ echo H > H
$ hg commit -A -m H -q
$ hg push -q -r . --to head4 --create
$ hg log -G
@ 5cd59d311f65 draft test H
o 1d14c3ce6ac0 draft test G
o 7f219660301f draft test F
o 8a5212ebc852 draft test E
o b3325c91a4d9 draft test D
o f838bfaca5c7 draft test C
o 27547f69f254 draft test B
o 4a2df7238c3b draft test A
New heads are reported during transfer and properly accounted for in
pullop.cgresult
$ cd ../clone
$ hg pull -B head1 -B head2 -B head3 -B head4
pulling from test:repo_server
searching for changes
$ hg log -G
o 5cd59d311f65 public test H
o b3325c91a4d9 public test D
o 1d14c3ce6ac0 public test G
o 7f219660301f public test F
o 8a5212ebc852 public test E
@ f838bfaca5c7 public test C
o 27547f69f254 public test B
o 4a2df7238c3b public test A
Removing a head from the original repository by merging it
$ cd ../repo
$ hg merge -r 'desc(G)' -q
$ hg commit -m Merge
$ echo I > I
$ hg commit -A -m H -q
$ hg push -q -r . --to head4
$ hg log -G
@ 9d18e5bd9ab0 draft test H
o 71bd7b46de72 draft test Merge
o 5cd59d311f65 draft test H
o 1d14c3ce6ac0 draft test G
o 7f219660301f draft test F
o 8a5212ebc852 draft test E
o b3325c91a4d9 draft test D
o f838bfaca5c7 draft test C
o 27547f69f254 draft test B
o 4a2df7238c3b draft test A
Removed heads are reported during transfer and properly accounted for in
pullop.cgresult
$ cd ../clone
$ hg pull -B head4
pulling from test:repo_server
searching for changes
$ hg log -G
o 9d18e5bd9ab0 public test H
o 71bd7b46de72 public test Merge
o 5cd59d311f65 public test H
o b3325c91a4d9 public test D
o 1d14c3ce6ac0 public test G
o 7f219660301f public test F
o 8a5212ebc852 public test E
@ f838bfaca5c7 public test C
o 27547f69f254 public test B
o 4a2df7238c3b public test A