mirror of
https://github.com/flutter/flutter.git
synced 2025-06-03 00:51:18 +00:00

To implement windows-arm64 support, it is needed to add architecture as a subdirectory (https://github.com/flutter/flutter/issues/129805). In short, when performing a flutter windows build, we have: - Before: build/windows/runner/Release/gallery.exe - After: build/windows/x64/runner/Release/gallery.exe This convention follows what flutter linux build does. Addresses: https://github.com/flutter/flutter/issues/129805 Addresses: https://github.com/flutter/flutter/issues/116196 Design doc: [flutter.dev/go/windows-arm64](https://flutter.dev/go/windows-arm64)
156 lines
4.6 KiB
Dart
156 lines
4.6 KiB
Dart
// Copyright 2014 The Flutter Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
import 'dart:io' as io;
|
|
|
|
import 'package:file/file.dart';
|
|
import 'package:file_testing/file_testing.dart';
|
|
import 'package:flutter_tools/src/base/io.dart';
|
|
|
|
import '../src/common.dart';
|
|
import 'test_utils.dart';
|
|
|
|
void main() {
|
|
late Directory tempDir;
|
|
late Directory projectRoot;
|
|
late String flutterBin;
|
|
late Directory releaseDir;
|
|
late File exeFile;
|
|
|
|
group('flutter build windows command', () {
|
|
setUpAll(() {
|
|
tempDir = createResolvedTempDirectorySync('build_windows_test.');
|
|
flutterBin = fileSystem.path.join(
|
|
getFlutterRoot(),
|
|
'bin',
|
|
'flutter',
|
|
);
|
|
ProcessResult result = processManager.runSync(<String>[flutterBin, 'config',
|
|
'--enable-windows-desktop',
|
|
]);
|
|
expect(result, const ProcessResultMatcher());
|
|
|
|
result = processManager.runSync(<String>[
|
|
flutterBin,
|
|
...getLocalEngineArguments(),
|
|
'create',
|
|
'hello',
|
|
], workingDirectory: tempDir.path);
|
|
expect(result, const ProcessResultMatcher());
|
|
|
|
projectRoot = tempDir.childDirectory('hello');
|
|
|
|
releaseDir = fileSystem.directory(fileSystem.path.join(
|
|
projectRoot.path,
|
|
'build',
|
|
'windows',
|
|
'x64',
|
|
'runner',
|
|
'Release',
|
|
));
|
|
|
|
exeFile = fileSystem.file(fileSystem.path.join(
|
|
releaseDir.path,
|
|
'hello.exe',
|
|
));
|
|
});
|
|
|
|
tearDownAll(() {
|
|
tryToDelete(tempDir);
|
|
});
|
|
|
|
testWithoutContext('flutter build windows creates exe', () {
|
|
final ProcessResult result = processManager.runSync(<String>[
|
|
flutterBin,
|
|
...getLocalEngineArguments(),
|
|
'build',
|
|
'windows',
|
|
'--no-pub',
|
|
], workingDirectory: projectRoot.path);
|
|
expect(result, const ProcessResultMatcher());
|
|
|
|
expect(releaseDir, exists);
|
|
expect(exeFile, exists);
|
|
|
|
// Default exe has build name 1.0.0 and build number 1.
|
|
final String fileVersion = _getFileVersion(exeFile);
|
|
final String productVersion = _getProductVersion(exeFile);
|
|
|
|
expect(fileVersion, equals('1.0.0.1'));
|
|
expect(productVersion, equals('1.0.0+1'));
|
|
});
|
|
|
|
testWithoutContext('flutter build windows sets build name', () {
|
|
final ProcessResult result = processManager.runSync(<String>[
|
|
flutterBin,
|
|
...getLocalEngineArguments(),
|
|
'build',
|
|
'windows',
|
|
'--no-pub',
|
|
'--build-name',
|
|
'1.2.3',
|
|
], workingDirectory: projectRoot.path);
|
|
expect(result, const ProcessResultMatcher());
|
|
|
|
final String fileVersion = _getFileVersion(exeFile);
|
|
final String productVersion = _getProductVersion(exeFile);
|
|
|
|
expect(fileVersion, equals('1.2.3.0'));
|
|
expect(productVersion, equals('1.2.3'));
|
|
});
|
|
|
|
testWithoutContext('flutter build windows sets build name and build number', () {
|
|
final ProcessResult result = processManager.runSync(<String>[
|
|
flutterBin,
|
|
...getLocalEngineArguments(),
|
|
'build',
|
|
'windows',
|
|
'--no-pub',
|
|
'--build-name',
|
|
'1.2.3',
|
|
'--build-number',
|
|
'4',
|
|
], workingDirectory: projectRoot.path);
|
|
expect(result, const ProcessResultMatcher());
|
|
|
|
final String fileVersion = _getFileVersion(exeFile);
|
|
final String productVersion = _getProductVersion(exeFile);
|
|
|
|
expect(fileVersion, equals('1.2.3.4'));
|
|
expect(productVersion, equals('1.2.3+4'));
|
|
});
|
|
}, skip: !io.Platform.isWindows); // [intended] Windows integration build.
|
|
}
|
|
|
|
String _getFileVersion(File file) {
|
|
// FileVersionInfo's FileVersion property excludes the private part,
|
|
// so this recreates the file version using the individual parts.
|
|
final ProcessResult result = Process.runSync(
|
|
'powershell.exe -command " '
|
|
'\$v = [System.Diagnostics.FileVersionInfo]::GetVersionInfo(\\"${file.path}\\"); '
|
|
r'Write-Output \"$($v.FileMajorPart).$($v.FileMinorPart).$($v.FileBuildPart).$($v.FilePrivatePart)\" '
|
|
'"',
|
|
<String>[]
|
|
);
|
|
|
|
expect(result, const ProcessResultMatcher());
|
|
|
|
// Trim trailing new line.
|
|
final String output = result.stdout as String;
|
|
return output.trim();
|
|
}
|
|
|
|
String _getProductVersion(File file) {
|
|
final ProcessResult result = Process.runSync(
|
|
'powershell.exe -command "[System.Diagnostics.FileVersionInfo]::GetVersionInfo(\\"${file.path}\\").ProductVersion"',
|
|
<String>[]
|
|
);
|
|
|
|
expect(result, const ProcessResultMatcher());
|
|
|
|
// Trim trailing new line.
|
|
final String output = result.stdout as String;
|
|
return output.trim();
|
|
}
|