Rico Wind | b4621c1 | 2017-08-28 12:48:53 +0200 | [diff] [blame] | 1 | #!/usr/bin/env python |
| 2 | # Copyright (c) 2017, the R8 project authors. Please see the AUTHORS file |
| 3 | # for details. All rights reserved. Use of this source code is governed by a |
| 4 | # BSD-style license that can be found in the LICENSE file. |
| 5 | |
Søren Gjesse | dc9d8a2 | 2017-10-12 12:40:59 +0200 | [diff] [blame] | 6 | import gradle |
Mads Ager | ac79413 | 2017-11-09 11:38:45 +0100 | [diff] [blame] | 7 | import create_maven_release |
Rico Wind | b4621c1 | 2017-08-28 12:48:53 +0200 | [diff] [blame] | 8 | import d8 |
| 9 | import os |
| 10 | import r8 |
Rico Wind | 0c24ae7 | 2017-09-08 11:33:56 +0200 | [diff] [blame] | 11 | import subprocess |
Rico Wind | b4621c1 | 2017-08-28 12:48:53 +0200 | [diff] [blame] | 12 | import sys |
| 13 | import utils |
Yohann Roussel | 73f58e1 | 2017-10-13 17:33:14 +0200 | [diff] [blame] | 14 | import shutil |
| 15 | import zipfile |
Rico Wind | b4621c1 | 2017-08-28 12:48:53 +0200 | [diff] [blame] | 16 | |
Rico Wind | 792e8c7 | 2017-08-30 09:43:46 +0200 | [diff] [blame] | 17 | ARCHIVE_BUCKET = 'r8-releases' |
Rico Wind | b4621c1 | 2017-08-28 12:48:53 +0200 | [diff] [blame] | 18 | |
| 19 | def GetVersion(): |
Yohann Roussel | 73f58e1 | 2017-10-13 17:33:14 +0200 | [diff] [blame] | 20 | r8_version = r8.run(['--version'], build = False).splitlines()[0].strip() |
| 21 | d8_version = d8.run(['--version'], build = False).splitlines()[0].strip() |
Rico Wind | b4621c1 | 2017-08-28 12:48:53 +0200 | [diff] [blame] | 22 | # The version printed is "D8 vVERSION_NUMBER" and "R8 vVERSION_NUMBER" |
| 23 | # Sanity check that versions match. |
| 24 | if d8_version.split()[1] != r8_version.split()[1]: |
| 25 | raise Exception( |
| 26 | 'Version mismatch: \n%s\n%s' % (d8_version, r8_version)) |
| 27 | return d8_version.split()[1] |
| 28 | |
Rico Wind | 0c24ae7 | 2017-09-08 11:33:56 +0200 | [diff] [blame] | 29 | def GetGitBranches(): |
| 30 | return subprocess.check_output(['git', 'show', '-s', '--pretty=%d', 'HEAD']) |
Rico Wind | b4621c1 | 2017-08-28 12:48:53 +0200 | [diff] [blame] | 31 | |
Rico Wind | 0c24ae7 | 2017-09-08 11:33:56 +0200 | [diff] [blame] | 32 | def GetGitHash(): |
| 33 | return subprocess.check_output(['git', 'rev-parse', 'HEAD']).strip() |
Rico Wind | b4621c1 | 2017-08-28 12:48:53 +0200 | [diff] [blame] | 34 | |
Rico Wind | 0c24ae7 | 2017-09-08 11:33:56 +0200 | [diff] [blame] | 35 | def IsMaster(version): |
Rico Wind | 2f72029 | 2017-10-06 14:32:12 +0200 | [diff] [blame] | 36 | branches = subprocess.check_output(['git', 'branch', '-r', '--contains', |
Rico Wind | 0c24ae7 | 2017-09-08 11:33:56 +0200 | [diff] [blame] | 37 | 'HEAD']) |
| 38 | if not version.endswith('-dev'): |
| 39 | # Sanity check, we don't want to archive on top of release builds EVER |
| 40 | # Note that even though we branch, we never push the bots to build the same |
| 41 | # commit as master on a branch since we always change the version to |
| 42 | # not have dev (or we crash here :-)). |
| 43 | if 'origin/master' in branches: |
| 44 | raise Exception('We are seeing origin/master in a commit that ' |
| 45 | 'don\'t have -dev in version') |
Mads Ager | ac79413 | 2017-11-09 11:38:45 +0100 | [diff] [blame] | 46 | return False |
Rico Wind | 0c24ae7 | 2017-09-08 11:33:56 +0200 | [diff] [blame] | 47 | if not 'origin/master' in branches: |
| 48 | raise Exception('We are not seeing origin/master ' |
| 49 | 'in a commit that have -dev in version') |
Mads Ager | ac79413 | 2017-11-09 11:38:45 +0100 | [diff] [blame] | 50 | return True |
Rico Wind | 0c24ae7 | 2017-09-08 11:33:56 +0200 | [diff] [blame] | 51 | |
| 52 | def GetStorageDestination(storage_prefix, version, file_name, is_master): |
| 53 | # We archive master commits under raw/master instead of directly under raw |
| 54 | archive_dir = 'raw/master' if is_master else 'raw' |
| 55 | return '%s%s/%s/%s/%s' % (storage_prefix, ARCHIVE_BUCKET, archive_dir, |
| 56 | version, file_name) |
| 57 | |
| 58 | def GetUploadDestination(version, file_name, is_master): |
| 59 | return GetStorageDestination('gs://', version, file_name, is_master) |
| 60 | |
| 61 | def GetUrl(version, file_name, is_master): |
Rico Wind | b4621c1 | 2017-08-28 12:48:53 +0200 | [diff] [blame] | 62 | return GetStorageDestination('http://storage.googleapis.com/', |
Rico Wind | 0c24ae7 | 2017-09-08 11:33:56 +0200 | [diff] [blame] | 63 | version, file_name, is_master) |
Rico Wind | b4621c1 | 2017-08-28 12:48:53 +0200 | [diff] [blame] | 64 | |
| 65 | def Main(): |
| 66 | if not 'BUILDBOT_BUILDERNAME' in os.environ: |
| 67 | raise Exception('You are not a bot, don\'t archive builds') |
Mads Ager | 0bd1ebd | 2017-11-22 13:40:21 +0100 | [diff] [blame] | 68 | # Create maven release first which uses a build that exclude dependencies. |
Mads Ager | a4911eb | 2017-11-22 13:19:36 +0100 | [diff] [blame] | 69 | create_maven_release.main(["--out", utils.LIBS]) |
| 70 | |
Mads Ager | 0bd1ebd | 2017-11-22 13:40:21 +0100 | [diff] [blame] | 71 | # Generate and copy the build that exclude dependencies. |
| 72 | gradle.RunGradleExcludeDeps([utils.R8]) |
| 73 | shutil.copyfile(utils.R8_JAR, utils.R8_EXCLUDE_DEPS_JAR) |
| 74 | |
Mads Ager | ac79413 | 2017-11-09 11:38:45 +0100 | [diff] [blame] | 75 | # Ensure all archived artifacts has been built before archiving. |
| 76 | gradle.RunGradle([utils.D8, utils.R8, utils.COMPATDX, utils.COMPATPROGUARD]) |
Rico Wind | b4621c1 | 2017-08-28 12:48:53 +0200 | [diff] [blame] | 77 | version = GetVersion() |
Mads Ager | ac79413 | 2017-11-09 11:38:45 +0100 | [diff] [blame] | 78 | is_master = IsMaster(version) |
Rico Wind | 0c24ae7 | 2017-09-08 11:33:56 +0200 | [diff] [blame] | 79 | if is_master: |
| 80 | # On master we use the git hash to archive with |
| 81 | print 'On master, using git hash for archiving' |
| 82 | version = GetGitHash() |
| 83 | |
Yohann Roussel | 73f58e1 | 2017-10-13 17:33:14 +0200 | [diff] [blame] | 84 | with utils.TempDir() as temp: |
| 85 | version_file = os.path.join(temp, 'r8-version.properties') |
| 86 | with open(version_file,'w') as version_writer: |
| 87 | version_writer.write('version.sha=' + GetGitHash() + '\n') |
Mads Ager | ac79413 | 2017-11-09 11:38:45 +0100 | [diff] [blame] | 88 | version_writer.write( |
| 89 | 'releaser=go/r8bot (' + os.environ.get('BUILDBOT_SLAVENAME') + ')\n') |
Yohann Roussel | 73f58e1 | 2017-10-13 17:33:14 +0200 | [diff] [blame] | 90 | version_writer.write('version-file.version.code=1\n') |
| 91 | |
Mads Ager | ac79413 | 2017-11-09 11:38:45 +0100 | [diff] [blame] | 92 | for file in [utils.D8_JAR, |
| 93 | utils.R8_JAR, |
Mads Ager | 0bd1ebd | 2017-11-22 13:40:21 +0100 | [diff] [blame] | 94 | utils.R8_EXCLUDE_DEPS_JAR, |
Mads Ager | ac79413 | 2017-11-09 11:38:45 +0100 | [diff] [blame] | 95 | utils.COMPATDX_JAR, |
| 96 | utils.COMPATPROGUARD_JAR, |
Mads Ager | 12a56bc | 2017-11-27 11:51:25 +0100 | [diff] [blame] | 97 | utils.MAVEN_ZIP, |
| 98 | utils.GENERATED_LICENSE]: |
Mads Ager | ac79413 | 2017-11-09 11:38:45 +0100 | [diff] [blame] | 99 | file_name = os.path.basename(file) |
Yohann Roussel | 73f58e1 | 2017-10-13 17:33:14 +0200 | [diff] [blame] | 100 | tagged_jar = os.path.join(temp, file_name) |
Mads Ager | ac79413 | 2017-11-09 11:38:45 +0100 | [diff] [blame] | 101 | shutil.copyfile(file, tagged_jar) |
Mads Ager | d25bfde | 2017-11-27 13:09:55 +0100 | [diff] [blame^] | 102 | if file_name.endswith('.jar'): |
Mads Ager | afc0cda | 2017-11-27 13:04:27 +0100 | [diff] [blame] | 103 | with zipfile.ZipFile(tagged_jar, 'a') as zip: |
| 104 | zip.write(version_file, os.path.basename(version_file)) |
Yohann Roussel | 73f58e1 | 2017-10-13 17:33:14 +0200 | [diff] [blame] | 105 | destination = GetUploadDestination(version, file_name, is_master) |
| 106 | print('Uploading %s to %s' % (tagged_jar, destination)) |
| 107 | utils.upload_file_to_cloud_storage(tagged_jar, destination) |
| 108 | print('File available at: %s' % GetUrl(version, file_name, is_master)) |
Rico Wind | b4621c1 | 2017-08-28 12:48:53 +0200 | [diff] [blame] | 109 | |
| 110 | if __name__ == '__main__': |
| 111 | sys.exit(Main()) |