Unverified Commit f44f625c authored by Greg Spencer's avatar Greg Spencer Committed by GitHub

Fix whitespace detector to handle deleted files. (#19690)

The trailing whitespace detector wasn't handling file deletes very well (at all, really).

This filters the set of files grepped to only include files that exist.

Also, clarified the failure message to make it more obvious what the failure is when the grep finds results.
parent d61b4fae
...@@ -64,7 +64,7 @@ task: ...@@ -64,7 +64,7 @@ task:
- bin\flutter.bat update-packages - bin\flutter.bat update-packages
- git fetch origin master - git fetch origin master
test_all_script: | test_all_script: |
export TEST_COMMIT_RANGE="$(git merge-base --fork-point FETCH_HEAD HEAD)..HEAD" export TEST_COMMIT_RANGE="$(git merge-base --fork-point FETCH_HEAD HEAD || git merge-base FETCH_HEAD HEAD)..HEAD"
bin\cache\dart-sdk\bin\dart.exe -c dev\bots\test.dart bin\cache\dart-sdk\bin\dart.exe -c dev\bots\test.dart
task: task:
...@@ -83,7 +83,7 @@ task: ...@@ -83,7 +83,7 @@ task:
- bin\flutter.bat update-packages - bin\flutter.bat update-packages
- git fetch origin master - git fetch origin master
test_all_script: | test_all_script: |
export TEST_COMMIT_RANGE="$(git merge-base --fork-point FETCH_HEAD HEAD)..HEAD" export TEST_COMMIT_RANGE="$(git merge-base --fork-point FETCH_HEAD HEAD || git merge-base FETCH_HEAD HEAD)..HEAD"
bin\cache\dart-sdk\bin\dart.exe -c dev\bots\test.dart bin\cache\dart-sdk\bin\dart.exe -c dev\bots\test.dart
task: task:
...@@ -98,7 +98,7 @@ task: ...@@ -98,7 +98,7 @@ task:
- bin/flutter update-packages - bin/flutter update-packages
test_all_script: | test_all_script: |
ulimit -S -n 2048 # https://github.com/flutter/flutter/issues/2976 ulimit -S -n 2048 # https://github.com/flutter/flutter/issues/2976
export TEST_COMMIT_RANGE="$(git merge-base --fork-point FETCH_HEAD HEAD)..HEAD" export TEST_COMMIT_RANGE="$(git merge-base --fork-point FETCH_HEAD HEAD || git merge-base FETCH_HEAD HEAD)..HEAD"
bin/cache/dart-sdk/bin/dart -c dev/bots/test.dart bin/cache/dart-sdk/bin/dart -c dev/bots/test.dart
task: task:
...@@ -113,5 +113,5 @@ task: ...@@ -113,5 +113,5 @@ task:
- bin/flutter update-packages - bin/flutter update-packages
test_all_script: | test_all_script: |
ulimit -S -n 2048 # https://github.com/flutter/flutter/issues/2976 ulimit -S -n 2048 # https://github.com/flutter/flutter/issues/2976
export TEST_COMMIT_RANGE="$(git merge-base --fork-point FETCH_HEAD HEAD)..HEAD" export TEST_COMMIT_RANGE="$(git merge-base --fork-point FETCH_HEAD HEAD || git merge-base FETCH_HEAD HEAD)..HEAD"
bin/cache/dart-sdk/bin/dart -c dev/bots/test.dart bin/cache/dart-sdk/bin/dart -c dev/bots/test.dart
...@@ -103,9 +103,8 @@ Future<Null> _checkForTrailingSpaces() async { ...@@ -103,9 +103,8 @@ Future<Null> _checkForTrailingSpaces() async {
final String commitRange = Platform.environment.containsKey('TEST_COMMIT_RANGE') final String commitRange = Platform.environment.containsKey('TEST_COMMIT_RANGE')
? Platform.environment['TEST_COMMIT_RANGE'] ? Platform.environment['TEST_COMMIT_RANGE']
: 'master..HEAD'; : 'master..HEAD';
print('Checking for trailing whitespace in source files.');
final List<String> fileTypes = <String>[ final List<String> fileTypes = <String>[
'*.dart', '*.cxx', '*.cpp', '*.cc', '*.c', '*.C', '*.h', '*.java', '*.mm', '*.m', '*.dart', '*.cxx', '*.cpp', '*.cc', '*.c', '*.C', '*.h', '*.java', '*.mm', '*.m', '.yml',
]; ];
final EvalResult changedFilesResult = await _evalCommand( final EvalResult changedFilesResult = await _evalCommand(
'git', <String>['diff', '-U0', '--no-color', '--name-only', commitRange, '--'] + fileTypes, 'git', <String>['diff', '-U0', '--no-color', '--name-only', commitRange, '--'] + fileTypes,
...@@ -115,8 +114,11 @@ Future<Null> _checkForTrailingSpaces() async { ...@@ -115,8 +114,11 @@ Future<Null> _checkForTrailingSpaces() async {
print('No Results for whitespace check.'); print('No Results for whitespace check.');
return; return;
} }
final List<String> changedFiles = changedFilesResult.stdout.trim().split('\n') // Only include files that actually exist, so that we don't try and grep for
.where((String item) => item.trim().isNotEmpty).toList(); // nonexistent files (can occur when files are deleted or moved).
final List<String> changedFiles = changedFilesResult.stdout.split('\n').where((String filename) {
return new File(filename).existsSync();
}).toList();
if (changedFiles.isNotEmpty) { if (changedFiles.isNotEmpty) {
await _runCommand('grep', await _runCommand('grep',
<String>[ <String>[
...@@ -125,8 +127,8 @@ Future<Null> _checkForTrailingSpaces() async { ...@@ -125,8 +127,8 @@ Future<Null> _checkForTrailingSpaces() async {
r'[[:space:]]+$', r'[[:space:]]+$',
] + changedFiles, ] + changedFiles,
workingDirectory: flutterRoot, workingDirectory: flutterRoot,
printOutput: false, failureMessage: '${red}Whitespace detected at the end of source code lines.$reset\nPlease remove:',
expectFailure: true, // Just means a non-zero exit code is expected. expectNonZeroExit: true, // Just means a non-zero exit code is expected.
expectedExitCode: 1, // Indicates that zero lines were found. expectedExitCode: 1, // Indicates that zero lines were found.
); );
} }
...@@ -244,7 +246,7 @@ Future<Null> _runSmokeTests() async { ...@@ -244,7 +246,7 @@ Future<Null> _runSmokeTests() async {
_runCommand(flutter, _runCommand(flutter,
<String>['drive', '--use-existing-app', '-t', path.join('test_driver', 'failure.dart')], <String>['drive', '--use-existing-app', '-t', path.join('test_driver', 'failure.dart')],
workingDirectory: path.join(flutterRoot, 'packages', 'flutter_driver'), workingDirectory: path.join(flutterRoot, 'packages', 'flutter_driver'),
expectFailure: true, expectNonZeroExit: true,
printOutput: false, printOutput: false,
timeout: _kShortTimeout, timeout: _kShortTimeout,
), ),
...@@ -387,8 +389,9 @@ String elapsedTime(DateTime start) { ...@@ -387,8 +389,9 @@ String elapsedTime(DateTime start) {
Future<Null> _runCommand(String executable, List<String> arguments, { Future<Null> _runCommand(String executable, List<String> arguments, {
String workingDirectory, String workingDirectory,
Map<String, String> environment, Map<String, String> environment,
bool expectFailure = false, bool expectNonZeroExit = false,
int expectedExitCode, int expectedExitCode,
String failureMessage,
bool printOutput = true, bool printOutput = true,
bool skip = false, bool skip = false,
Duration timeout = _kLongTimeout, Duration timeout = _kLongTimeout,
...@@ -420,17 +423,20 @@ Future<Null> _runCommand(String executable, List<String> arguments, { ...@@ -420,17 +423,20 @@ Future<Null> _runCommand(String executable, List<String> arguments, {
final int exitCode = await process.exitCode.timeout(timeout, onTimeout: () { final int exitCode = await process.exitCode.timeout(timeout, onTimeout: () {
stderr.writeln('Process timed out after $timeout'); stderr.writeln('Process timed out after $timeout');
return expectFailure ? 0 : 1; return expectNonZeroExit ? 0 : 1;
}); });
print('$clock ELAPSED TIME: $bold${elapsedTime(start)}$reset for $commandDescription in $relativeWorkingDir: '); print('$clock ELAPSED TIME: $bold${elapsedTime(start)}$reset for $commandDescription in $relativeWorkingDir: ');
if ((exitCode == 0) == expectFailure || (expectedExitCode != null && exitCode != expectedExitCode)) { if ((exitCode == 0) == expectNonZeroExit || (expectedExitCode != null && exitCode != expectedExitCode)) {
if (failureMessage != null) {
print(failureMessage);
}
if (!printOutput) { if (!printOutput) {
stdout.writeln(utf8.decode((await savedStdout).expand((List<int> ints) => ints).toList())); stdout.writeln(utf8.decode((await savedStdout).expand((List<int> ints) => ints).toList()));
stderr.writeln(utf8.decode((await savedStderr).expand((List<int> ints) => ints).toList())); stderr.writeln(utf8.decode((await savedStderr).expand((List<int> ints) => ints).toList()));
} }
print( print(
'$red━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━$reset\n' '$red━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━$reset\n'
'${bold}ERROR:$red Last command exited with $exitCode (expected: ${expectFailure ? 'non-zero' : 'zero'}).$reset\n' '${bold}ERROR:$red Last command exited with $exitCode (expected: ${expectNonZeroExit ? (expectedExitCode ?? 'non-zero') : 'zero'}).$reset\n'
'${bold}Command:$cyan $commandDescription$reset\n' '${bold}Command:$cyan $commandDescription$reset\n'
'${bold}Relative working directory:$red $relativeWorkingDir$reset\n' '${bold}Relative working directory:$red $relativeWorkingDir$reset\n'
'$red━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━$reset' '$red━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━$reset'
...@@ -466,7 +472,7 @@ Future<Null> _runFlutterTest(String workingDirectory, { ...@@ -466,7 +472,7 @@ Future<Null> _runFlutterTest(String workingDirectory, {
} }
return _runCommand(flutter, args, return _runCommand(flutter, args,
workingDirectory: workingDirectory, workingDirectory: workingDirectory,
expectFailure: expectFailure, expectNonZeroExit: expectFailure,
printOutput: printOutput, printOutput: printOutput,
skip: skip, skip: skip,
timeout: timeout, timeout: timeout,
......
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