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
b3f63d38
Unverified
Commit
b3f63d38
authored
Oct 09, 2021
by
Ian Hickson
Committed by
GitHub
Oct 09, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Document why some lints aren't enabled and fix some minor issues. (#91527)
parent
cd5936e4
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
68 additions
and
69 deletions
+68
-69
analysis_options.yaml
analysis_options.yaml
+7
-8
utils.dart
dev/devicelab/lib/framework/utils.dart
+2
-10
analysis_options.yaml
packages/flutter/lib/analysis_options.yaml
+5
-0
driver.dart
packages/flutter_driver/lib/src/driver/driver.dart
+49
-47
packages.dart
packages/flutter_tools/lib/src/commands/packages.dart
+5
-4
No files found.
analysis_options.yaml
View file @
b3f63d38
...
@@ -27,13 +27,12 @@ analyzer:
...
@@ -27,13 +27,12 @@ analyzer:
missing_required_param
:
warning
missing_required_param
:
warning
# treat missing returns as a warning (not a hint)
# treat missing returns as a warning (not a hint)
missing_return
:
warning
missing_return
:
warning
# allow having TODO
/HACK
comments in the code
# allow having TODO comments in the code
todo
:
ignore
todo
:
ignore
hack
:
ignore
# allow self-reference to deprecated members (we do this because otherwise we have
# allow self-reference to deprecated members (we do this because otherwise we have
# to annotate every member in every test, assert, etc, when we deprecate something)
# to annotate every member in every test, assert, etc, when we deprecate something)
deprecated_member_use_from_same_package
:
ignore
deprecated_member_use_from_same_package
:
ignore
# TODO(
https://github.com/flutter/flutter/issues/74381):
# TODO(
ianh): https://github.com/flutter/flutter/issues/74381
# Clean up existing unnecessary imports, and remove line to ignore.
# Clean up existing unnecessary imports, and remove line to ignore.
unnecessary_import
:
ignore
unnecessary_import
:
ignore
# Turned off until null-safe rollout is complete.
# Turned off until null-safe rollout is complete.
...
@@ -92,12 +91,12 @@ linter:
...
@@ -92,12 +91,12 @@ linter:
-
avoid_unnecessary_containers
-
avoid_unnecessary_containers
-
avoid_unused_constructor_parameters
-
avoid_unused_constructor_parameters
-
avoid_void_async
-
avoid_void_async
# - avoid_web_libraries_in_flutter #
not yet tested
# - avoid_web_libraries_in_flutter #
we use web libraries in web-specific code, and our tests prevent us from using them elsewhere
-
await_only_futures
-
await_only_futures
-
camel_case_extensions
-
camel_case_extensions
-
camel_case_types
-
camel_case_types
-
cancel_subscriptions
-
cancel_subscriptions
# - cascade_invocations #
not yet tested
# - cascade_invocations #
doesn't match the typical style of this repo
-
cast_nullable_to_non_nullable
-
cast_nullable_to_non_nullable
# - close_sinks # not reliable enough
# - close_sinks # not reliable enough
# - comment_references # blocked on https://github.com/dart-lang/linter/issues/1142
# - comment_references # blocked on https://github.com/dart-lang/linter/issues/1142
...
@@ -105,9 +104,9 @@ linter:
...
@@ -105,9 +104,9 @@ linter:
-
control_flow_in_finally
-
control_flow_in_finally
# - curly_braces_in_flow_control_structures # not required by flutter style
# - curly_braces_in_flow_control_structures # not required by flutter style
-
deprecated_consistency
-
deprecated_consistency
# - diagnostic_describe_all_properties #
not yet tested
# - diagnostic_describe_all_properties #
enabled only at the framework level (packages/flutter/lib)
-
directives_ordering
-
directives_ordering
# - do_not_use_environment #
we do this commonly
# - do_not_use_environment #
there are appropriate times to use the environment, especially in our tests and build logic
-
empty_catches
-
empty_catches
-
empty_constructor_bodies
-
empty_constructor_bodies
-
empty_statements
-
empty_statements
...
@@ -125,7 +124,7 @@ linter:
...
@@ -125,7 +124,7 @@ linter:
-
library_private_types_in_public_api
-
library_private_types_in_public_api
# - lines_longer_than_80_chars # not required by flutter style
# - lines_longer_than_80_chars # not required by flutter style
-
list_remove_unrelated_type
-
list_remove_unrelated_type
# - literal_only_boolean_expressions # too many false positives: https://github.com/dart-lang/
sdk/issues/34181
# - literal_only_boolean_expressions # too many false positives: https://github.com/dart-lang/
linter/issues/453
-
missing_whitespace_between_adjacent_strings
-
missing_whitespace_between_adjacent_strings
-
no_adjacent_strings_in_list
-
no_adjacent_strings_in_list
# - no_default_cases # too many false positives
# - no_default_cases # too many false positives
...
...
dev/devicelab/lib/framework/utils.dart
View file @
b3f63d38
...
@@ -21,22 +21,14 @@ String cwd = Directory.current.path;
...
@@ -21,22 +21,14 @@ String cwd = Directory.current.path;
/// The local engine to use for [flutter] and [evalFlutter], if any.
/// The local engine to use for [flutter] and [evalFlutter], if any.
String
?
get
localEngine
{
String
?
get
localEngine
{
// Use two distinct `defaultValue`s to determine whether a 'localEngine'
const
bool
isDefined
=
bool
.
hasEnvironment
(
'localEngine'
);
// declaration exists in the environment.
const
bool
isDefined
=
String
.
fromEnvironment
(
'localEngine'
,
defaultValue:
'a'
)
==
String
.
fromEnvironment
(
'localEngine'
,
defaultValue:
'b'
);
return
isDefined
?
const
String
.
fromEnvironment
(
'localEngine'
)
:
null
;
return
isDefined
?
const
String
.
fromEnvironment
(
'localEngine'
)
:
null
;
}
}
/// The local engine source path to use if a local engine is used for [flutter]
/// The local engine source path to use if a local engine is used for [flutter]
/// and [evalFlutter].
/// and [evalFlutter].
String
?
get
localEngineSrcPath
{
String
?
get
localEngineSrcPath
{
// Use two distinct `defaultValue`s to determine whether a
const
bool
isDefined
=
bool
.
hasEnvironment
(
'localEngineSrcPath'
);
// 'localEngineSrcPath' declaration exists in the environment.
const
bool
isDefined
=
String
.
fromEnvironment
(
'localEngineSrcPath'
,
defaultValue:
'a'
)
==
String
.
fromEnvironment
(
'localEngineSrcPath'
,
defaultValue:
'b'
);
return
isDefined
?
const
String
.
fromEnvironment
(
'localEngineSrcPath'
)
:
null
;
return
isDefined
?
const
String
.
fromEnvironment
(
'localEngineSrcPath'
)
:
null
;
}
}
...
...
packages/flutter/lib/analysis_options.yaml
0 → 100644
View file @
b3f63d38
include
:
../analysis_options.yaml
linter
:
rules
:
# - diagnostic_describe_all_properties # blocked on https://github.com/dart-lang/sdk/issues/47418
packages/flutter_driver/lib/src/driver/driver.dart
View file @
b3f63d38
...
@@ -556,53 +556,55 @@ abstract class FlutterDriver {
...
@@ -556,53 +556,55 @@ abstract class FlutterDriver {
///
///
/// The image will be returned as a PNG.
/// The image will be returned as a PNG.
///
///
/// HACK: There will be a 2-second artificial delay before screenshotting,
/// **Warning:** This is not reliable.
/// the delay here is to deal with a race between the driver script and
///
/// the raster thread (formerly known as the GPU thread). The issue is
/// There is a two-second artificial delay before screenshotting. The delay
/// that driver API synchronizes with the framework based on transient
/// here is to deal with a race between the driver script and the raster
/// callbacks, which are out of sync with the raster thread.
/// thread (formerly known as the GPU thread). The issue is that the driver
/// API synchronizes with the framework based on transient callbacks, which
/// are out of sync with the raster thread.
///
/// Here's the timeline of events in ASCII art:
/// Here's the timeline of events in ASCII art:
///
///
///
----
---------------------------------------------------------------
/// ---------------------------------------------------------------
/// Without this delay:
/// Without this delay:
///
----
---------------------------------------------------------------
/// ---------------------------------------------------------------
/// UI : <-- build -->
/// UI : <-- build -->
/// Raster: <-- rasterize -->
/// Raster: <-- rasterize -->
/// Gap : | random |
/// Gap : | random |
/// Driver: <-- screenshot -->
/// Driver: <-- screenshot -->
///
///
/// In the diagram above, the gap is the time between the last driver
/// In the diagram above, the gap is the time between the last driver action
/// action taken, such as a `tap()`, and the subsequent call to
/// taken, such as a `tap()`, and the subsequent call to `screenshot()`. The
/// `screenshot()`. The gap is random because it is determined by the
/// gap is random because it is determined by the unpredictable communication
/// unpredictable network communication between the driver process and
/// channel between the driver process and the application. If this gap is too
/// the application. If this gap is too short, which it typically will
/// short, which it typically will be, the screenshot is taken before the
/// be, the screenshot is taken before the raster thread is done
/// raster thread is done rasterizing the frame, so the screenshot of the
/// rasterizing the frame, so the screenshot of the previous frame is
/// previous frame is taken, which is not what is intended.
/// taken, which is wrong.
///
///
///
----
---------------------------------------------------------------
/// ---------------------------------------------------------------
/// With this delay, if we're lucky:
/// With this delay, if we're lucky:
///
----
---------------------------------------------------------------
/// ---------------------------------------------------------------
/// UI : <-- build -->
/// UI : <-- build -->
/// Raster: <-- rasterize -->
/// Raster: <-- rasterize -->
/// Gap : | 2 seconds or more |
/// Gap : | 2 seconds or more |
/// Driver: <-- screenshot -->
/// Driver: <-- screenshot -->
///
///
///
The two-second gap should be long enough for the raster thread to
///
The two-second gap should be long enough for the raster thread to finish
///
finish rasterizing the frame, but not longer than necessary to keep
///
rasterizing the frame, but not longer than necessary to keep driver tests
///
driver tests
as fast a possible.
/// as fast a possible.
///
///
///
----
---------------------------------------------------------------
/// ---------------------------------------------------------------
/// With this delay, if we're not lucky:
/// With this delay, if we're not lucky:
///
----
---------------------------------------------------------------
/// ---------------------------------------------------------------
/// UI : <-- build -->
/// UI : <-- build -->
/// Raster: <-- rasterize randomly slow today -->
/// Raster: <-- rasterize randomly slow today -->
/// Gap : | 2 seconds or more |
/// Gap : | 2 seconds or more |
/// Driver: <-- screenshot -->
/// Driver: <-- screenshot -->
///
///
///
In practice, sometimes the device gets really busy for a while and
///
In practice, sometimes the device gets really busy for a while and even
///
even two seconds isn't enough, which means that this is still racy
///
two seconds isn't enough, which means that this is still racy and a source
///
and a source
of flakes.
/// of flakes.
Future
<
List
<
int
>>
screenshot
()
async
{
Future
<
List
<
int
>>
screenshot
()
async
{
throw
UnimplementedError
();
throw
UnimplementedError
();
}
}
...
...
packages/flutter_tools/lib/src/commands/packages.dart
View file @
b3f63d38
...
@@ -305,10 +305,11 @@ class PackagesInteractiveGetCommand extends FlutterCommand {
...
@@ -305,10 +305,11 @@ class PackagesInteractiveGetCommand extends FlutterCommand {
List
<
String
>
rest
=
argResults
.
rest
;
List
<
String
>
rest
=
argResults
.
rest
;
final
bool
isHelp
=
rest
.
contains
(
'-h'
)
||
rest
.
contains
(
'--help'
);
final
bool
isHelp
=
rest
.
contains
(
'-h'
)
||
rest
.
contains
(
'--help'
);
String
target
;
String
target
;
if
(
rest
.
length
==
1
&&
(
rest
[
0
].
contains
(
'/'
)
||
rest
[
0
].
contains
(
r'\'
)))
{
if
(
rest
.
length
==
1
&&
(
rest
.
single
.
contains
(
'/'
)
||
rest
.
single
.
contains
(
r'\'
)))
{
// HACK: Supporting flutter specific behavior where you can pass a
// For historical reasons, if there is one argument to the command and it contains
// folder to the command.
// a multiple-component path (i.e. contains a slash) then we use that to determine
target
=
findProjectRoot
(
globals
.
fs
,
rest
[
0
]);
// to which project we're applying the command.
target
=
findProjectRoot
(
globals
.
fs
,
rest
.
single
);
rest
=
<
String
>[];
rest
=
<
String
>[];
}
else
{
}
else
{
target
=
findProjectRoot
(
globals
.
fs
);
target
=
findProjectRoot
(
globals
.
fs
);
...
...
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