launchpad-reviewers team mailing list archive
  
  - 
     launchpad-reviewers team launchpad-reviewers team
- 
    Mailing list archive
  
- 
    Message #20496
  
Re:  [Merge] lp:~cjwatson/launchpad/buildmaster-twisted-agent into lp:launchpad
  
Diff comments:
> === modified file 'lib/lp/buildmaster/interactor.py'
> --- lib/lp/buildmaster/interactor.py	2015-02-17 05:38:37 +0000
> +++ lib/lp/buildmaster/interactor.py	2016-05-24 14:41:49 +0000
> @@ -46,6 +54,56 @@
>      noisy = False
>  
>  
> +class FileWritingProtocol(Protocol):
> +    """A protocol that saves data to a file."""
> +
> +    def __init__(self, finished, filename):
> +        self.finished = finished
> +        self.filename = filename
> +        self.file = None
> +
> +    def dataReceived(self, data):
> +        if self.file is None:
> +            self.file = open(self.filename, "wb")
> +        try:
> +            self.file.write(data)
> +        except IOError:
> +            try:
> +                self.file.close()
> +            except IOError:
> +                pass
> +            self.file = None
> +            self.finished.errback()
errback uses the exception context by default, so no need.
> +
> +    def connectionLost(self, reason):
> +        try:
> +            self.file.close()
> +        except IOError:
> +            self.finished.errback()
> +        else:
> +            if reason.check(ResponseDone):
> +                self.finished.callback(None)
> +            else:
> +                self.finished.errback(reason)
> +
> +
> +_default_pool = None
> +
> +
> +def default_pool(reactor=None):
> +    global _default_pool
> +    if reactor is None:
> +        reactor = default_reactor
> +    if _default_pool is None:
> +        # Circular import.
> +        from lp.buildmaster.manager import SlaveScanner
> +        # Short cached connection timeout to avoid potential weirdness with
> +        # virtual builders that reboot frequently.
> +        _default_pool = HTTPConnectionPool(reactor)
> +        _default_pool.cachedConnectionTimeout = SlaveScanner.SCAN_INTERVAL
> +    return _default_pool
> +
> +
>  class BuilderSlave(object):
>      """Add in a few useful methods for the XMLRPC slave.
>  
-- 
https://code.launchpad.net/~cjwatson/launchpad/buildmaster-twisted-agent/+merge/295593
Your team Launchpad code reviewers is subscribed to branch lp:launchpad.
References