Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
d688b52a
Unverified
Commit
d688b52a
authored
Dec 02, 2020
by
Jonah Williams
Committed by
GitHub
Dec 02, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[flutter_tools] post process the gradle log output (#71499)
parent
7c14f6c8
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
102 additions
and
33 deletions
+102
-33
gradle.dart
packages/flutter_tools/lib/src/android/gradle.dart
+11
-33
gradle_log_processor.dart
...s/flutter_tools/lib/src/android/gradle_log_processor.dart
+48
-0
gradle_log_processor_test.dart
...test/general.shard/android/gradle_log_processor_test.dart
+43
-0
No files found.
packages/flutter_tools/lib/src/android/gradle.dart
View file @
d688b52a
...
@@ -23,6 +23,7 @@ import '../globals.dart' as globals;
...
@@ -23,6 +23,7 @@ import '../globals.dart' as globals;
import
'../project.dart'
;
import
'../project.dart'
;
import
'../reporting/reporting.dart'
;
import
'../reporting/reporting.dart'
;
import
'gradle_errors.dart'
;
import
'gradle_errors.dart'
;
import
'gradle_log_processor.dart'
;
import
'gradle_utils.dart'
;
import
'gradle_utils.dart'
;
/// The directory where the APK artifact is generated.
/// The directory where the APK artifact is generated.
...
@@ -360,31 +361,7 @@ Future<void> buildGradleApp({
...
@@ -360,31 +361,7 @@ Future<void> buildGradleApp({
}
}
command
.
add
(
assembleTask
);
command
.
add
(
assembleTask
);
GradleHandledError
detectedGradleError
;
final
GradleLogProcessor
gradleLogProcessor
=
GradleLogProcessor
(
localGradleErrors
,
globals
.
logger
.
isVerbose
);
String
detectedGradleErrorLine
;
String
consumeLog
(
String
line
)
{
// This message was removed from first-party plugins,
// but older plugin versions still display this message.
if
(
androidXPluginWarningRegex
.
hasMatch
(
line
))
{
// Don't pipe.
return
null
;
}
if
(
detectedGradleError
!=
null
)
{
// Pipe stdout/stderr from Gradle.
return
line
;
}
for
(
final
GradleHandledError
gradleError
in
localGradleErrors
)
{
if
(
gradleError
.
test
(
line
))
{
detectedGradleErrorLine
=
line
;
detectedGradleError
=
gradleError
;
// The first error match wins.
break
;
}
}
// Pipe stdout/stderr from Gradle.
return
line
;
}
final
Stopwatch
sw
=
Stopwatch
()..
start
();
final
Stopwatch
sw
=
Stopwatch
()..
start
();
int
exitCode
=
1
;
int
exitCode
=
1
;
try
{
try
{
...
@@ -393,13 +370,14 @@ Future<void> buildGradleApp({
...
@@ -393,13 +370,14 @@ Future<void> buildGradleApp({
workingDirectory:
project
.
android
.
hostAppGradleRoot
.
path
,
workingDirectory:
project
.
android
.
hostAppGradleRoot
.
path
,
allowReentrantFlutter:
true
,
allowReentrantFlutter:
true
,
environment:
gradleEnvironment
,
environment:
gradleEnvironment
,
mapFunction:
consumeLog
,
mapFunction:
gradleLogProcessor
.
consumeLog
,
);
);
}
on
ProcessException
catch
(
exception
)
{
}
on
ProcessException
catch
(
exception
)
{
consumeLog
(
exception
.
toString
());
gradleLogProcessor
.
atFailureFooter
=
false
;
gradleLogProcessor
.
consumeLog
(
exception
.
toString
());
// Rethrow the exception if the error isn't handled by any of the
// Rethrow the exception if the error isn't handled by any of the
// `localGradleErrors`.
// `localGradleErrors`.
if
(
detectedGradleError
==
null
)
{
if
(
gradleLogProcessor
.
detectedGradleError
==
null
)
{
rethrow
;
rethrow
;
}
}
}
finally
{
}
finally
{
...
@@ -409,22 +387,22 @@ Future<void> buildGradleApp({
...
@@ -409,22 +387,22 @@ Future<void> buildGradleApp({
globals
.
flutterUsage
.
sendTiming
(
'build'
,
'gradle'
,
sw
.
elapsed
);
globals
.
flutterUsage
.
sendTiming
(
'build'
,
'gradle'
,
sw
.
elapsed
);
if
(
exitCode
!=
0
)
{
if
(
exitCode
!=
0
)
{
if
(
detectedGradleError
==
null
)
{
if
(
gradleLogProcessor
.
detectedGradleError
==
null
)
{
BuildEvent
(
'gradle-unknown-failure'
,
flutterUsage:
globals
.
flutterUsage
).
send
();
BuildEvent
(
'gradle-unknown-failure'
,
flutterUsage:
globals
.
flutterUsage
).
send
();
throwToolExit
(
throwToolExit
(
'Gradle task
$assembleTask
failed with exit code
$exitCode
'
,
'Gradle task
$assembleTask
failed with exit code
$exitCode
'
,
exitCode:
exitCode
,
exitCode:
exitCode
,
);
);
}
else
{
}
else
{
final
GradleBuildStatus
status
=
await
detectedGradleError
.
handler
(
final
GradleBuildStatus
status
=
await
gradleLogProcessor
.
detectedGradleError
.
handler
(
line:
detectedGradleErrorLine
,
line:
gradleLogProcessor
.
detectedGradleErrorLine
,
project:
project
,
project:
project
,
usesAndroidX:
usesAndroidX
,
usesAndroidX:
usesAndroidX
,
shouldBuildPluginAsAar:
shouldBuildPluginAsAar
,
shouldBuildPluginAsAar:
shouldBuildPluginAsAar
,
);
);
if
(
retries
>=
1
)
{
if
(
retries
>=
1
)
{
final
String
successEventLabel
=
'gradle-
${detectedGradleError.eventLabel}
-success'
;
final
String
successEventLabel
=
'gradle-
${
gradleLogProcessor.
detectedGradleError.eventLabel}
-success'
;
switch
(
status
)
{
switch
(
status
)
{
case
GradleBuildStatus
.
retry
:
case
GradleBuildStatus
.
retry
:
await
buildGradleApp
(
await
buildGradleApp
(
...
@@ -454,7 +432,7 @@ Future<void> buildGradleApp({
...
@@ -454,7 +432,7 @@ Future<void> buildGradleApp({
// noop.
// noop.
}
}
}
}
BuildEvent
(
'gradle-
${detectedGradleError.eventLabel}
-failure'
,
flutterUsage:
globals
.
flutterUsage
).
send
();
BuildEvent
(
'gradle-
${
gradleLogProcessor.
detectedGradleError.eventLabel}
-failure'
,
flutterUsage:
globals
.
flutterUsage
).
send
();
throwToolExit
(
throwToolExit
(
'Gradle task
$assembleTask
failed with exit code
$exitCode
'
,
'Gradle task
$assembleTask
failed with exit code
$exitCode
'
,
exitCode:
exitCode
,
exitCode:
exitCode
,
...
...
packages/flutter_tools/lib/src/android/gradle_log_processor.dart
0 → 100644
View file @
d688b52a
// 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
'gradle_errors.dart'
;
/// Process log output from gradle, removing irrelevant output and capturing
/// exception information.
class
GradleLogProcessor
{
GradleLogProcessor
(
this
.
localGradleErrors
,
this
.
verbose
);
final
List
<
GradleHandledError
>
localGradleErrors
;
final
bool
verbose
;
GradleHandledError
detectedGradleError
;
String
detectedGradleErrorLine
;
bool
atFailureFooter
=
false
;
String
consumeLog
(
String
line
)
{
// All gradle failures lead to a fairly long footer which contains mostly
// irrelevant information for a flutter build, along with misleading advice to
// run with --stacktrace (which does not exist for the flutter CLI). remove this.
if
(!
verbose
&&
(
line
.
startsWith
(
'FAILURE: Build failed with an exception.'
)
||
atFailureFooter
))
{
atFailureFooter
=
true
;
return
null
;
}
// This message was removed from first-party plugins,
// but older plugin versions still display this message.
if
(
androidXPluginWarningRegex
.
hasMatch
(
line
))
{
// Don't pipe.
return
null
;
}
if
(
detectedGradleError
!=
null
)
{
// Pipe stdout/stderr from Gradle.
return
line
;
}
for
(
final
GradleHandledError
gradleError
in
localGradleErrors
)
{
if
(
gradleError
.
test
(
line
))
{
detectedGradleErrorLine
=
line
;
detectedGradleError
=
gradleError
;
// The first error match wins.
break
;
}
}
// Pipe stdout/stderr from Gradle.
return
line
;
}
}
packages/flutter_tools/test/general.shard/android/gradle_log_processor_test.dart
0 → 100644
View file @
d688b52a
// 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:flutter_tools/src/android/gradle_errors.dart'
;
import
'package:flutter_tools/src/android/gradle_log_processor.dart'
;
import
'../../src/common.dart'
;
final
List
<
String
>
gradleErrorOutputLines
=
r''
'
Some other stuff.
FAILURE: Build failed with an exception.
* Where:
Script '
/
Users
/
mit
/
dev
/
flutter
/
packages
/
flutter_tools
/
gradle
/
flutter
.
gradle
' line: 900
* What went wrong:
Execution failed for task '
:
app:
compileFlutterBuildRelease
'.
> Process '
command
'/Users/mit/dev/flutter/bin/flutter'' finished with non-zero exit value 1
* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output. Run with --scan to get full insights.
* Get more help at https://help.gradle.org
BUILD FAILED in 24s
'''
.
split
(
'
\n
'
);
void
main
(
)
{
testWithoutContext
(
'Does not print failure footer in non-verbose mode'
,
()
async
{
final
GradleLogProcessor
gradleLogProcessor
=
GradleLogProcessor
(<
GradleHandledError
>[],
false
);
expect
(
gradleErrorOutputLines
.
map
(
gradleLogProcessor
.
consumeLog
).
where
((
String
line
)
=>
line
!=
null
),
<
String
>[
'Some other stuff.'
]);
expect
(
gradleLogProcessor
.
atFailureFooter
,
true
);
});
testWithoutContext
(
'Does print failure footer in verbose mode'
,
()
async
{
final
GradleLogProcessor
gradleLogProcessor
=
GradleLogProcessor
(<
GradleHandledError
>[],
true
);
expect
(
gradleErrorOutputLines
.
map
(
gradleLogProcessor
.
consumeLog
).
where
((
String
line
)
=>
line
!=
null
),
gradleErrorOutputLines
);
expect
(
gradleLogProcessor
.
atFailureFooter
,
false
);
});
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment