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

Reverts https://github.com/flutter/flutter/pull/163753
Relands https://github.com/flutter/flutter/pull/140783
Original PR description below
------
This makes various Flutter version information available at runtime.
It's basically the same as executing `flutter --version`. This is
especially useful for tools like Crashlytics or Sentry (see for example
https://github.com/getsentry/sentry-dart/issues/416).
Usage example:
```dart
FlutterVersion.version; // 3.16.5
FlutterVersion.channel; // stable
FlutterVersion.gitUrl; // https://github.com/flutter/flutter.git
FlutterVersion.frameworkRevision; // 78666c8dc5
FlutterVersion.engineRevision; // 3f3e560236
FlutterVersion.dartVersion; // 3.2.3
```
This approach has prior art as seen in #134179.
Fixes https://github.com/flutter/flutter/issues/61814
<!-- *If you had to change anything in the [flutter/tests] repo, include
a link to the migration guide as per the [breaking change policy].* -->
## Pre-launch Checklist
- [x] I read the [Contributor Guide] and followed the process outlined
there for submitting PRs.
- [x] I read the [Tree Hygiene] wiki page, which explains my
responsibilities.
- [x] I read and followed the [Flutter Style Guide], including [Features
we expect every widget to implement].
- [x] I signed the [CLA].
- [x] I listed at least one issue that this PR fixes in the description
above.
- [x] I updated/added relevant documentation (doc comments with `///`).
- [x] I added new tests to check the change I am making, or this PR is
[test-exempt].
- [x] All existing and new tests are passing.
If you need help, consider asking for advice on the #hackers-new channel
on [Discord].
<!-- Links -->
[Contributor Guide]:
https://github.com/flutter/flutter/wiki/Tree-hygiene#overview
[Tree Hygiene]: https://github.com/flutter/flutter/wiki/Tree-hygiene
[test-exempt]:
https://github.com/flutter/flutter/wiki/Tree-hygiene#tests
[Flutter Style Guide]:
https://github.com/flutter/flutter/wiki/Style-guide-for-Flutter-repo
[Features we expect every widget to implement]:
https://github.com/flutter/flutter/wiki/Style-guide-for-Flutter-repo#features-we-expect-every-widget-to-implement
[CLA]: https://cla.developers.google.com/
[flutter/tests]: https://github.com/flutter/tests
[breaking change policy]:
https://github.com/flutter/flutter/wiki/Tree-hygiene#handling-breaking-changes
[Discord]: https://github.com/flutter/flutter/wiki/Chat
145 lines
4.6 KiB
Dart
145 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 'package:file/memory.dart';
|
|
import 'package:flutter_tools/src/base/file_system.dart';
|
|
import 'package:flutter_tools/src/base/logger.dart';
|
|
import 'package:flutter_tools/src/base/platform.dart';
|
|
import 'package:flutter_tools/src/build_system/build_system.dart';
|
|
import 'package:flutter_tools/src/cache.dart';
|
|
import 'package:flutter_tools/src/commands/build.dart';
|
|
import 'package:unified_analytics/unified_analytics.dart';
|
|
|
|
import '../../src/common.dart';
|
|
import '../../src/context.dart';
|
|
import '../../src/fake_process_manager.dart';
|
|
import '../../src/fakes.dart';
|
|
import '../../src/test_build_system.dart';
|
|
import '../../src/test_flutter_command_runner.dart';
|
|
|
|
void main() {
|
|
late BufferLogger logger;
|
|
late MemoryFileSystem fs;
|
|
late FakeProcessManager processManager;
|
|
late Platform platform;
|
|
late Cache cache;
|
|
late FakeAnalytics fakeAnalytics;
|
|
|
|
setUpAll(() {
|
|
Cache.disableLocking();
|
|
});
|
|
|
|
setUp(() {
|
|
fs = MemoryFileSystem.test();
|
|
final Directory flutterRoot = fs.directory('flutter');
|
|
Cache.flutterRoot = flutterRoot.path;
|
|
logger = BufferLogger.test();
|
|
platform = FakePlatform(environment: const <String, String>{'PATH': ''});
|
|
processManager = FakeProcessManager.empty();
|
|
cache = Cache.test(rootOverride: flutterRoot, logger: logger, processManager: processManager);
|
|
fakeAnalytics = getInitializedFakeAnalyticsInstance(
|
|
fs: fs,
|
|
fakeFlutterVersion: FakeFlutterVersion(),
|
|
);
|
|
});
|
|
|
|
testUsingContext(
|
|
'will not build an AAR for a plugin',
|
|
() async {
|
|
fs.file('pubspec.yaml').writeAsStringSync('''
|
|
name: foo_bar
|
|
|
|
flutter:
|
|
plugin:
|
|
platforms:
|
|
some_platform:
|
|
null
|
|
''');
|
|
|
|
final BuildCommand command = BuildCommand(
|
|
androidSdk: FakeAndroidSdk(),
|
|
buildSystem: TestBuildSystem.all(BuildResult(success: true)),
|
|
fileSystem: fs,
|
|
logger: logger,
|
|
osUtils: FakeOperatingSystemUtils(),
|
|
);
|
|
|
|
expect(
|
|
createTestCommandRunner(command).run(const <String>['build', 'aar', '--no-pub']),
|
|
throwsToolExit(message: 'AARs can only be built from modules'),
|
|
);
|
|
expect(processManager, hasNoRemainingExpectations);
|
|
},
|
|
overrides: <Type, Generator>{
|
|
Cache: () => cache,
|
|
FileSystem: () => fs,
|
|
Platform: () => platform,
|
|
ProcessManager: () => processManager,
|
|
},
|
|
);
|
|
|
|
testUsingContext(
|
|
'will build an AAR for a module',
|
|
() async {
|
|
fs.file('pubspec.yaml').writeAsStringSync('''
|
|
name: foo_bar
|
|
|
|
flutter:
|
|
module:
|
|
foo: bar
|
|
''');
|
|
final Directory dotAndroidDir = fs.directory('.android')..createSync(recursive: true);
|
|
dotAndroidDir.childFile('gradlew').createSync();
|
|
|
|
processManager.addCommands(<FakeCommand>[
|
|
const FakeCommand(command: <String>['chmod', '755', 'flutter/bin/cache/artifacts']),
|
|
const FakeCommand(command: <String>['which', 'java']),
|
|
...<String>['Debug', 'Profile', 'Release'].map(
|
|
(String buildMode) => FakeCommand(
|
|
command: <Pattern>[
|
|
'/.android/gradlew',
|
|
'-I=/flutter/packages/flutter_tools/gradle/aar_init_script.gradle',
|
|
...List<RegExp>.filled(4, RegExp(r'-P[a-zA-Z-]+=.*')),
|
|
'-q',
|
|
...List<RegExp>.filled(6, RegExp(r'-P[a-zA-Z-]+=.*')),
|
|
'assembleAar$buildMode',
|
|
],
|
|
onRun: (_) => fs.directory('/build/host/outputs/repo').createSync(recursive: true),
|
|
),
|
|
),
|
|
]);
|
|
|
|
cache.getArtifactDirectory('gradle_wrapper').createSync(recursive: true);
|
|
|
|
final BuildCommand command = BuildCommand(
|
|
androidSdk: FakeAndroidSdk(),
|
|
buildSystem: TestBuildSystem.all(BuildResult(success: true)),
|
|
fileSystem: fs,
|
|
logger: logger,
|
|
osUtils: FakeOperatingSystemUtils(),
|
|
);
|
|
|
|
await createTestCommandRunner(command).run(const <String>['build', 'aar', '--no-pub']);
|
|
expect(processManager, hasNoRemainingExpectations);
|
|
expect(
|
|
fakeAnalytics.sentEvents,
|
|
contains(
|
|
Event.commandUsageValues(
|
|
workflow: 'build/aar',
|
|
commandHasTerminal: false,
|
|
buildAarProjectType: 'module',
|
|
buildAarTargetPlatform: 'android-arm,android-arm64,android-x64',
|
|
),
|
|
),
|
|
);
|
|
},
|
|
overrides: <Type, Generator>{
|
|
FileSystem: () => fs,
|
|
Platform: () => platform,
|
|
ProcessManager: () => processManager,
|
|
Analytics: () => fakeAnalytics,
|
|
},
|
|
);
|
|
}
|