blob: 15b0d23c0138db66272e8fab307a813ee07fd8ce [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()
Tamas Kenez180be092018-12-05 15:23:06 +0100124 # Create maven release which uses a build that exclude dependencies.
Rico Wind8fc8bfa2019-03-22 09:57:36 +0100125 create_maven_release.run(utils.MAVEN_ZIP)
126 create_maven_release.run(utils.MAVEN_ZIP_LIB, is_r8lib=True)
Mads Agera4911eb2017-11-22 13:19:36 +0100127
Tamas Kenez180be092018-12-05 15:23:06 +0100128 # Generate and copy a full build without dependencies.
Mads Agerb10c07f2017-11-27 13:25:52 +0100129 gradle.RunGradleExcludeDeps([utils.R8, utils.R8_SRC])
Tamas Kenez180be092018-12-05 15:23:06 +0100130 shutil.copyfile(utils.R8_JAR, utils.R8_FULL_EXCLUDE_DEPS_JAR)
Mads Ager0bd1ebd2017-11-22 13:40:21 +0100131
Mads Agerac794132017-11-09 11:38:45 +0100132 # Ensure all archived artifacts has been built before archiving.
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100133 # The target tasks postfixed by 'lib' depend on the actual target task so
Tamas Kenezf960e9c2018-12-03 16:13:29 +0100134 # building it invokes the original task first.
Morten Krogh-Jespersene28db462019-01-09 13:32:15 +0100135 # The '-Pno_internal' flag is important because we generate the lib based on uses in tests.
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100136 gradle.RunGradle([
137 utils.R8,
138 utils.D8,
139 utils.COMPATDX,
140 utils.COMPATPROGUARD,
141 utils.R8LIB,
Morten Krogh-Jespersencae32a72019-01-11 11:02:19 +0100142 utils.R8LIB_NO_DEPS,
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100143 utils.COMPATDXLIB,
144 utils.COMPATPROGUARDLIB,
Morten Krogh-Jespersene28db462019-01-09 13:32:15 +0100145 '-Pno_internal'
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100146 ])
Rico Windb4621c12017-08-28 12:48:53 +0200147 version = GetVersion()
Mads Agerac794132017-11-09 11:38:45 +0100148 is_master = IsMaster(version)
Rico Wind0c24ae72017-09-08 11:33:56 +0200149 if is_master:
150 # On master we use the git hash to archive with
151 print 'On master, using git hash for archiving'
152 version = GetGitHash()
153
Rico Wind1a29c4f2018-01-25 08:43:08 +0100154 destination = GetVersionDestination('gs://', version, is_master)
Søren Gjessede7dd452019-03-06 16:03:17 +0100155 if utils.cloud_storage_exists(destination) and not options.dry_run:
Rico Wind1a29c4f2018-01-25 08:43:08 +0100156 raise Exception('Target archive directory %s already exists' % destination)
Yohann Roussel73f58e12017-10-13 17:33:14 +0200157 with utils.TempDir() as temp:
158 version_file = os.path.join(temp, 'r8-version.properties')
159 with open(version_file,'w') as version_writer:
160 version_writer.write('version.sha=' + GetGitHash() + '\n')
Søren Gjessec425e6a2019-06-28 11:41:14 +0200161 if not os.environ.get('SWARMING_BOT_ID') and not options.dry_run:
162 raise Exception('Environment variable SWARMING_BOT_ID not set')
163
164 releaser = \
165 ("<local developer build>" if options.dry_run
166 else 'releaser=go/r8bot ('
167 + os.environ.get('SWARMING_BOT_ID') + ')\n')
168 version_writer.write(releaser)
Yohann Roussel73f58e12017-10-13 17:33:14 +0200169 version_writer.write('version-file.version.code=1\n')
170
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100171 for file in [
172 utils.D8_JAR,
173 utils.R8_JAR,
174 utils.R8LIB_JAR,
Tamas Kenez54b939a2018-12-07 15:55:26 +0100175 utils.R8LIB_JAR + '.map',
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100176 utils.R8_SRC_JAR,
177 utils.R8_FULL_EXCLUDE_DEPS_JAR,
178 utils.R8LIB_EXCLUDE_DEPS_JAR,
Tamas Kenez54b939a2018-12-07 15:55:26 +0100179 utils.R8LIB_EXCLUDE_DEPS_JAR + '.map',
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100180 utils.COMPATDX_JAR,
181 utils.COMPATDXLIB_JAR,
Tamas Kenez54b939a2018-12-07 15:55:26 +0100182 utils.COMPATDXLIB_JAR + '.map',
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100183 utils.COMPATPROGUARD_JAR,
184 utils.COMPATPROGUARDLIB_JAR,
Tamas Kenez54b939a2018-12-07 15:55:26 +0100185 utils.COMPATPROGUARDLIB_JAR + '.map',
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100186 utils.MAVEN_ZIP,
Rico Wind8fc8bfa2019-03-22 09:57:36 +0100187 utils.MAVEN_ZIP_LIB,
Tamas Kenez03ab76f2018-12-07 14:33:25 +0100188 utils.GENERATED_LICENSE,
189 ]:
Mads Agerac794132017-11-09 11:38:45 +0100190 file_name = os.path.basename(file)
Yohann Roussel73f58e12017-10-13 17:33:14 +0200191 tagged_jar = os.path.join(temp, file_name)
Mads Agerac794132017-11-09 11:38:45 +0100192 shutil.copyfile(file, tagged_jar)
Mads Agerb10c07f2017-11-27 13:25:52 +0100193 if file_name.endswith('.jar') and not file_name.endswith('-src.jar'):
Mads Agerafc0cda2017-11-27 13:04:27 +0100194 with zipfile.ZipFile(tagged_jar, 'a') as zip:
195 zip.write(version_file, os.path.basename(version_file))
Yohann Roussel73f58e12017-10-13 17:33:14 +0200196 destination = GetUploadDestination(version, file_name, is_master)
197 print('Uploading %s to %s' % (tagged_jar, destination))
Rico Wind63a13562018-12-10 14:31:02 +0100198 if options.dry_run:
Søren Gjessec425e6a2019-06-28 11:41:14 +0200199 if options.dry_run_output:
200 dry_run_destination = os.path.join(options.dry_run_output, file_name)
201 print('Dry run, not actually uploading. Copying to '
202 + dry_run_destination)
203 shutil.copyfile(tagged_jar, dry_run_destination)
204 else:
205 print('Dry run, not actually uploading')
Rico Wind63a13562018-12-10 14:31:02 +0100206 else:
207 utils.upload_file_to_cloud_storage(tagged_jar, destination)
208 print('File available at: %s' % GetUrl(version, file_name, is_master))
Rico Windc0b16382018-05-17 13:23:43 +0200209 if file == utils.R8_JAR:
210 # Upload R8 to a maven compatible location.
Søren Gjesse1c115b52019-08-14 12:43:57 +0200211 maven_dst = GetUploadDestination(utils.get_maven_path('r8', version),
Rico Windc0b16382018-05-17 13:23:43 +0200212 'r8-%s.jar' % version, is_master)
Rico Wind63a13562018-12-10 14:31:02 +0100213 if options.dry_run:
214 print('Dry run, not actually creating maven repo')
215 else:
216 utils.upload_file_to_cloud_storage(tagged_jar, maven_dst)
217 print('Maven repo root available at: %s' % GetMavenUrl(is_master))
Rico Windc0b16382018-05-17 13:23:43 +0200218
Rico Windb4621c12017-08-28 12:48:53 +0200219
220if __name__ == '__main__':
221 sys.exit(Main())