blob: 998c73754f410df2b5738e8497238343c92aefb5 [file] [log] [blame]
David James0f5252f2013-04-19 08:03:14 -07001# Copyright (c) 2013 The Chromium OS Authors. All rights reserved.
2# Use of this source code is governed by a BSD-style license that can be
3# found in the LICENSE file.
4
5"""Download a binpkg from Google Storage.
6
7This is needed for two reasons:
8 1) In the case where a binpkg is left over in the packages dir,
9 portage doesn't handle retries well and reports an error.
10 2) gsutil retries when a download is interrupted, but it doesn't
11 handle the case where we are unable to resume a transfer and the
12 transfer needs to be restarted from scratch. Ensuring that the
13 file is deleted between each retry helps handle that eventuality.
14"""
15
16import shutil
17
18from chromite.lib import commandline
19from chromite.lib import cros_build_lib
20from chromite.lib import gs
21from chromite.lib import osutils
David Jamesc93e6a4d2014-01-13 11:37:36 -080022from chromite.lib import retry_util
David James0f5252f2013-04-19 08:03:14 -070023
24
25def GetParser():
26 """Creates the argparse parser."""
27 parser = commandline.ArgumentParser(description=__doc__)
28 parser.add_argument('uri', help='Google Storage URI to download')
29 parser.add_argument('filename', help='Location to store the file.')
30 return parser
31
32def Copy(ctx, uri, filename):
33 """Run the copy using a temp file."""
34 temp_path = '%s.tmp' % filename
35 osutils.SafeUnlink(temp_path)
36 try:
David Jamesc788ad02014-04-09 13:50:14 -070037 ctx.Copy(uri, temp_path, parallel=False, log_output=True)
David James0f5252f2013-04-19 08:03:14 -070038 shutil.move(temp_path, filename)
39 finally:
40 osutils.SafeUnlink(temp_path)
41
Mike Frysinger9ad5fab2013-05-30 13:37:26 -040042def main(argv):
David James0f5252f2013-04-19 08:03:14 -070043 parser = GetParser()
Mike Frysinger9ad5fab2013-05-30 13:37:26 -040044 options = parser.parse_args(argv)
David James0f5252f2013-04-19 08:03:14 -070045 ctx = gs.GSContext(retries=0)
46 try:
David Jamesc93e6a4d2014-01-13 11:37:36 -080047 retry_util.RetryCommand(Copy, ctx.DEFAULT_RETRIES, ctx, options.uri,
48 options.filename, sleep=ctx.DEFAULT_SLEEP_TIME)
David James0f5252f2013-04-19 08:03:14 -070049 except (gs.GSContextException, cros_build_lib.RunCommandError) as ex:
50 # Hide the stack trace using Die.
51 cros_build_lib.Die('%s', ex)