Unverified Commit 29d59e3c authored by Greg Spencer's avatar Greg Spencer Committed by GitHub

Switch Mac packaging to use .zip files. (#14894)

We can't use .tar.xz on Mac because although it can unpack them on the command line (with tar), the "Archive Utility" that runs when you double-click on them just does some crazy behavior (it
converts it to a compressed cpio archive, and when you double-click on that, it converts it back to .tar.xz, without ever unpacking it!)

So, this changes the script to use .zip for Mac, and the files are about 220MB larger than they need to be. 
parent 5dca13de
...@@ -248,7 +248,14 @@ class ArchiveCreator { ...@@ -248,7 +248,14 @@ class ArchiveCreator {
/// Used when an output filename is not given. /// Used when an output filename is not given.
String get _archiveName { String get _archiveName {
final String os = platform.operatingSystem.toLowerCase(); final String os = platform.operatingSystem.toLowerCase();
final String suffix = platform.isWindows ? 'zip' : 'tar.xz'; // We don't use .tar.xz on Mac because although it can unpack them
// on the command line (with tar), the "Archive Utility" that runs
// when you double-click on them just does some crazy behavior (it
// converts it to a compressed cpio archive, and when you double
// click on that, it converts it back to .tar.xz, without ever
// unpacking it!) So, we use .zip for Mac, and the files are about
// 220MB larger than they need to be. :-(
final String suffix = platform.isLinux ? 'tar.xz' : 'zip';
return 'flutter_${os}_$_version-$branchName.$suffix'; return 'flutter_${os}_$_version-$branchName.$suffix';
} }
...@@ -364,8 +371,9 @@ class ArchiveCreator { ...@@ -364,8 +371,9 @@ class ArchiveCreator {
/// ///
/// May only be run on Windows (since 7Zip is not available on other platforms). /// May only be run on Windows (since 7Zip is not available on other platforms).
Future<String> _createZipArchive(File output, Directory source) { Future<String> _createZipArchive(File output, Directory source) {
assert(platform.isWindows); // 7Zip is only available on Windows. List<String> commandLine;
final List<String> commandLine = <String>[ if (platform.isWindows) {
commandLine = <String>[
'7za', '7za',
'a', 'a',
'-tzip', '-tzip',
...@@ -373,6 +381,15 @@ class ArchiveCreator { ...@@ -373,6 +381,15 @@ class ArchiveCreator {
output.absolute.path, output.absolute.path,
path.basename(source.path), path.basename(source.path),
]; ];
} else {
commandLine = <String>[
'zip',
'-r',
'-9',
output.absolute.path,
path.basename(source.path),
];
}
return _processRunner.runProcess(commandLine, return _processRunner.runProcess(commandLine,
workingDirectory: new Directory(path.dirname(source.absolute.path))); workingDirectory: new Directory(path.dirname(source.absolute.path)));
} }
......
...@@ -113,10 +113,12 @@ void main() { ...@@ -113,10 +113,12 @@ void main() {
'git clean -f -X **/.packages': null, 'git clean -f -X **/.packages': null,
}); });
final String archiveName = path.join(tmpDir.absolute.path, final String archiveName = path.join(tmpDir.absolute.path,
'flutter_${platformName}_v1.2.3-dev${platform.isWindows ? '.zip' : '.tar.xz'}'); 'flutter_${platformName}_v1.2.3-dev${platform.isLinux ? '.tar.xz' : '.zip'}');
if (platform.isWindows) { if (platform.isWindows) {
calls['7za a -tzip -mx=9 $archiveName flutter'] = null; calls['7za a -tzip -mx=9 $archiveName flutter'] = null;
} else { } else if (platform.isMacOS) {
calls['zip -r -9 $archiveName flutter'] = null;
} else if (platform.isLinux) {
calls['tar cJf $archiveName flutter'] = null; calls['tar cJf $archiveName flutter'] = null;
} }
processManager.fakeResults = calls; processManager.fakeResults = calls;
...@@ -156,10 +158,12 @@ void main() { ...@@ -156,10 +158,12 @@ void main() {
'git clean -f -X **/.packages': null, 'git clean -f -X **/.packages': null,
}); });
final String archiveName = path.join(tmpDir.absolute.path, final String archiveName = path.join(tmpDir.absolute.path,
'flutter_${platformName}_v1.2.3-dev${platform.isWindows ? '.zip' : '.tar.xz'}'); 'flutter_${platformName}_v1.2.3-dev${platform.isLinux ? '.tar.xz' : '.zip'}');
if (platform.isWindows) { if (platform.isWindows) {
calls['7za a -tzip -mx=9 $archiveName flutter'] = null; calls['7za a -tzip -mx=9 $archiveName flutter'] = null;
} else { } else if (platform.isMacOS) {
calls['zip -r -9 $archiveName flutter'] = null;
} else if (platform.isLinux) {
calls['tar cJf $archiveName flutter'] = null; calls['tar cJf $archiveName flutter'] = null;
} }
processManager.fakeResults = calls; processManager.fakeResults = calls;
...@@ -211,8 +215,8 @@ void main() { ...@@ -211,8 +215,8 @@ void main() {
test('calls the right processes', () async { test('calls the right processes', () async {
final String releasesName = 'releases_$platformName.json'; final String releasesName = 'releases_$platformName.json';
final String archiveName = platform.isWindows ? 'archive.zip' : 'archive.tar.xz'; final String archiveName = platform.isLinux ? 'archive.tar.xz' : 'archive.zip';
final String archiveMime = platform.isWindows ? 'application/zip' : 'application/x-gtar'; final String archiveMime = platform.isLinux ? 'application/x-gtar' : 'application/zip';
final String archivePath = path.join(tempDir.absolute.path, archiveName); final String archivePath = path.join(tempDir.absolute.path, archiveName);
final String gsArchivePath = 'gs://flutter_infra/releases/dev/$platformName/$archiveName'; final String gsArchivePath = 'gs://flutter_infra/releases/dev/$platformName/$archiveName';
final String jsonPath = path.join(tempDir.absolute.path, releasesName); final String jsonPath = path.join(tempDir.absolute.path, releasesName);
...@@ -225,12 +229,12 @@ void main() { ...@@ -225,12 +229,12 @@ void main() {
}, },
"releases": { "releases": {
"6da8ec6bd0c4801b80d666869e4069698561c043": { "6da8ec6bd0c4801b80d666869e4069698561c043": {
"${platformName}_archive": "dev/linux/flutter_${platformName}_0.21.0-beta.tar.xz", "${platformName}_archive": "dev/linux/flutter_${platformName}_0.21.0-beta.zip",
"release_date": "2017-12-19T10:30:00,847287019-08:00", "release_date": "2017-12-19T10:30:00,847287019-08:00",
"version": "0.21.0-beta" "version": "0.21.0-beta"
}, },
"f88c60b38c3a5ef92115d24e3da4175b4890daba": { "f88c60b38c3a5ef92115d24e3da4175b4890daba": {
"${platformName}_archive": "dev/linux/flutter_${platformName}_0.22.0-dev.tar.xz", "${platformName}_archive": "dev/linux/flutter_${platformName}_0.22.0-dev.zip",
"release_date": "2018-01-19T13:30:09,728487019-08:00", "release_date": "2018-01-19T13:30:09,728487019-08:00",
"version": "0.22.0-dev" "version": "0.22.0-dev"
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment