mirror of
https://github.com/flutter/packages.git
synced 2025-06-03 17:48:10 +08:00
[flutter_plugin_tools] Run pub get for custom-test (#5322)
When running a Dart test script for `custom-test`, `pub get` needs to be run first in order for it to work in a clean environment such as CI. This will unblock enabling Pigeon's Dart tests in flutter/packages.
This commit is contained in:
@ -1,10 +1,11 @@
|
||||
## NEXT
|
||||
## 0.8.2+1
|
||||
|
||||
- Adds a new `readme-check` command.
|
||||
- Updates `publish-plugin` command documentation.
|
||||
- Fixes `all-plugins-app` to preserve the original application's Dart SDK
|
||||
version to avoid changing language feature opt-ins that the template may
|
||||
rely on.
|
||||
- Fixes `custom-test` to run `pub get` before running Dart test scripts.
|
||||
|
||||
## 0.8.2
|
||||
|
||||
|
@ -43,10 +43,19 @@ class CustomTestCommand extends PackageLoopingCommand {
|
||||
|
||||
// Run the custom Dart script if presest.
|
||||
if (script.existsSync()) {
|
||||
final int exitCode = await processRunner.runAndStream(
|
||||
// Ensure that dependencies are available.
|
||||
final int pubGetExitCode = await processRunner.runAndStream(
|
||||
'dart', <String>['pub', 'get'],
|
||||
workingDir: package.directory);
|
||||
if (pubGetExitCode != 0) {
|
||||
return PackageResult.fail(
|
||||
<String>['Unable to get script dependencies']);
|
||||
}
|
||||
|
||||
final int testExitCode = await processRunner.runAndStream(
|
||||
'dart', <String>['run', 'tool/$_scriptName'],
|
||||
workingDir: package.directory);
|
||||
if (exitCode != 0) {
|
||||
if (testExitCode != 0) {
|
||||
return PackageResult.fail();
|
||||
}
|
||||
ranTests = true;
|
||||
|
@ -1,7 +1,7 @@
|
||||
name: flutter_plugin_tools
|
||||
description: Productivity utils for flutter/plugins and flutter/packages
|
||||
repository: https://github.com/flutter/plugins/tree/main/script/tool
|
||||
version: 0.8.2
|
||||
version: 0.8.2+1
|
||||
|
||||
dependencies:
|
||||
args: ^2.1.0
|
||||
|
@ -85,6 +85,21 @@ void main() {
|
||||
]));
|
||||
});
|
||||
|
||||
test('runs pub get before running Dart test script', () async {
|
||||
final Directory package = createFakePlugin('a_package', packagesDir,
|
||||
extraFiles: <String>['tool/run_tests.dart']);
|
||||
|
||||
await runCapturingPrint(runner, <String>['custom-test']);
|
||||
|
||||
expect(
|
||||
processRunner.recordedCalls,
|
||||
containsAll(<ProcessCall>[
|
||||
ProcessCall('dart', const <String>['pub', 'get'], package.path),
|
||||
ProcessCall('dart', const <String>['run', 'tool/run_tests.dart'],
|
||||
package.path),
|
||||
]));
|
||||
});
|
||||
|
||||
test('runs when only legacy is present', () async {
|
||||
final Directory package = createFakePlugin('a_package', packagesDir,
|
||||
extraFiles: <String>['run_tests.sh']);
|
||||
@ -128,7 +143,8 @@ void main() {
|
||||
]);
|
||||
|
||||
processRunner.mockProcessesForExecutable['dart'] = <io.Process>[
|
||||
MockProcess(exitCode: 1),
|
||||
MockProcess(exitCode: 0), // pub get
|
||||
MockProcess(exitCode: 1), // test script
|
||||
];
|
||||
|
||||
Error? commandError;
|
||||
@ -146,6 +162,32 @@ void main() {
|
||||
]));
|
||||
});
|
||||
|
||||
test('fails if pub get fails', () async {
|
||||
createFakePlugin('a_package', packagesDir, extraFiles: <String>[
|
||||
'tool/run_tests.dart',
|
||||
'run_tests.sh',
|
||||
]);
|
||||
|
||||
processRunner.mockProcessesForExecutable['dart'] = <io.Process>[
|
||||
MockProcess(exitCode: 1),
|
||||
];
|
||||
|
||||
Error? commandError;
|
||||
final List<String> output = await runCapturingPrint(
|
||||
runner, <String>['custom-test'], errorHandler: (Error e) {
|
||||
commandError = e;
|
||||
});
|
||||
|
||||
expect(commandError, isA<ToolExit>());
|
||||
expect(
|
||||
output,
|
||||
containsAllInOrder(<Matcher>[
|
||||
contains('The following packages had errors:'),
|
||||
contains('a_package:\n'
|
||||
' Unable to get script dependencies')
|
||||
]));
|
||||
});
|
||||
|
||||
test('fails if legacy fails', () async {
|
||||
final Directory package =
|
||||
createFakePlugin('a_package', packagesDir, extraFiles: <String>[
|
||||
@ -260,7 +302,8 @@ void main() {
|
||||
]);
|
||||
|
||||
processRunner.mockProcessesForExecutable['dart'] = <io.Process>[
|
||||
MockProcess(exitCode: 1),
|
||||
MockProcess(exitCode: 0), // pub get
|
||||
MockProcess(exitCode: 1), // test script
|
||||
];
|
||||
|
||||
Error? commandError;
|
||||
|
Reference in New Issue
Block a user