##// END OF EJS Templates
sshpeer: enable+fix warning about sshpeers not being closed explicitly...
Valentin Gatien-Baron -
r47804:a4c19a16 default
parent child Browse files
Show More
@@ -704,6 +704,7 b' def _pull(orig, ui, repo, source=b"defau'
704 704
705 705 if scratchbookmarks:
706 706 other = hg.peer(repo, opts, source)
707 try:
707 708 fetchedbookmarks = other.listkeyspatterns(
708 709 b'bookmarks', patterns=scratchbookmarks
709 710 )
@@ -714,6 +715,8 b' def _pull(orig, ui, repo, source=b"defau'
714 715 )
715 716 scratchbookmarks[bookmark] = fetchedbookmarks[bookmark]
716 717 revs.append(fetchedbookmarks[bookmark])
718 finally:
719 other.close()
717 720 opts[b'bookmark'] = bookmarks
718 721 opts[b'rev'] = revs
719 722
@@ -848,10 +851,13 b' def _push(orig, ui, repo, dest=None, *ar'
848 851 if common.isremotebooksenabled(ui):
849 852 if bookmark and scratchpush:
850 853 other = hg.peer(repo, opts, destpath)
854 try:
851 855 fetchedbookmarks = other.listkeyspatterns(
852 856 b'bookmarks', patterns=[bookmark]
853 857 )
854 858 remotescratchbookmarks.update(fetchedbookmarks)
859 finally:
860 other.close()
855 861 _saveremotebookmarks(repo, remotescratchbookmarks, destpath)
856 862 if oldphasemove:
857 863 exchange._localphasemove = oldphasemove
@@ -595,10 +595,14 b' def trackedcmd(ui, repo, remotepath=None'
595 595 ui.status(_(b'comparing with %s\n') % util.hidepassword(url))
596 596 remote = hg.peer(repo, opts, url)
597 597
598 try:
598 599 # check narrow support before doing anything if widening needs to be
599 600 # performed. In future we should also abort if client is ellipses and
600 601 # server does not support ellipses
601 if widening and wireprototypes.NARROWCAP not in remote.capabilities():
602 if (
603 widening
604 and wireprototypes.NARROWCAP not in remote.capabilities()
605 ):
602 606 raise error.Abort(_(b"server does not support narrow clones"))
603 607
604 608 commoninc = discovery.findcommonincoming(repo, remote)
@@ -667,5 +671,7 b' def trackedcmd(ui, repo, remotepath=None'
667 671 newincludes,
668 672 newexcludes,
669 673 )
674 finally:
675 remote.close()
670 676
671 677 return 0
@@ -3820,9 +3820,12 b' def identify('
3820 3820 output = []
3821 3821 revs = []
3822 3822
3823 peer = None
3824 try:
3823 3825 if source:
3824 3826 source, branches = hg.parseurl(ui.expandpath(source))
3825 peer = hg.peer(repo or ui, opts, source) # only pass ui when no repo
3827 # only pass ui when no repo
3828 peer = hg.peer(repo or ui, opts, source)
3826 3829 repo = peer.local()
3827 3830 revs, checkout = hg.addbranchrevs(repo, peer, branches, None)
3828 3831
@@ -3946,6 +3949,9 b' def identify('
3946 3949
3947 3950 fm.plain(b"%s\n" % b' '.join(output))
3948 3951 fm.end()
3952 finally:
3953 if peer:
3954 peer.close()
3949 3955
3950 3956
3951 3957 @command(
@@ -4291,12 +4297,15 b' def incoming(ui, repo, source=b"default"'
4291 4297 ui.expandpath(source), opts.get(b'branch')
4292 4298 )
4293 4299 other = hg.peer(repo, opts, source)
4300 try:
4294 4301 if b'bookmarks' not in other.listkeys(b'namespaces'):
4295 4302 ui.warn(_(b"remote doesn't support bookmarks\n"))
4296 4303 return 0
4297 4304 ui.pager(b'incoming')
4298 4305 ui.status(_(b'comparing with %s\n') % util.hidepassword(source))
4299 4306 return bookmarks.incoming(ui, repo, other)
4307 finally:
4308 other.close()
4300 4309
4301 4310 repo._subtoppath = ui.expandpath(source)
4302 4311 try:
@@ -4327,7 +4336,8 b' def init(ui, dest=b".", **opts):'
4327 4336 Returns 0 on success.
4328 4337 """
4329 4338 opts = pycompat.byteskwargs(opts)
4330 hg.peer(ui, opts, ui.expandpath(dest), create=True)
4339 peer = hg.peer(ui, opts, ui.expandpath(dest), create=True)
4340 peer.close()
4331 4341
4332 4342
4333 4343 @command(
@@ -4963,12 +4973,15 b' def outgoing(ui, repo, dest=None, **opts'
4963 4973 if opts.get(b'bookmarks'):
4964 4974 dest = path.pushloc or path.loc
4965 4975 other = hg.peer(repo, opts, dest)
4976 try:
4966 4977 if b'bookmarks' not in other.listkeys(b'namespaces'):
4967 4978 ui.warn(_(b"remote doesn't support bookmarks\n"))
4968 4979 return 0
4969 4980 ui.status(_(b'comparing with %s\n') % util.hidepassword(dest))
4970 4981 ui.pager(b'outgoing')
4971 4982 return bookmarks.outgoing(ui, repo, other)
4983 finally:
4984 other.close()
4972 4985
4973 4986 repo._subtoppath = path.pushloc or path.loc
4974 4987 try:
@@ -5679,6 +5692,7 b' def push(ui, repo, dest=None, **opts):'
5679 5692 revs, checkout = hg.addbranchrevs(repo, repo, branches, opts.get(b'rev'))
5680 5693 other = hg.peer(repo, opts, dest)
5681 5694
5695 try:
5682 5696 if revs:
5683 5697 revs = [repo[r].node() for r in scmutil.revrange(repo, revs)]
5684 5698 if not revs:
@@ -5714,7 +5728,9 b' def push(ui, repo, dest=None, **opts):'
5714 5728 finally:
5715 5729 del repo._subtoppath
5716 5730
5717 opargs = dict(opts.get(b'opargs', {})) # copy opargs since we may mutate it
5731 opargs = dict(
5732 opts.get(b'opargs', {})
5733 ) # copy opargs since we may mutate it
5718 5734 opargs.setdefault(b'pushvars', []).extend(opts.get(b'pushvars', []))
5719 5735
5720 5736 pushop = exchange.push(
@@ -5735,7 +5751,8 b' def push(ui, repo, dest=None, **opts):'
5735 5751 result = 2
5736 5752 elif not result and pushop.bkresult:
5737 5753 result = 2
5738
5754 finally:
5755 other.close()
5739 5756 return result
5740 5757
5741 5758
@@ -471,6 +471,7 b' def debugcapabilities(ui, path, **opts):'
471 471 """lists the capabilities of a remote peer"""
472 472 opts = pycompat.byteskwargs(opts)
473 473 peer = hg.peer(ui, opts, path)
474 try:
474 475 caps = peer.capabilities()
475 476 ui.writenoi18n(b'Main capabilities:\n')
476 477 for c in sorted(caps):
@@ -482,6 +483,8 b' def debugcapabilities(ui, path, **opts):'
482 483 ui.write(b' %s\n' % key)
483 484 for v in values:
484 485 ui.write(b' %s\n' % v)
486 finally:
487 peer.close()
485 488
486 489
487 490 @command(
@@ -2615,12 +2618,17 b' def debugpeer(ui, path):'
2615 2618 with ui.configoverride(overrides):
2616 2619 peer = hg.peer(ui, {}, path)
2617 2620
2621 try:
2618 2622 local = peer.local() is not None
2619 2623 canpush = peer.canpush()
2620 2624
2621 2625 ui.write(_(b'url: %s\n') % peer.url())
2622 2626 ui.write(_(b'local: %s\n') % (_(b'yes') if local else _(b'no')))
2623 ui.write(_(b'pushable: %s\n') % (_(b'yes') if canpush else _(b'no')))
2627 ui.write(
2628 _(b'pushable: %s\n') % (_(b'yes') if canpush else _(b'no'))
2629 )
2630 finally:
2631 peer.close()
2624 2632
2625 2633
2626 2634 @command(
@@ -2723,6 +2731,7 b' def debugpushkey(ui, repopath, namespace'
2723 2731 """
2724 2732
2725 2733 target = hg.peer(ui, {}, repopath)
2734 try:
2726 2735 if keyinfo:
2727 2736 key, old, new = keyinfo
2728 2737 with target.commandexecutor() as e:
@@ -2741,8 +2750,11 b' def debugpushkey(ui, repopath, namespace'
2741 2750 else:
2742 2751 for k, v in sorted(pycompat.iteritems(target.listkeys(namespace))):
2743 2752 ui.write(
2744 b"%s\t%s\n" % (stringutil.escapestr(k), stringutil.escapestr(v))
2745 )
2753 b"%s\t%s\n"
2754 % (stringutil.escapestr(k), stringutil.escapestr(v))
2755 )
2756 finally:
2757 target.close()
2746 2758
2747 2759
2748 2760 @command(b'debugpvec', [], _(b'A B'))
@@ -4095,6 +4107,7 b' def debugwhyunstable(ui, repo, rev):'
4095 4107 def debugwireargs(ui, repopath, *vals, **opts):
4096 4108 opts = pycompat.byteskwargs(opts)
4097 4109 repo = hg.peer(ui, opts, repopath)
4110 try:
4098 4111 for opt in cmdutil.remoteopts:
4099 4112 del opts[opt[1]]
4100 4113 args = {}
@@ -4108,6 +4121,8 b' def debugwireargs(ui, repopath, *vals, *'
4108 4121 ui.write(b"%s\n" % res1)
4109 4122 if res1 != res2:
4110 4123 ui.warn(b"%s\n" % res2)
4124 finally:
4125 repo.close()
4111 4126
4112 4127
4113 4128 def _parsewirelangblocks(fh):
@@ -678,6 +678,9 b' def clone('
678 678 srcpeer = source.peer() # in case we were called with a localrepo
679 679 branches = (None, branch or [])
680 680 origsource = source = srcpeer.url()
681 srclock = destlock = cleandir = None
682 destpeer = None
683 try:
681 684 revs, checkout = addbranchrevs(srcpeer, srcpeer, branches, revs)
682 685
683 686 if dest is None:
@@ -696,9 +699,13 b' def clone('
696 699 destvfs = vfsmod.vfs(dest, expandpath=True)
697 700 if destvfs.lexists():
698 701 if not destvfs.isdir():
699 raise error.InputError(_(b"destination '%s' already exists") % dest)
702 raise error.InputError(
703 _(b"destination '%s' already exists") % dest
704 )
700 705 elif destvfs.listdir():
701 raise error.InputError(_(b"destination '%s' is not empty") % dest)
706 raise error.InputError(
707 _(b"destination '%s' is not empty") % dest
708 )
702 709
703 710 createopts = {}
704 711 narrow = False
@@ -792,7 +799,9 b' def clone('
792 799
793 800 # TODO this is a somewhat arbitrary restriction.
794 801 if narrow:
795 ui.status(_(b'(pooled storage not supported for narrow clones)\n'))
802 ui.status(
803 _(b'(pooled storage not supported for narrow clones)\n')
804 )
796 805 sharepath = None
797 806
798 807 if sharepath:
@@ -809,9 +818,8 b' def clone('
809 818 stream=stream,
810 819 )
811 820
812 srclock = destlock = cleandir = None
813 821 srcrepo = srcpeer.local()
814 try:
822
815 823 abspath = origsource
816 824 if islocal(origsource):
817 825 abspath = os.path.abspath(util.urllocalpath(origsource))
@@ -1052,6 +1060,8 b' def clone('
1052 1060 shutil.rmtree(cleandir, True)
1053 1061 if srcpeer is not None:
1054 1062 srcpeer.close()
1063 if destpeer and destpeer.local() is None:
1064 destpeer.close()
1055 1065 return srcpeer, destpeer
1056 1066
1057 1067
@@ -1253,6 +1263,8 b' def _incoming('
1253 1263 """
1254 1264 source, branches = parseurl(ui.expandpath(source), opts.get(b'branch'))
1255 1265 other = peer(repo, opts, source)
1266 cleanupfn = other.close
1267 try:
1256 1268 ui.status(_(b'comparing with %s\n') % util.hidepassword(source))
1257 1269 revs, checkout = addbranchrevs(repo, other, branches, opts.get(b'rev'))
1258 1270
@@ -1261,7 +1273,7 b' def _incoming('
1261 1273 other, chlist, cleanupfn = bundlerepo.getremotechanges(
1262 1274 ui, repo, other, revs, opts[b"bundle"], opts[b"force"]
1263 1275 )
1264 try:
1276
1265 1277 if not chlist:
1266 1278 ui.status(_(b"no changes found\n"))
1267 1279 return subreporecurse()
@@ -1320,6 +1332,7 b' def _outgoing(ui, repo, dest, opts):'
1320 1332 revs = [repo[rev].node() for rev in scmutil.revrange(repo, revs)]
1321 1333
1322 1334 other = peer(repo, opts, dest)
1335 try:
1323 1336 outgoing = discovery.findcommonoutgoing(
1324 1337 repo, other, revs, force=opts.get(b'force')
1325 1338 )
@@ -1327,6 +1340,9 b' def _outgoing(ui, repo, dest, opts):'
1327 1340 if not o:
1328 1341 scmutil.nochangesfound(repo.ui, repo, outgoing.excluded)
1329 1342 return o, other
1343 except: # re-raises
1344 other.close()
1345 raise
1330 1346
1331 1347
1332 1348 def outgoing(ui, repo, dest, opts):
@@ -1341,6 +1357,7 b' def outgoing(ui, repo, dest, opts):'
1341 1357
1342 1358 limit = logcmdutil.getlimit(opts)
1343 1359 o, other = _outgoing(ui, repo, dest, opts)
1360 try:
1344 1361 if not o:
1345 1362 cmdutil.outgoinghooks(ui, repo, other, opts, o)
1346 1363 return recurse()
@@ -1362,6 +1379,8 b' def outgoing(ui, repo, dest, opts):'
1362 1379 cmdutil.outgoinghooks(ui, repo, other, opts, o)
1363 1380 recurse()
1364 1381 return 0 # exit code is zero since we found outgoing changes
1382 finally:
1383 other.close()
1365 1384
1366 1385
1367 1386 def verify(repo, level=None):
@@ -1841,9 +1841,12 b' def outgoing(repo, subset, x):'
1841 1841 if revs:
1842 1842 revs = [repo.lookup(rev) for rev in revs]
1843 1843 other = hg.peer(repo, {}, dest)
1844 try:
1844 1845 repo.ui.pushbuffer()
1845 1846 outgoing = discovery.findcommonoutgoing(repo, other, onlyheads=revs)
1846 1847 repo.ui.popbuffer()
1848 finally:
1849 other.close()
1847 1850 cl = repo.changelog
1848 1851 o = {cl.rev(r) for r in outgoing.missing}
1849 1852 return subset & o
@@ -175,10 +175,7 b' def _cleanuppipes(ui, pipei, pipeo, pipe'
175 175 # to deadlocks due to a peer get gc'ed in a fork
176 176 # We add our own stack trace, because the stacktrace when called
177 177 # from __del__ is useless.
178 if False: # enabled in next commit
179 ui.develwarn(
180 b'missing close on SSH connection created at:\n%s' % warn
181 )
178 ui.develwarn(b'missing close on SSH connection created at:\n%s' % warn)
182 179
183 180
184 181 def _makeconnection(ui, sshcmd, args, remotecmd, path, sshenv=None):
@@ -716,13 +716,17 b' class hgsubrepo(abstractsubrepo):'
716 716 _(b'sharing subrepo %s from %s\n')
717 717 % (subrelpath(self), srcurl)
718 718 )
719 peer = getpeer()
720 try:
719 721 shared = hg.share(
720 722 self._repo._subparent.baseui,
721 getpeer(),
723 peer,
722 724 self._repo.root,
723 725 update=False,
724 726 bookmarks=False,
725 727 )
728 finally:
729 peer.close()
726 730 self._repo = shared.local()
727 731 else:
728 732 # TODO: find a common place for this and this code in the
@@ -743,14 +747,18 b' class hgsubrepo(abstractsubrepo):'
743 747 _(b'cloning subrepo %s from %s\n')
744 748 % (subrelpath(self), util.hidepassword(srcurl))
745 749 )
750 peer = getpeer()
751 try:
746 752 other, cloned = hg.clone(
747 753 self._repo._subparent.baseui,
748 754 {},
749 getpeer(),
755 peer,
750 756 self._repo.root,
751 757 update=False,
752 758 shareopts=shareopts,
753 759 )
760 finally:
761 peer.close()
754 762 self._repo = cloned.local()
755 763 self._initrepo(parentrepo, source, create=True)
756 764 self._cachestorehash(srcurl)
@@ -760,7 +768,11 b' class hgsubrepo(abstractsubrepo):'
760 768 % (subrelpath(self), util.hidepassword(srcurl))
761 769 )
762 770 cleansub = self.storeclean(srcurl)
763 exchange.pull(self._repo, getpeer())
771 peer = getpeer()
772 try:
773 exchange.pull(self._repo, peer)
774 finally:
775 peer.close()
764 776 if cleansub:
765 777 # keep the repo clean after pull
766 778 self._cachestorehash(srcurl)
@@ -845,7 +857,10 b' class hgsubrepo(abstractsubrepo):'
845 857 % (subrelpath(self), util.hidepassword(dsturl))
846 858 )
847 859 other = hg.peer(self._repo, {b'ssh': ssh}, dsturl)
860 try:
848 861 res = exchange.push(self._repo, other, force, newbranch=newbranch)
862 finally:
863 other.close()
849 864
850 865 # the repo is now clean
851 866 self._cachestorehash(dsturl)
@@ -21,7 +21,10 b' def getflogheads(ui, repo, path):'
21 21 dest = repo.ui.expandpath(b'default')
22 22 peer = hg.peer(repo, {}, dest)
23 23
24 try:
24 25 flogheads = peer.x_rfl_getflogheads(path)
26 finally:
27 peer.close()
25 28
26 29 if flogheads:
27 30 for head in flogheads:
@@ -361,6 +361,7 b' Empty [acl.allow]'
361 361 bundle2-input-bundle: 5 parts total
362 362 transaction abort!
363 363 rollback completed
364 truncating cache/rbc-revs-v1 to 8
364 365 abort: acl: user "fred" not allowed on "foo/file.txt" (changeset "ef1ea85a6374")
365 366 no rollback information available
366 367 0:6675d58eff77
@@ -808,7 +809,6 b' fred is not blocked from moving bookmark'
808 809 acl: acl.deny.bookmarks not enabled
809 810 acl: bookmark access granted: "ef1ea85a6374b77d6da9dcda9541f498f2d17df7" on bookmark "moving-bookmark"
810 811 bundle2-input-bundle: 7 parts total
811 truncating cache/rbc-revs-v1 to 8
812 812 updating the branch cache
813 813 invalid branch cache (served.hidden): tip differs
814 814 added 1 changesets with 1 changes to 1 files
@@ -900,6 +900,7 b' fred is not allowed to move bookmarks'
900 900 bundle2-input-bundle: 7 parts total
901 901 transaction abort!
902 902 rollback completed
903 truncating cache/rbc-revs-v1 to 8
903 904 abort: acl: user "fred" denied on bookmark "moving-bookmark" (changeset "ef1ea85a6374b77d6da9dcda9541f498f2d17df7")
904 905 no rollback information available
905 906 0:6675d58eff77
@@ -985,7 +986,6 b' barney is allowed everywhere'
985 986 bundle2-input-part: "phase-heads" supported
986 987 bundle2-input-part: total payload size 24
987 988 bundle2-input-bundle: 5 parts total
988 truncating cache/rbc-revs-v1 to 8
989 989 updating the branch cache
990 990 added 3 changesets with 3 changes to 3 files
991 991 bundle2-output-bundle: "HG20", 1 parts total
@@ -1073,6 +1073,7 b' wilma can change files with a .txt exten'
1073 1073 bundle2-input-bundle: 5 parts total
1074 1074 transaction abort!
1075 1075 rollback completed
1076 truncating cache/rbc-revs-v1 to 8
1076 1077 abort: acl: user "wilma" not allowed on "quux/file.py" (changeset "911600dab2ae")
1077 1078 no rollback information available
1078 1079 0:6675d58eff77
@@ -1322,7 +1323,6 b' acl.config can set only [acl.allow]/[acl'
1322 1323 bundle2-input-part: "phase-heads" supported
1323 1324 bundle2-input-part: total payload size 24
1324 1325 bundle2-input-bundle: 5 parts total
1325 truncating cache/rbc-revs-v1 to 8
1326 1326 updating the branch cache
1327 1327 added 3 changesets with 3 changes to 3 files
1328 1328 bundle2-output-bundle: "HG20", 1 parts total
@@ -1499,6 +1499,7 b' no one is allowed inside foo/Bar/'
1499 1499 bundle2-input-bundle: 5 parts total
1500 1500 transaction abort!
1501 1501 rollback completed
1502 truncating cache/rbc-revs-v1 to 8
1502 1503 abort: acl: user "fred" denied on "foo/Bar/file.txt" (changeset "f9cafe1212c8")
1503 1504 no rollback information available
1504 1505 0:6675d58eff77
@@ -1583,7 +1584,6 b' OS-level groups'
1583 1584 bundle2-input-part: "phase-heads" supported
1584 1585 bundle2-input-part: total payload size 24
1585 1586 bundle2-input-bundle: 5 parts total
1586 truncating cache/rbc-revs-v1 to 8
1587 1587 updating the branch cache
1588 1588 added 3 changesets with 3 changes to 3 files
1589 1589 bundle2-output-bundle: "HG20", 1 parts total
@@ -1671,6 +1671,7 b' OS-level groups'
1671 1671 bundle2-input-bundle: 5 parts total
1672 1672 transaction abort!
1673 1673 rollback completed
1674 truncating cache/rbc-revs-v1 to 8
1674 1675 abort: acl: user "fred" denied on "foo/Bar/file.txt" (changeset "f9cafe1212c8")
1675 1676 no rollback information available
1676 1677 0:6675d58eff77
@@ -382,6 +382,7 b' test http authentication'
382 382 devel-peer-request: 16 bytes of commands arguments in headers
383 383 devel-peer-request: finished in *.???? seconds (200) (glob)
384 384 received listkey for "phases": 15 bytes
385 (sent 9 HTTP requests and 3898 bytes; received 920 bytes in responses)
385 386 $ hg rollback -q
386 387
387 388 $ sed 's/.*] "/"/' < ../access.log
@@ -462,6 +462,7 b' lfs content, and the extension enabled.'
462 462 remote: adding manifests
463 463 remote: adding file changes
464 464 remote: added 1 changesets with 1 changes to 1 files
465 (sent 8 HTTP requests and 3526 bytes; received 961 bytes in responses) (?)
465 466 $ grep 'lfs' .hg/requires $SERVER_REQUIRES
466 467 .hg/requires:lfs
467 468 $TESTTMP/server/.hg/requires:lfs
General Comments 0
You need to be logged in to leave comments. Login now