Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(4614)

Unified Diff: build/download_sdk_extras.py

Issue 709663002: Add gclient hook to download SDK extras on bots. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix assignment to rc and check for android_tools/sdk/extras dir. Created 6 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« DEPS ('K') | « DEPS ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: build/download_sdk_extras.py
diff --git a/build/download_sdk_extras.py b/build/download_sdk_extras.py
new file mode 100755
index 0000000000000000000000000000000000000000..1f22d7b4d938d469c5bf361a1b68d127aeac5c3e
--- /dev/null
+++ b/build/download_sdk_extras.py
@@ -0,0 +1,48 @@
+#!/usr/bin/env python
+# Copyright (c) 2014 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+
+"""Script to download sdk/extras packages on the bots from google storage."""
+
+import os
+import subprocess
+import sys
+
+sys.path.insert(0, os.path.join(os.path.dirname(__file__), 'android'))
+from pylib import constants
+
+GSUTIL_PATH = os.path.join(os.path.dirname(__file__), os.pardir, os.pardir,
+ os.pardir, os.pardir, os.pardir, 'third_party', 'gsutil', 'gsutil')
+SDK_EXTRAS_BUCKET = 'gs://chrome-sdk-extras'
nyquist 2014/11/25 20:08:26 Does this already have the exact same content (exc
navabi 2014/11/25 20:40:49 Yes.
+SDK_EXTRAS_PATH = os.path.join(constants.ANDROID_SDK_ROOT, 'extras')
nyquist 2014/11/25 20:08:26 It feels like there should be a .gitignore in http
navabi 2014/11/25 20:40:49 Yes. It is in place, in that the head of the andro
nyquist 2014/11/26 03:17:29 So you also cleaned out that folder? Or are you sa
+
+
+def GetCmdOutputAndStatus(cmd_lst):
+ process = subprocess.Popen(cmd_lst, stdout=subprocess.PIPE)
+ stdout, _ = process.communicate()
+ return stdout, process.returncode
+
+def is_buildbot_checkout():
nyquist 2014/11/25 20:08:26 this is a little bit odd to me, but I don't have a
navabi 2014/11/25 20:40:49 I'll consider it. But even if we checked some othe
+ if not os.path.exists(GSUTIL_PATH) or not os.path.exists(SDK_EXTRAS_PATH):
+ return False
+ stdout, rc = GetCmdOutputAndStatus([GSUTIL_PATH, 'ls', SDK_EXTRAS_BUCKET])
+ # If successfully read bucket, then this must be a bot with permissions
+ return not rc
+
+def main(args):
+ if is_buildbot_checkout():
+ success = True
+ for arg in args[1:]:
+ package_bucket = '%s/%s' % (SDK_EXTRAS_BUCKET, arg)
+ cmd_lst = [GSUTIL_PATH, '-m', 'rsync', '-r', package_bucket,
nyquist 2014/11/25 20:08:26 would you want '-d' here to delete the files that
navabi 2014/11/25 20:40:49 No. That would remove other packages the way we cu
+ SDK_EXTRAS_PATH]
+ stdout, rc = GetCmdOutputAndStatus(cmd_lst)
+ success = (rc == 0) and success
+ if not success:
+ return 1
+ return 0
+
+
+if __name__ == '__main__':
+ sys.exit(main(sys.argv))
« DEPS ('K') | « DEPS ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698