blob: 32c5c32992aa50fdc9c676e22f84adf871a940c2 [file] [log] [blame]
Rico Windb4621c12017-08-28 12:48:53 +02001#!/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
Mads Agerac794132017-11-09 11:38:45 +01006import create_maven_release
Mathias Ravdd6a6de2018-05-18 10:18:33 +02007import gradle
Ian Zerny3f54e222019-02-12 10:51:17 +01008import jdk
Rico Wind63a13562018-12-10 14:31:02 +01009import optparse
Rico Windb4621c12017-08-28 12:48:53 +020010import os
Rico Windcea9ce02019-03-06 14:25:52 +010011import resource
Mathias Ravdd6a6de2018-05-18 10:18:33 +020012import shutil
Rico Wind0c24ae72017-09-08 11:33:56 +020013import subprocess
Rico Windb4621c12017-08-28 12:48:53 +020014import sys
Mathias Ravdd6a6de2018-05-18 10:18:33 +020015import toolhelper
Rico Windb4621c12017-08-28 12:48:53 +020016import utils
Yohann Roussel73f58e12017-10-13 17:33:14 +020017import zipfile
Tamas Kenez180be092018-12-05 15:23:06 +010018from build_r8lib import build_r8lib
Rico Windb4621c12017-08-28 12:48:53 +020019
Rico Wind792e8c72017-08-30 09:43:46 +020020ARCHIVE_BUCKET = 'r8-releases'
Rico Windb4621c12017-08-28 12:48:53 +020021
Rico Wind63a13562018-12-10 14:31:02 +010022def ParseOptions():
23 result = optparse.OptionParser()
24 result.add_option('--dry-run', '--dry_run',
25 help='Build only, no upload.',
26 default=False, action='store_true')
Søren Gjessec425e6a2019-06-28 11:41:14 +020027 result.add_option('--dry-run-output', '--dry_run_output',
28 help='Output directory for \'build only, no upload\'.',
29 type="string", action="store")
Rico Wind63a13562018-12-10 14:31:02 +010030 return result.parse_args()
31
Mathias Ravdd6a6de2018-05-18 10:18:33 +020032def GetToolVersion(jar_path):
Morten Krogh-Jespersen0de13732019-03-01 08:56:39 +010033 # TODO(mkroghj) This would not work for r8-lib, maybe use utils.getR8Version.
Ian Zerny3f54e222019-02-12 10:51:17 +010034 output = subprocess.check_output([
35 jdk.GetJavaExecutable(), '-jar', jar_path, '--version'
36 ])
Mathias Ravdd6a6de2018-05-18 10:18:33 +020037 return output.splitlines()[0].strip()
38
Rico Windb4621c12017-08-28 12:48:53 +020039def GetVersion():
Mathias Ravdd6a6de2018-05-18 10:18:33 +020040 r8_version = GetToolVersion(utils.R8_JAR)
41 d8_version = GetToolVersion(utils.D8_JAR)
Rico Windb4621c12017-08-28 12:48:53 +020042 # The version printed is "D8 vVERSION_NUMBER" and "R8 vVERSION_NUMBER"
43 # Sanity check that versions match.
44 if d8_version.split()[1] != r8_version.split()[1]:
45 raise Exception(
46 'Version mismatch: \n%s\n%s' % (d8_version, r8_version))
47 return d8_version.split()[1]
48
Rico Wind0c24ae72017-09-08 11:33:56 +020049def GetGitBranches():
50 return subprocess.check_output(['git', 'show', '-s', '--pretty=%d', 'HEAD'])
Rico Windb4621c12017-08-28 12:48:53 +020051
Rico Wind0c24ae72017-09-08 11:33:56 +020052def GetGitHash():
53 return subprocess.check_output(['git', 'rev-parse', 'HEAD']).strip()
Rico Windb4621c12017-08-28 12:48:53 +020054
Rico Wind0c24ae72017-09-08 11:33:56 +020055def IsMaster(version):
Rico Wind2f720292017-10-06 14:32:12 +020056 branches = subprocess.check_output(['git', 'branch', '-r', '--contains',
Rico Wind0c24ae72017-09-08 11:33:56 +020057 'HEAD'])
Rico Windd450ba12019-04-24 13:18:40 +020058 # CL runs from gerrit does not have a branch, we always treat them as master
59 # commits to archive these to the hash based location
60 if len(branches) == 0:
61 return True
Rico Wind0c24ae72017-09-08 11:33:56 +020062 if not version.endswith('-dev'):
63 # Sanity check, we don't want to archive on top of release builds EVER
64 # Note that even though we branch, we never push the bots to build the same
65 # commit as master on a branch since we always change the version to
66 # not have dev (or we crash here :-)).
67 if 'origin/master' in branches:
68 raise Exception('We are seeing origin/master in a commit that '
69 'don\'t have -dev in version')
Mads Agerac794132017-11-09 11:38:45 +010070 return False
Rico Wind0c24ae72017-09-08 11:33:56 +020071 if not 'origin/master' in branches:
72 raise Exception('We are not seeing origin/master '
73 'in a commit that have -dev in version')
Mads Agerac794132017-11-09 11:38:45 +010074 return True
Rico Wind0c24ae72017-09-08 11:33:56 +020075
Rico Windc0b16382018-05-17 13:23:43 +020076def GetStorageDestination(storage_prefix,
77 version_or_path,
78 file_name,
79 is_master):
Rico Wind0c24ae72017-09-08 11:33:56 +020080 # We archive master commits under raw/master instead of directly under raw
Rico Windc0b16382018-05-17 13:23:43 +020081 version_dir = GetVersionDestination(storage_prefix,
82 version_or_path,
83 is_master)
Rico Wind1a29c4f2018-01-25 08:43:08 +010084 return '%s/%s' % (version_dir, file_name)
85
Rico Windc0b16382018-05-17 13:23:43 +020086def GetVersionDestination(storage_prefix, version_or_path, is_master):
Rico Wind0c24ae72017-09-08 11:33:56 +020087 archive_dir = 'raw/master' if is_master else 'raw'
Rico Windc0b16382018-05-17 13:23:43 +020088 return '%s%s/%s/%s' % (storage_prefix, ARCHIVE_BUCKET,
89 archive_dir, version_or_path)
Rico Wind0c24ae72017-09-08 11:33:56 +020090
Rico Windc0b16382018-05-17 13:23:43 +020091def GetUploadDestination(version_or_path, file_name, is_master):
92 return GetStorageDestination('gs://', version_or_path, file_name, is_master)
Rico Wind0c24ae72017-09-08 11:33:56 +020093
Rico Windc0b16382018-05-17 13:23:43 +020094def GetUrl(version_or_path, file_name, is_master):
Rico Windb4621c12017-08-28 12:48:53 +020095 return GetStorageDestination('http://storage.googleapis.com/',
Rico Windc0b16382018-05-17 13:23:43 +020096 version_or_path, file_name, is_master)
97
98def GetMavenUrl(is_master):
99 return GetVersionDestination('http://storage.googleapis.com/', '', is_master)
Rico Windb4621c12017-08-28 12:48:53 +0200100
Rico Wind7219bb02019-03-18 08:30:12 +0100101def SetRLimitToMax():
102 (soft, hard) = resource.getrlimit(resource.RLIMIT_NOFILE)
103 resource.setrlimit(resource.RLIMIT_NOFILE, (hard, hard))
104
Rico Windcea9ce02019-03-06 14:25:52 +0100105def PrintResourceInfo():
106 (soft, hard) = resource.getrlimit(resource.RLIMIT_NOFILE)
107 print('INFO: Open files soft limit: %s' % soft)
108 print('INFO: Open files hard limit: %s' % hard)
109
Rico Windb4621c12017-08-28 12:48:53 +0200110def Main():
Rico Wind63a13562018-12-10 14:31:02 +0100111 (options, args) = ParseOptions()
Rico Wind089ca042019-03-06 13:27:25 +0000112 if not utils.is_bot() and not options.dry_run:
Søren Gjessec425e6a2019-06-28 11:41:14 +0200113 raise Exception('You are not a bot, don\'t archive builds. '
114 + 'Use --dry-run to test locally')
Søren Gjessec425e6a2019-06-28 11:41:14 +0200115 if (options.dry_run_output and
116 (not os.path.exists(options.dry_run_output) or
117 not os.path.isdir(options.dry_run_output))):
118 raise Exception(options.dry_run_output
119 + ' does not exist or is not a directory')
Tamas Kenez180be092018-12-05 15:23:06 +0100120
Rico Wind7219bb02019-03-18 08:30:12 +0100121 if utils.is_bot():
122 SetRLimitToMax()
Rico Windcea9ce02019-03-06 14:25:52 +0100123 PrintResourceInfo()
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200124
Tamas Kenez180be092018-12-05 15:23:06 +0100125 # Create maven release which uses a build that exclude dependencies.
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200126 create_maven_release.generate_r8_maven_zip(utils.MAVEN_ZIP)
127 create_maven_release.generate_r8_maven_zip(
128 utils.MAVEN_ZIP_LIB, is_r8lib=True)
129 # Create maven release of the desuage_jdk_libs configuration.
130 create_maven_release.generate_desugar_configuration_maven_zip(
131 utils.DESUGAR_CONFIGURATION_MAVEN_ZIP)
Mads Agera4911eb2017-11-22 13:19:36 +0100132
Tamas Kenez180be092018-12-05 15:23:06 +0100133 # Generate and copy a full build without dependencies.
Mads Agerb10c07f2017-11-27 13:25:52 +0100134 gradle.RunGradleExcludeDeps([utils.R8, utils.R8_SRC])
Tamas Kenez180be092018-12-05 15:23:06 +0100135 shutil.copyfile(utils.R8_JAR, utils.R8_FULL_EXCLUDE_DEPS_JAR)
Mads Ager0bd1ebd2017-11-22 13:40:21 +0100136
Mads Agerac794132017-11-09 11:38:45 +0100137 # Ensure all archived artifacts has been built before archiving.
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100138 # The target tasks postfixed by 'lib' depend on the actual target task so
Tamas Kenezf960e9c2018-12-03 16:13:29 +0100139 # building it invokes the original task first.
Morten Krogh-Jespersene28db462019-01-09 13:32:15 +0100140 # The '-Pno_internal' flag is important because we generate the lib based on uses in tests.
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100141 gradle.RunGradle([
142 utils.R8,
143 utils.D8,
144 utils.COMPATDX,
145 utils.COMPATPROGUARD,
146 utils.R8LIB,
Morten Krogh-Jespersencae32a72019-01-11 11:02:19 +0100147 utils.R8LIB_NO_DEPS,
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100148 utils.COMPATDXLIB,
149 utils.COMPATPROGUARDLIB,
Morten Krogh-Jespersene28db462019-01-09 13:32:15 +0100150 '-Pno_internal'
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100151 ])
Rico Windb4621c12017-08-28 12:48:53 +0200152 version = GetVersion()
Mads Agerac794132017-11-09 11:38:45 +0100153 is_master = IsMaster(version)
Rico Wind0c24ae72017-09-08 11:33:56 +0200154 if is_master:
155 # On master we use the git hash to archive with
156 print 'On master, using git hash for archiving'
157 version = GetGitHash()
158
Rico Wind1a29c4f2018-01-25 08:43:08 +0100159 destination = GetVersionDestination('gs://', version, is_master)
Søren Gjessede7dd452019-03-06 16:03:17 +0100160 if utils.cloud_storage_exists(destination) and not options.dry_run:
Rico Wind1a29c4f2018-01-25 08:43:08 +0100161 raise Exception('Target archive directory %s already exists' % destination)
Yohann Roussel73f58e12017-10-13 17:33:14 +0200162 with utils.TempDir() as temp:
163 version_file = os.path.join(temp, 'r8-version.properties')
164 with open(version_file,'w') as version_writer:
165 version_writer.write('version.sha=' + GetGitHash() + '\n')
Søren Gjessec425e6a2019-06-28 11:41:14 +0200166 if not os.environ.get('SWARMING_BOT_ID') and not options.dry_run:
167 raise Exception('Environment variable SWARMING_BOT_ID not set')
168
169 releaser = \
170 ("<local developer build>" if options.dry_run
171 else 'releaser=go/r8bot ('
172 + os.environ.get('SWARMING_BOT_ID') + ')\n')
173 version_writer.write(releaser)
Yohann Roussel73f58e12017-10-13 17:33:14 +0200174 version_writer.write('version-file.version.code=1\n')
175
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100176 for file in [
177 utils.D8_JAR,
178 utils.R8_JAR,
179 utils.R8LIB_JAR,
Tamas Kenez54b939a2018-12-07 15:55:26 +0100180 utils.R8LIB_JAR + '.map',
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100181 utils.R8_SRC_JAR,
182 utils.R8_FULL_EXCLUDE_DEPS_JAR,
183 utils.R8LIB_EXCLUDE_DEPS_JAR,
Tamas Kenez54b939a2018-12-07 15:55:26 +0100184 utils.R8LIB_EXCLUDE_DEPS_JAR + '.map',
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100185 utils.COMPATDX_JAR,
186 utils.COMPATDXLIB_JAR,
Tamas Kenez54b939a2018-12-07 15:55:26 +0100187 utils.COMPATDXLIB_JAR + '.map',
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100188 utils.COMPATPROGUARD_JAR,
189 utils.COMPATPROGUARDLIB_JAR,
Tamas Kenez54b939a2018-12-07 15:55:26 +0100190 utils.COMPATPROGUARDLIB_JAR + '.map',
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100191 utils.MAVEN_ZIP,
Rico Wind8fc8bfa2019-03-22 09:57:36 +0100192 utils.MAVEN_ZIP_LIB,
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200193 utils.DESUGAR_CONFIGURATION,
194 utils.DESUGAR_CONFIGURATION_MAVEN_ZIP,
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100195 utils.GENERATED_LICENSE,
196 ]:
Mads Agerac794132017-11-09 11:38:45 +0100197 file_name = os.path.basename(file)
Yohann Roussel73f58e12017-10-13 17:33:14 +0200198 tagged_jar = os.path.join(temp, file_name)
Mads Agerac794132017-11-09 11:38:45 +0100199 shutil.copyfile(file, tagged_jar)
Mads Agerb10c07f2017-11-27 13:25:52 +0100200 if file_name.endswith('.jar') and not file_name.endswith('-src.jar'):
Mads Agerafc0cda2017-11-27 13:04:27 +0100201 with zipfile.ZipFile(tagged_jar, 'a') as zip:
202 zip.write(version_file, os.path.basename(version_file))
Yohann Roussel73f58e12017-10-13 17:33:14 +0200203 destination = GetUploadDestination(version, file_name, is_master)
204 print('Uploading %s to %s' % (tagged_jar, destination))
Rico Wind63a13562018-12-10 14:31:02 +0100205 if options.dry_run:
Søren Gjessec425e6a2019-06-28 11:41:14 +0200206 if options.dry_run_output:
207 dry_run_destination = os.path.join(options.dry_run_output, file_name)
208 print('Dry run, not actually uploading. Copying to '
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200209 + dry_run_destination)
Søren Gjessec425e6a2019-06-28 11:41:14 +0200210 shutil.copyfile(tagged_jar, dry_run_destination)
211 else:
212 print('Dry run, not actually uploading')
Rico Wind63a13562018-12-10 14:31:02 +0100213 else:
214 utils.upload_file_to_cloud_storage(tagged_jar, destination)
215 print('File available at: %s' % GetUrl(version, file_name, is_master))
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200216
217 # Upload R8 to a maven compatible location.
Rico Windc0b16382018-05-17 13:23:43 +0200218 if file == utils.R8_JAR:
Søren Gjesse1c115b52019-08-14 12:43:57 +0200219 maven_dst = GetUploadDestination(utils.get_maven_path('r8', version),
Rico Windc0b16382018-05-17 13:23:43 +0200220 'r8-%s.jar' % version, is_master)
Rico Wind63a13562018-12-10 14:31:02 +0100221 if options.dry_run:
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200222 print('Dry run, not actually creating maven repo for R8')
Rico Wind63a13562018-12-10 14:31:02 +0100223 else:
224 utils.upload_file_to_cloud_storage(tagged_jar, maven_dst)
225 print('Maven repo root available at: %s' % GetMavenUrl(is_master))
Rico Windc0b16382018-05-17 13:23:43 +0200226
Søren Gjesse6e5e5842019-09-03 08:48:30 +0200227 # Upload desugar_jdk_libs configuration to a maven compatible location.
228 if file == utils.DESUGAR_CONFIGURATION:
229 jar_name = 'desugar_jdk_libs_configuration-%s.jar' % version
230 maven_dst = GetUploadDestination(
231 utils.get_maven_path('desugar_jdk_libs_configuration', version),
232 jar_name, is_master)
233
234 with utils.TempDir() as tmp_dir:
235 desugar_jdk_libs_configuration_jar = os.path.join(tmp_dir, jar_name)
236 create_maven_release.generate_jar_with_desugar_configuration(
237 utils.DESUGAR_CONFIGURATION, desugar_jdk_libs_configuration_jar)
238
239 if options.dry_run:
240 print('Dry run, not actually creating maven repo for '
241 + 'desugar configuration.')
242 shutil.copyfile(
243 desugar_jdk_libs_configuration_jar,
244 os.path.join(options.dry_run_output, jar_name))
245 else:
246 utils.upload_file_to_cloud_storage(
247 desugar_jdk_libs_configuration_jar, maven_dst)
248 print('Maven repo root available at: %s' % GetMavenUrl(is_master))
Rico Windb4621c12017-08-28 12:48:53 +0200249
250if __name__ == '__main__':
251 sys.exit(Main())