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
61751835
Unverified
Commit
61751835
authored
Sep 02, 2020
by
Jenn Magder
Committed by
GitHub
Sep 02, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add --device-timeout flag to device-related commands (#64834)
parent
608f0606
Changes
14
Show whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
141 additions
and
40 deletions
+141
-40
attach.dart
packages/flutter_tools/lib/src/commands/attach.dart
+1
-0
devices.dart
packages/flutter_tools/lib/src/commands/devices.dart
+18
-12
drive.dart
packages/flutter_tools/lib/src/commands/drive.dart
+4
-4
install.dart
packages/flutter_tools/lib/src/commands/install.dart
+1
-0
logs.dart
packages/flutter_tools/lib/src/commands/logs.dart
+1
-0
run.dart
packages/flutter_tools/lib/src/commands/run.dart
+1
-0
screenshot.dart
packages/flutter_tools/lib/src/commands/screenshot.dart
+1
-0
device.dart
packages/flutter_tools/lib/src/device.dart
+6
-1
flutter_command.dart
packages/flutter_tools/lib/src/runner/flutter_command.dart
+24
-1
attach_test.dart
...utter_tools/test/commands.shard/hermetic/attach_test.dart
+2
-0
drive_test.dart
...lutter_tools/test/commands.shard/hermetic/drive_test.dart
+5
-5
run_test.dart
.../flutter_tools/test/commands.shard/hermetic/run_test.dart
+10
-7
device_test.dart
packages/flutter_tools/test/general.shard/device_test.dart
+66
-9
context.dart
packages/flutter_tools/test/src/context.dart
+1
-1
No files found.
packages/flutter_tools/lib/src/commands/attach.dart
View file @
61751835
...
@@ -102,6 +102,7 @@ class AttachCommand extends FlutterCommand {
...
@@ -102,6 +102,7 @@ class AttachCommand extends FlutterCommand {
);
);
usesTrackWidgetCreation
(
verboseHelp:
verboseHelp
);
usesTrackWidgetCreation
(
verboseHelp:
verboseHelp
);
addDdsOptions
(
verboseHelp:
verboseHelp
);
addDdsOptions
(
verboseHelp:
verboseHelp
);
usesDeviceTimeoutOption
();
hotRunnerFactory
??=
HotRunnerFactory
();
hotRunnerFactory
??=
HotRunnerFactory
();
}
}
...
...
packages/flutter_tools/lib/src/commands/devices.dart
View file @
61751835
...
@@ -22,8 +22,9 @@ class DevicesCommand extends FlutterCommand {
...
@@ -22,8 +22,9 @@ class DevicesCommand extends FlutterCommand {
'timeout'
,
'timeout'
,
abbr:
't'
,
abbr:
't'
,
defaultsTo:
null
,
defaultsTo:
null
,
help:
'
Time in seconds to wait for devices to attach. Longer timeouts may be necessary for networked devices.'
help:
'
(deprecated) Use --device-timeout instead'
,
);
);
usesDeviceTimeoutOption
();
}
}
@override
@override
...
@@ -32,20 +33,25 @@ class DevicesCommand extends FlutterCommand {
...
@@ -32,20 +33,25 @@ class DevicesCommand extends FlutterCommand {
@override
@override
final
String
description
=
'List all connected devices.'
;
final
String
description
=
'List all connected devices.'
;
Duration
get
timeout
{
@override
if
(
argResults
[
'timeout'
]
==
null
)
{
Duration
get
deviceDiscoveryTimeout
{
return
null
;
if
(
argResults
[
'timeout'
]
!=
null
)
{
}
if
(
_timeout
==
null
)
{
final
int
timeoutSeconds
=
int
.
tryParse
(
stringArg
(
'timeout'
));
final
int
timeoutSeconds
=
int
.
tryParse
(
stringArg
(
'timeout'
));
if
(
timeoutSeconds
==
null
)
{
if
(
timeoutSeconds
==
null
)
{
throwToolExit
(
'Could not parse -t/--timeout argument. It must be an integer.'
);
throwToolExit
(
'Could not parse -t/--timeout argument. It must be an integer.'
);
}
}
_timeout
=
Duration
(
seconds:
timeoutSeconds
);
return
Duration
(
seconds:
timeoutSeconds
);
}
return
super
.
deviceDiscoveryTimeout
;
}
@override
Future
<
void
>
validateCommand
()
{
if
(
argResults
[
'timeout'
]
!=
null
)
{
globals
.
printError
(
'--timeout has been deprecated, use --
${FlutterOptions.kDeviceTimeout}
instead'
);
}
}
return
_timeout
;
return
super
.
validateCommand
()
;
}
}
Duration
_timeout
;
@override
@override
Future
<
FlutterCommandResult
>
runCommand
()
async
{
Future
<
FlutterCommandResult
>
runCommand
()
async
{
...
@@ -56,7 +62,7 @@ class DevicesCommand extends FlutterCommand {
...
@@ -56,7 +62,7 @@ class DevicesCommand extends FlutterCommand {
exitCode:
1
);
exitCode:
1
);
}
}
final
List
<
Device
>
devices
=
await
globals
.
deviceManager
.
refreshAllConnectedDevices
(
timeout:
t
imeout
);
final
List
<
Device
>
devices
=
await
globals
.
deviceManager
.
refreshAllConnectedDevices
(
timeout:
deviceDiscoveryT
imeout
);
if
(
boolArg
(
'machine'
))
{
if
(
boolArg
(
'machine'
))
{
await
printDevicesAsJson
(
devices
);
await
printDevicesAsJson
(
devices
);
...
@@ -68,8 +74,8 @@ class DevicesCommand extends FlutterCommand {
...
@@ -68,8 +74,8 @@ class DevicesCommand extends FlutterCommand {
status
.
writeln
(
'Run "flutter emulators" to list and start any available device emulators.'
);
status
.
writeln
(
'Run "flutter emulators" to list and start any available device emulators.'
);
status
.
writeln
();
status
.
writeln
();
status
.
write
(
'If you expected your device to be detected, please run "flutter doctor" to diagnose potential issues. '
);
status
.
write
(
'If you expected your device to be detected, please run "flutter doctor" to diagnose potential issues. '
);
if
(
t
imeout
==
null
)
{
if
(
deviceDiscoveryT
imeout
==
null
)
{
status
.
write
(
'You may also try increasing the time to wait for connected devices with the --
timeout
flag. '
);
status
.
write
(
'You may also try increasing the time to wait for connected devices with the --
${FlutterOptions.kDeviceTimeout}
flag. '
);
}
}
status
.
write
(
'Visit https://flutter.dev/setup/ for troubleshooting tips.'
);
status
.
write
(
'Visit https://flutter.dev/setup/ for troubleshooting tips.'
);
...
...
packages/flutter_tools/lib/src/commands/drive.dart
View file @
61751835
...
@@ -146,7 +146,7 @@ class DriveCommand extends RunCommandBase {
...
@@ -146,7 +146,7 @@ class DriveCommand extends RunCommandBase {
@override
@override
Future
<
void
>
validateCommand
()
async
{
Future
<
void
>
validateCommand
()
async
{
if
(
userIdentifier
!=
null
)
{
if
(
userIdentifier
!=
null
)
{
final
Device
device
=
await
findTargetDevice
();
final
Device
device
=
await
findTargetDevice
(
timeout:
deviceDiscoveryTimeout
);
if
(
device
is
!
AndroidDevice
)
{
if
(
device
is
!
AndroidDevice
)
{
throwToolExit
(
'--
${FlutterOptions.kDeviceUser}
is only supported for Android'
);
throwToolExit
(
'--
${FlutterOptions.kDeviceUser}
is only supported for Android'
);
}
}
...
@@ -161,7 +161,7 @@ class DriveCommand extends RunCommandBase {
...
@@ -161,7 +161,7 @@ class DriveCommand extends RunCommandBase {
throwToolExit
(
null
);
throwToolExit
(
null
);
}
}
_device
=
await
findTargetDevice
();
_device
=
await
findTargetDevice
(
timeout:
deviceDiscoveryTimeout
);
if
(
device
==
null
)
{
if
(
device
==
null
)
{
throwToolExit
(
null
);
throwToolExit
(
null
);
}
}
...
@@ -388,9 +388,9 @@ $ex
...
@@ -388,9 +388,9 @@ $ex
}
}
}
}
Future
<
Device
>
findTargetDevice
()
async
{
Future
<
Device
>
findTargetDevice
(
{
@required
Duration
timeout
}
)
async
{
final
DeviceManager
deviceManager
=
globals
.
deviceManager
;
final
DeviceManager
deviceManager
=
globals
.
deviceManager
;
final
List
<
Device
>
devices
=
await
deviceManager
.
findTargetDevices
(
FlutterProject
.
current
());
final
List
<
Device
>
devices
=
await
deviceManager
.
findTargetDevices
(
FlutterProject
.
current
()
,
timeout:
timeout
);
if
(
deviceManager
.
hasSpecifiedDeviceId
)
{
if
(
deviceManager
.
hasSpecifiedDeviceId
)
{
if
(
devices
.
isEmpty
)
{
if
(
devices
.
isEmpty
)
{
...
...
packages/flutter_tools/lib/src/commands/install.dart
View file @
61751835
...
@@ -16,6 +16,7 @@ class InstallCommand extends FlutterCommand with DeviceBasedDevelopmentArtifacts
...
@@ -16,6 +16,7 @@ class InstallCommand extends FlutterCommand with DeviceBasedDevelopmentArtifacts
InstallCommand
()
{
InstallCommand
()
{
requiresPubspecYaml
();
requiresPubspecYaml
();
usesDeviceUserOption
();
usesDeviceUserOption
();
usesDeviceTimeoutOption
();
argParser
.
addFlag
(
'uninstall-only'
,
argParser
.
addFlag
(
'uninstall-only'
,
negatable:
true
,
negatable:
true
,
defaultsTo:
false
,
defaultsTo:
false
,
...
...
packages/flutter_tools/lib/src/commands/logs.dart
View file @
61751835
...
@@ -18,6 +18,7 @@ class LogsCommand extends FlutterCommand {
...
@@ -18,6 +18,7 @@ class LogsCommand extends FlutterCommand {
abbr:
'c'
,
abbr:
'c'
,
help:
'Clear log history before reading from logs.'
,
help:
'Clear log history before reading from logs.'
,
);
);
usesDeviceTimeoutOption
();
}
}
@override
@override
...
...
packages/flutter_tools/lib/src/commands/run.dart
View file @
61751835
...
@@ -75,6 +75,7 @@ abstract class RunCommandBase extends FlutterCommand with DeviceBasedDevelopment
...
@@ -75,6 +75,7 @@ abstract class RunCommandBase extends FlutterCommand with DeviceBasedDevelopment
usesTrackWidgetCreation
(
verboseHelp:
verboseHelp
);
usesTrackWidgetCreation
(
verboseHelp:
verboseHelp
);
addNullSafetyModeOptions
(
hide:
!
verboseHelp
);
addNullSafetyModeOptions
(
hide:
!
verboseHelp
);
usesDeviceUserOption
();
usesDeviceUserOption
();
usesDeviceTimeoutOption
();
}
}
bool
get
traceStartup
=>
boolArg
(
'trace-startup'
);
bool
get
traceStartup
=>
boolArg
(
'trace-startup'
);
...
...
packages/flutter_tools/lib/src/commands/screenshot.dart
View file @
61751835
...
@@ -51,6 +51,7 @@ class ScreenshotCommand extends FlutterCommand {
...
@@ -51,6 +51,7 @@ class ScreenshotCommand extends FlutterCommand {
},
},
defaultsTo:
_kDeviceType
,
defaultsTo:
_kDeviceType
,
);
);
usesDeviceTimeoutOption
();
}
}
@override
@override
...
...
packages/flutter_tools/lib/src/device.dart
View file @
61751835
...
@@ -209,7 +209,12 @@ abstract class DeviceManager {
...
@@ -209,7 +209,12 @@ abstract class DeviceManager {
/// * If the user did not specify a device id and there is more than one
/// * If the user did not specify a device id and there is more than one
/// device connected, then filter out unsupported devices and prioritize
/// device connected, then filter out unsupported devices and prioritize
/// ephemeral devices.
/// ephemeral devices.
Future
<
List
<
Device
>>
findTargetDevices
(
FlutterProject
flutterProject
)
async
{
Future
<
List
<
Device
>>
findTargetDevices
(
FlutterProject
flutterProject
,
{
Duration
timeout
})
async
{
if
(
timeout
!=
null
)
{
// Reset the cache with the specified timeout.
await
refreshAllConnectedDevices
(
timeout:
timeout
);
}
List
<
Device
>
devices
=
await
getDevices
();
List
<
Device
>
devices
=
await
getDevices
();
// Always remove web and fuchsia devices from `--all`. This setting
// Always remove web and fuchsia devices from `--all`. This setting
...
...
packages/flutter_tools/lib/src/runner/flutter_command.dart
View file @
61751835
...
@@ -113,6 +113,7 @@ class FlutterOptions {
...
@@ -113,6 +113,7 @@ class FlutterOptions {
static
const
String
kPerformanceMeasurementFile
=
'performance-measurement-file'
;
static
const
String
kPerformanceMeasurementFile
=
'performance-measurement-file'
;
static
const
String
kNullSafety
=
'sound-null-safety'
;
static
const
String
kNullSafety
=
'sound-null-safety'
;
static
const
String
kDeviceUser
=
'device-user'
;
static
const
String
kDeviceUser
=
'device-user'
;
static
const
String
kDeviceTimeout
=
'device-timeout'
;
static
const
String
kAnalyzeSize
=
'analyze-size'
;
static
const
String
kAnalyzeSize
=
'analyze-size'
;
static
const
String
kNullAssertions
=
'null-assertions'
;
static
const
String
kNullAssertions
=
'null-assertions'
;
}
}
...
@@ -404,6 +405,28 @@ abstract class FlutterCommand extends Command<void> {
...
@@ -404,6 +405,28 @@ abstract class FlutterCommand extends Command<void> {
valueHelp:
'10'
);
valueHelp:
'10'
);
}
}
void
usesDeviceTimeoutOption
()
{
argParser
.
addOption
(
FlutterOptions
.
kDeviceTimeout
,
help:
'Time in seconds to wait for devices to attach. Longer timeouts may be necessary for networked devices.'
,
valueHelp:
'10'
);
}
Duration
get
deviceDiscoveryTimeout
{
if
(
_deviceDiscoveryTimeout
==
null
&&
argResults
.
options
.
contains
(
FlutterOptions
.
kDeviceTimeout
)
&&
argResults
.
wasParsed
(
FlutterOptions
.
kDeviceTimeout
))
{
final
int
timeoutSeconds
=
int
.
tryParse
(
stringArg
(
FlutterOptions
.
kDeviceTimeout
));
if
(
timeoutSeconds
==
null
)
{
throwToolExit
(
'Could not parse --
${FlutterOptions.kDeviceTimeout}
argument. It must be an integer.'
);
}
_deviceDiscoveryTimeout
=
Duration
(
seconds:
timeoutSeconds
);
}
return
_deviceDiscoveryTimeout
;
}
Duration
_deviceDiscoveryTimeout
;
void
addBuildModeFlags
({
bool
defaultToRelease
=
true
,
bool
verboseHelp
=
false
,
bool
excludeDebug
=
false
})
{
void
addBuildModeFlags
({
bool
defaultToRelease
=
true
,
bool
verboseHelp
=
false
,
bool
excludeDebug
=
false
})
{
// A release build must be the default if a debug build is not possible.
// A release build must be the default if a debug build is not possible.
assert
(
defaultToRelease
||
!
excludeDebug
);
assert
(
defaultToRelease
||
!
excludeDebug
);
...
@@ -970,7 +993,7 @@ abstract class FlutterCommand extends Command<void> {
...
@@ -970,7 +993,7 @@ abstract class FlutterCommand extends Command<void> {
return
null
;
return
null
;
}
}
final
DeviceManager
deviceManager
=
globals
.
deviceManager
;
final
DeviceManager
deviceManager
=
globals
.
deviceManager
;
List
<
Device
>
devices
=
await
deviceManager
.
findTargetDevices
(
FlutterProject
.
current
());
List
<
Device
>
devices
=
await
deviceManager
.
findTargetDevices
(
FlutterProject
.
current
()
,
timeout:
deviceDiscoveryTimeout
);
if
(
devices
.
isEmpty
&&
deviceManager
.
hasSpecifiedDeviceId
)
{
if
(
devices
.
isEmpty
&&
deviceManager
.
hasSpecifiedDeviceId
)
{
globals
.
printStatus
(
userMessages
.
flutterNoMatchingDevice
(
deviceManager
.
specifiedDeviceId
));
globals
.
printStatus
(
userMessages
.
flutterNoMatchingDevice
(
deviceManager
.
specifiedDeviceId
));
...
...
packages/flutter_tools/test/commands.shard/hermetic/attach_test.dart
View file @
61751835
...
@@ -342,6 +342,8 @@ void main() {
...
@@ -342,6 +342,8 @@ void main() {
'-v'
,
'-v'
,
'--device-user'
,
'--device-user'
,
'10'
,
'10'
,
'--device-timeout'
,
'15'
,
]);
]);
final
VerificationResult
verificationResult
=
verify
(
final
VerificationResult
verificationResult
=
verify
(
mockHotRunnerFactory
.
build
(
mockHotRunnerFactory
.
build
(
...
...
packages/flutter_tools/test/commands.shard/hermetic/drive_test.dart
View file @
61751835
...
@@ -281,7 +281,7 @@ void main() {
...
@@ -281,7 +281,7 @@ void main() {
when
(
mockDevice
.
name
).
thenReturn
(
'specified-device'
);
when
(
mockDevice
.
name
).
thenReturn
(
'specified-device'
);
when
(
mockDevice
.
id
).
thenReturn
(
'123'
);
when
(
mockDevice
.
id
).
thenReturn
(
'123'
);
final
Device
device
=
await
findTargetDevice
();
final
Device
device
=
await
findTargetDevice
(
timeout:
null
);
expect
(
device
.
name
,
'specified-device'
);
expect
(
device
.
name
,
'specified-device'
);
},
overrides:
<
Type
,
Generator
>{
},
overrides:
<
Type
,
Generator
>{
FileSystem:
()
=>
fs
,
FileSystem:
()
=>
fs
,
...
@@ -293,7 +293,7 @@ void main() {
...
@@ -293,7 +293,7 @@ void main() {
Platform
platform
()
=>
FakePlatform
(
operatingSystem:
operatingSystem
);
Platform
platform
()
=>
FakePlatform
(
operatingSystem:
operatingSystem
);
testUsingContext
(
'returns null if no devices found'
,
()
async
{
testUsingContext
(
'returns null if no devices found'
,
()
async
{
expect
(
await
findTargetDevice
(),
isNull
);
expect
(
await
findTargetDevice
(
timeout:
null
),
isNull
);
},
overrides:
<
Type
,
Generator
>{
},
overrides:
<
Type
,
Generator
>{
FileSystem:
()
=>
fs
,
FileSystem:
()
=>
fs
,
ProcessManager:
()
=>
FakeProcessManager
.
any
(),
ProcessManager:
()
=>
FakeProcessManager
.
any
(),
...
@@ -305,7 +305,7 @@ void main() {
...
@@ -305,7 +305,7 @@ void main() {
when
(
mockDevice
.
name
).
thenReturn
(
'mock-android-device'
);
when
(
mockDevice
.
name
).
thenReturn
(
'mock-android-device'
);
testDeviceManager
.
addDevice
(
mockDevice
);
testDeviceManager
.
addDevice
(
mockDevice
);
final
Device
device
=
await
findTargetDevice
();
final
Device
device
=
await
findTargetDevice
(
timeout:
null
);
expect
(
device
.
name
,
'mock-android-device'
);
expect
(
device
.
name
,
'mock-android-device'
);
},
overrides:
<
Type
,
Generator
>{
},
overrides:
<
Type
,
Generator
>{
FileSystem:
()
=>
fs
,
FileSystem:
()
=>
fs
,
...
@@ -337,7 +337,7 @@ void main() {
...
@@ -337,7 +337,7 @@ void main() {
testDeviceManager
.
addDevice
(
mockDevice
);
testDeviceManager
.
addDevice
(
mockDevice
);
testDeviceManager
.
addDevice
(
mockUnsupportedDevice
);
testDeviceManager
.
addDevice
(
mockUnsupportedDevice
);
final
Device
device
=
await
findTargetDevice
();
final
Device
device
=
await
findTargetDevice
(
timeout:
null
);
expect
(
device
.
name
,
'mock-android-device'
);
expect
(
device
.
name
,
'mock-android-device'
);
},
overrides:
<
Type
,
Generator
>{
},
overrides:
<
Type
,
Generator
>{
FileSystem:
()
=>
fs
,
FileSystem:
()
=>
fs
,
...
@@ -366,7 +366,7 @@ void main() {
...
@@ -366,7 +366,7 @@ void main() {
when
(
mockDevice
.
isLocalEmulator
)
when
(
mockDevice
.
isLocalEmulator
)
.
thenAnswer
((
Invocation
invocation
)
=>
Future
<
bool
>.
value
(
true
));
.
thenAnswer
((
Invocation
invocation
)
=>
Future
<
bool
>.
value
(
true
));
final
Device
device
=
await
findTargetDevice
();
final
Device
device
=
await
findTargetDevice
(
timeout:
null
);
expect
(
device
.
name
,
'mock-simulator'
);
expect
(
device
.
name
,
'mock-simulator'
);
},
overrides:
<
Type
,
Generator
>{
},
overrides:
<
Type
,
Generator
>{
FileSystem:
()
=>
fs
,
FileSystem:
()
=>
fs
,
...
...
packages/flutter_tools/test/commands.shard/hermetic/run_test.dart
View file @
61751835
...
@@ -178,7 +178,7 @@ void main() {
...
@@ -178,7 +178,7 @@ void main() {
when
(
mockDeviceManager
.
getDevices
()).
thenAnswer
(
when
(
mockDeviceManager
.
getDevices
()).
thenAnswer
(
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(
noDevices
)
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(
noDevices
)
);
);
when
(
mockDeviceManager
.
findTargetDevices
(
any
)).
thenAnswer
(
when
(
mockDeviceManager
.
findTargetDevices
(
any
,
timeout:
anyNamed
(
'timeout'
)
)).
thenAnswer
(
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(
noDevices
)
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(
noDevices
)
);
);
...
@@ -214,7 +214,7 @@ void main() {
...
@@ -214,7 +214,7 @@ void main() {
when
(
mockDeviceManager
.
getDevices
()).
thenAnswer
((
Invocation
invocation
)
async
{
when
(
mockDeviceManager
.
getDevices
()).
thenAnswer
((
Invocation
invocation
)
async
{
return
<
Device
>[
device
];
return
<
Device
>[
device
];
});
});
when
(
mockDeviceManager
.
findTargetDevices
(
any
)).
thenAnswer
((
Invocation
invocation
)
async
{
when
(
mockDeviceManager
.
findTargetDevices
(
any
,
timeout:
anyNamed
(
'timeout'
)
)).
thenAnswer
((
Invocation
invocation
)
async
{
return
<
Device
>[
device
];
return
<
Device
>[
device
];
});
});
when
(
mockDeviceManager
.
hasSpecifiedAllDevices
).
thenReturn
(
false
);
when
(
mockDeviceManager
.
hasSpecifiedAllDevices
).
thenReturn
(
false
);
...
@@ -254,7 +254,7 @@ void main() {
...
@@ -254,7 +254,7 @@ void main() {
]);
]);
});
});
when
(
mockDeviceManager
.
findTargetDevices
(
any
)).
thenAnswer
(
when
(
mockDeviceManager
.
findTargetDevices
(
any
,
timeout:
anyNamed
(
'timeout'
)
)).
thenAnswer
(
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(<
Device
>[]),
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(<
Device
>[]),
);
);
...
@@ -301,7 +301,8 @@ void main() {
...
@@ -301,7 +301,8 @@ void main() {
);
);
// No devices are attached, we just want to verify update the cache
// No devices are attached, we just want to verify update the cache
// BEFORE checking for devices
// BEFORE checking for devices
when
(
mockDeviceManager
.
findTargetDevices
(
any
)).
thenAnswer
(
const
Duration
timeout
=
Duration
(
seconds:
10
);
when
(
mockDeviceManager
.
findTargetDevices
(
any
,
timeout:
timeout
)).
thenAnswer
(
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(<
Device
>[])
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(<
Device
>[])
);
);
...
@@ -309,6 +310,8 @@ void main() {
...
@@ -309,6 +310,8 @@ void main() {
await
createTestCommandRunner
(
command
).
run
(<
String
>[
await
createTestCommandRunner
(
command
).
run
(<
String
>[
'run'
,
'run'
,
'--no-pub'
,
'--no-pub'
,
'--device-timeout'
,
'10'
,
]);
]);
fail
(
'Exception expected'
);
fail
(
'Exception expected'
);
}
on
ToolExit
catch
(
e
)
{
}
on
ToolExit
catch
(
e
)
{
...
@@ -324,7 +327,7 @@ void main() {
...
@@ -324,7 +327,7 @@ void main() {
// as part of gathering `requiredArtifacts`
// as part of gathering `requiredArtifacts`
mockDeviceManager
.
getDevices
(),
mockDeviceManager
.
getDevices
(),
// in validateCommand()
// in validateCommand()
mockDeviceManager
.
findTargetDevices
(
any
),
mockDeviceManager
.
findTargetDevices
(
any
,
timeout:
anyNamed
(
'timeout'
)
),
]);
]);
},
overrides:
<
Type
,
Generator
>{
},
overrides:
<
Type
,
Generator
>{
ApplicationPackageFactory:
()
=>
mockApplicationPackageFactory
,
ApplicationPackageFactory:
()
=>
mockApplicationPackageFactory
,
...
@@ -365,7 +368,7 @@ void main() {
...
@@ -365,7 +368,7 @@ void main() {
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(<
Device
>[
mockDevice
])
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(<
Device
>[
mockDevice
])
);
);
when
(
mockDeviceManager
.
findTargetDevices
(
any
)).
thenAnswer
(
when
(
mockDeviceManager
.
findTargetDevices
(
any
,
timeout:
anyNamed
(
'timeout'
)
)).
thenAnswer
(
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(<
Device
>[
mockDevice
])
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(<
Device
>[
mockDevice
])
);
);
...
@@ -434,7 +437,7 @@ void main() {
...
@@ -434,7 +437,7 @@ void main() {
when
(
mockDeviceManager
.
getDevices
()).
thenAnswer
((
Invocation
invocation
)
{
when
(
mockDeviceManager
.
getDevices
()).
thenAnswer
((
Invocation
invocation
)
{
return
Future
<
List
<
Device
>>.
value
(<
Device
>[
fakeDevice
]);
return
Future
<
List
<
Device
>>.
value
(<
Device
>[
fakeDevice
]);
});
});
when
(
mockDeviceManager
.
findTargetDevices
(
any
)).
thenAnswer
(
when
(
mockDeviceManager
.
findTargetDevices
(
any
,
timeout:
anyNamed
(
'timeout'
)
)).
thenAnswer
(
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(<
Device
>[
fakeDevice
])
(
Invocation
invocation
)
=>
Future
<
List
<
Device
>>.
value
(<
Device
>[
fakeDevice
])
);
);
});
});
...
...
packages/flutter_tools/test/general.shard/device_test.dart
View file @
61751835
...
@@ -58,8 +58,10 @@ void main() {
...
@@ -58,8 +58,10 @@ void main() {
// 3. A device discoverer that succeeds.
// 3. A device discoverer that succeeds.
final
DeviceManager
deviceManager
=
TestDeviceManager
(
final
DeviceManager
deviceManager
=
TestDeviceManager
(
devices
,
devices
,
testLongPollingDeviceDiscovery:
true
,
deviceDiscoveryOverrides:
<
DeviceDiscovery
>[
testThrowingDeviceDiscovery:
true
,
ThrowingPollingDeviceDiscovery
(),
LongPollingDeviceDiscovery
(),
],
);
);
Future
<
void
>
expectDevice
(
String
id
,
List
<
Device
>
expected
)
async
{
Future
<
void
>
expectDevice
(
String
id
,
List
<
Device
>
expected
)
async
{
...
@@ -89,7 +91,9 @@ void main() {
...
@@ -89,7 +91,9 @@ void main() {
// 2. A device discoverer that succeeds.
// 2. A device discoverer that succeeds.
final
DeviceManager
deviceManager
=
TestDeviceManager
(
final
DeviceManager
deviceManager
=
TestDeviceManager
(
devices
,
devices
,
testThrowingDeviceDiscovery:
true
deviceDiscoveryOverrides:
<
DeviceDiscovery
>[
ThrowingPollingDeviceDiscovery
(),
],
);
);
Future
<
void
>
expectDevice
(
String
id
,
List
<
Device
>
expected
)
async
{
Future
<
void
>
expectDevice
(
String
id
,
List
<
Device
>
expected
)
async
{
...
@@ -387,7 +391,62 @@ void main() {
...
@@ -387,7 +391,62 @@ void main() {
Artifacts:
()
=>
Artifacts
.
test
(),
Artifacts:
()
=>
Artifacts
.
test
(),
Cache:
()
=>
cache
,
Cache:
()
=>
cache
,
});
});
testUsingContext
(
'does not refresh device cache without a timeout'
,
()
async
{
final
List
<
Device
>
devices
=
<
Device
>[
ephemeralOne
,
];
final
MockDeviceDiscovery
mockDeviceDiscovery
=
MockDeviceDiscovery
();
when
(
mockDeviceDiscovery
.
supportsPlatform
).
thenReturn
(
true
);
// when(mockDeviceDiscovery.discoverDevices(timeout: timeout)).thenAnswer((_) async => devices);
when
(
mockDeviceDiscovery
.
devices
).
thenAnswer
((
_
)
async
=>
devices
);
// when(mockDeviceDiscovery.discoverDevices(timeout: timeout)).thenAnswer((_) async => devices);
final
DeviceManager
deviceManager
=
TestDeviceManager
(<
Device
>[],
deviceDiscoveryOverrides:
<
DeviceDiscovery
>[
mockDeviceDiscovery
]);
deviceManager
.
specifiedDeviceId
=
ephemeralOne
.
id
;
final
List
<
Device
>
filtered
=
await
deviceManager
.
findTargetDevices
(
FlutterProject
.
current
(),
);
expect
(
filtered
.
single
,
ephemeralOne
);
verify
(
mockDeviceDiscovery
.
devices
).
called
(
1
);
verifyNever
(
mockDeviceDiscovery
.
discoverDevices
(
timeout:
anyNamed
(
'timeout'
)));
},
overrides:
<
Type
,
Generator
>{
Artifacts:
()
=>
Artifacts
.
test
(),
Cache:
()
=>
cache
,
});
testUsingContext
(
'refreshes device cache with a timeout'
,
()
async
{
final
List
<
Device
>
devices
=
<
Device
>[
ephemeralOne
,
];
const
Duration
timeout
=
Duration
(
seconds:
2
);
final
MockDeviceDiscovery
mockDeviceDiscovery
=
MockDeviceDiscovery
();
when
(
mockDeviceDiscovery
.
supportsPlatform
).
thenReturn
(
true
);
when
(
mockDeviceDiscovery
.
discoverDevices
(
timeout:
timeout
)).
thenAnswer
((
_
)
async
=>
devices
);
when
(
mockDeviceDiscovery
.
devices
).
thenAnswer
((
_
)
async
=>
devices
);
// when(mockDeviceDiscovery.discoverDevices(timeout: timeout)).thenAnswer((_) async => devices);
final
DeviceManager
deviceManager
=
TestDeviceManager
(<
Device
>[],
deviceDiscoveryOverrides:
<
DeviceDiscovery
>[
mockDeviceDiscovery
]);
deviceManager
.
specifiedDeviceId
=
ephemeralOne
.
id
;
final
List
<
Device
>
filtered
=
await
deviceManager
.
findTargetDevices
(
FlutterProject
.
current
(),
timeout:
timeout
,
);
expect
(
filtered
.
single
,
ephemeralOne
);
verify
(
mockDeviceDiscovery
.
devices
).
called
(
1
);
verify
(
mockDeviceDiscovery
.
discoverDevices
(
timeout:
anyNamed
(
'timeout'
))).
called
(
1
);
},
overrides:
<
Type
,
Generator
>{
Artifacts:
()
=>
Artifacts
.
test
(),
Cache:
()
=>
cache
,
});
});
});
group
(
'ForwardedPort'
,
()
{
group
(
'ForwardedPort'
,
()
{
group
(
'dispose()'
,
()
{
group
(
'dispose()'
,
()
{
testUsingContext
(
'does not throw exception if no process is present'
,
()
{
testUsingContext
(
'does not throw exception if no process is present'
,
()
{
...
@@ -427,16 +486,13 @@ void main() {
...
@@ -427,16 +486,13 @@ void main() {
class
TestDeviceManager
extends
DeviceManager
{
class
TestDeviceManager
extends
DeviceManager
{
TestDeviceManager
(
List
<
Device
>
allDevices
,
{
TestDeviceManager
(
List
<
Device
>
allDevices
,
{
bool
testLongPollingDeviceDiscovery
=
false
,
List
<
DeviceDiscovery
>
deviceDiscoveryOverrides
,
bool
testThrowingDeviceDiscovery
=
false
,
})
{
})
{
_fakeDeviceDiscoverer
=
FakePollingDeviceDiscovery
();
_fakeDeviceDiscoverer
=
FakePollingDeviceDiscovery
();
_deviceDiscoverers
=
<
DeviceDiscovery
>[
_deviceDiscoverers
=
<
DeviceDiscovery
>[
if
(
testLongPollingDeviceDiscovery
)
LongPollingDeviceDiscovery
(),
if
(
testThrowingDeviceDiscovery
)
ThrowingPollingDeviceDiscovery
(),
_fakeDeviceDiscoverer
,
_fakeDeviceDiscoverer
,
if
(
deviceDiscoveryOverrides
!=
null
)
...
deviceDiscoveryOverrides
];
];
resetDevices
(
allDevices
);
resetDevices
(
allDevices
);
}
}
...
@@ -464,3 +520,4 @@ class MockProcess extends Mock implements Process {}
...
@@ -464,3 +520,4 @@ class MockProcess extends Mock implements Process {}
class
MockTerminal
extends
Mock
implements
AnsiTerminal
{}
class
MockTerminal
extends
Mock
implements
AnsiTerminal
{}
class
MockStdio
extends
Mock
implements
Stdio
{}
class
MockStdio
extends
Mock
implements
Stdio
{}
class
MockCache
extends
Mock
implements
Cache
{}
class
MockCache
extends
Mock
implements
Cache
{}
class
MockDeviceDiscovery
extends
Mock
implements
DeviceDiscovery
{}
packages/flutter_tools/test/src/context.dart
View file @
61751835
...
@@ -248,7 +248,7 @@ class FakeDeviceManager implements DeviceManager {
...
@@ -248,7 +248,7 @@ class FakeDeviceManager implements DeviceManager {
}
}
@override
@override
Future
<
List
<
Device
>>
findTargetDevices
(
FlutterProject
flutterProject
)
async
{
Future
<
List
<
Device
>>
findTargetDevices
(
FlutterProject
flutterProject
,
{
Duration
timeout
}
)
async
{
return
devices
;
return
devices
;
}
}
}
}
...
...
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