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
efa47a6f
Commit
efa47a6f
authored
Feb 14, 2016
by
Devon Carew
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1874 from devoncarew/command_renames
rename list->devices, start->run
parents
aa41783a
cc72bbc7
Changes
13
Show whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
46 additions
and
35 deletions
+46
-35
executable.dart
packages/flutter_tools/lib/executable.dart
+7
-6
artifacts.dart
packages/flutter_tools/lib/src/artifacts.dart
+4
-4
apk.dart
packages/flutter_tools/lib/src/commands/apk.dart
+1
-1
cache.dart
packages/flutter_tools/lib/src/commands/cache.dart
+3
-0
daemon.dart
packages/flutter_tools/lib/src/commands/daemon.dart
+6
-2
devices.dart
packages/flutter_tools/lib/src/commands/devices.dart
+3
-2
ios.dart
packages/flutter_tools/lib/src/commands/ios.dart
+4
-3
listen.dart
packages/flutter_tools/lib/src/commands/listen.dart
+2
-2
run.dart
packages/flutter_tools/lib/src/commands/run.dart
+8
-7
run_mojo.dart
packages/flutter_tools/lib/src/commands/run_mojo.dart
+1
-1
test.dart
packages/flutter_tools/lib/src/commands/test.dart
+1
-1
flutter_command_runner.dart
.../flutter_tools/lib/src/runner/flutter_command_runner.dart
+2
-2
devices.test.dart
packages/flutter_tools/test/devices.test.dart
+4
-4
No files found.
packages/flutter_tools/lib/executable.dart
View file @
efa47a6f
...
@@ -17,14 +17,14 @@ import 'src/commands/build.dart';
...
@@ -17,14 +17,14 @@ import 'src/commands/build.dart';
import
'src/commands/cache.dart'
;
import
'src/commands/cache.dart'
;
import
'src/commands/create.dart'
;
import
'src/commands/create.dart'
;
import
'src/commands/daemon.dart'
;
import
'src/commands/daemon.dart'
;
import
'src/commands/devices.dart'
;
import
'src/commands/install.dart'
;
import
'src/commands/install.dart'
;
import
'src/commands/ios.dart'
;
import
'src/commands/ios.dart'
;
import
'src/commands/list.dart'
;
import
'src/commands/listen.dart'
;
import
'src/commands/listen.dart'
;
import
'src/commands/logs.dart'
;
import
'src/commands/logs.dart'
;
import
'src/commands/refresh.dart'
;
import
'src/commands/refresh.dart'
;
import
'src/commands/run.dart'
;
import
'src/commands/run_mojo.dart'
;
import
'src/commands/run_mojo.dart'
;
import
'src/commands/start.dart'
;
import
'src/commands/stop.dart'
;
import
'src/commands/stop.dart'
;
import
'src/commands/test.dart'
;
import
'src/commands/test.dart'
;
import
'src/commands/trace.dart'
;
import
'src/commands/trace.dart'
;
...
@@ -38,22 +38,23 @@ import 'src/runner/flutter_command_runner.dart';
...
@@ -38,22 +38,23 @@ import 'src/runner/flutter_command_runner.dart';
Future
main
(
List
<
String
>
args
)
async
{
Future
main
(
List
<
String
>
args
)
async
{
bool
help
=
args
.
contains
(
'-h'
)
||
args
.
contains
(
'--help'
);
bool
help
=
args
.
contains
(
'-h'
)
||
args
.
contains
(
'--help'
);
bool
verbose
=
args
.
contains
(
'-v'
)
||
args
.
contains
(
'--verbose'
);
bool
verbose
=
args
.
contains
(
'-v'
)
||
args
.
contains
(
'--verbose'
);
bool
verboseHelp
=
help
&&
verbose
;
FlutterCommandRunner
runner
=
new
FlutterCommandRunner
(
verboseHelp:
help
&&
verbose
)
FlutterCommandRunner
runner
=
new
FlutterCommandRunner
(
verboseHelp:
verboseHelp
)
..
addCommand
(
new
AnalyzeCommand
())
..
addCommand
(
new
AnalyzeCommand
())
..
addCommand
(
new
ApkCommand
())
..
addCommand
(
new
ApkCommand
())
..
addCommand
(
new
BuildCommand
())
..
addCommand
(
new
BuildCommand
())
..
addCommand
(
new
CacheCommand
())
..
addCommand
(
new
CacheCommand
())
..
addCommand
(
new
CreateCommand
())
..
addCommand
(
new
CreateCommand
())
..
addCommand
(
new
DaemonCommand
())
..
addCommand
(
new
DaemonCommand
(
hideCommand:
!
verboseHelp
))
..
addCommand
(
new
DevicesCommand
())
..
addCommand
(
new
InstallCommand
())
..
addCommand
(
new
InstallCommand
())
..
addCommand
(
new
IOSCommand
())
..
addCommand
(
new
IOSCommand
())
..
addCommand
(
new
ListCommand
())
..
addCommand
(
new
ListenCommand
())
..
addCommand
(
new
ListenCommand
())
..
addCommand
(
new
LogsCommand
())
..
addCommand
(
new
LogsCommand
())
..
addCommand
(
new
RefreshCommand
())
..
addCommand
(
new
RefreshCommand
())
..
addCommand
(
new
RunCommand
())
..
addCommand
(
new
RunMojoCommand
())
..
addCommand
(
new
RunMojoCommand
())
..
addCommand
(
new
StartCommand
())
..
addCommand
(
new
StopCommand
())
..
addCommand
(
new
StopCommand
())
..
addCommand
(
new
TestCommand
())
..
addCommand
(
new
TestCommand
())
..
addCommand
(
new
TraceCommand
())
..
addCommand
(
new
TraceCommand
())
...
...
packages/flutter_tools/lib/src/artifacts.dart
View file @
efa47a6f
...
@@ -306,7 +306,7 @@ class ArtifactStore {
...
@@ -306,7 +306,7 @@ class ArtifactStore {
static
final
Map
<
String
,
Future
>
_pendingZipDownloads
=
new
Map
<
String
,
Future
>();
static
final
Map
<
String
,
Future
>
_pendingZipDownloads
=
new
Map
<
String
,
Future
>();
static
Directory
_
getBaseCacheDir
()
{
static
Directory
getBaseCacheDir
()
{
if
(
flutterRoot
==
null
)
{
if
(
flutterRoot
==
null
)
{
printError
(
'FLUTTER_ROOT not specified. Cannot find artifact cache.'
);
printError
(
'FLUTTER_ROOT not specified. Cannot find artifact cache.'
);
throw
new
ProcessExit
(
2
);
throw
new
ProcessExit
(
2
);
...
@@ -319,7 +319,7 @@ class ArtifactStore {
...
@@ -319,7 +319,7 @@ class ArtifactStore {
static
Directory
_getCacheDirForPlatform
(
String
platform
)
{
static
Directory
_getCacheDirForPlatform
(
String
platform
)
{
validateSkyEnginePackage
();
validateSkyEnginePackage
();
Directory
baseDir
=
_
getBaseCacheDir
();
Directory
baseDir
=
getBaseCacheDir
();
// TODO(jamesr): Add support for more configurations.
// TODO(jamesr): Add support for more configurations.
String
config
=
'Release'
;
String
config
=
'Release'
;
Directory
artifactSpecificDir
=
new
Directory
(
path
.
join
(
Directory
artifactSpecificDir
=
new
Directory
(
path
.
join
(
...
@@ -344,7 +344,7 @@ class ArtifactStore {
...
@@ -344,7 +344,7 @@ class ArtifactStore {
static
Future
<
String
>
getThirdPartyFile
(
String
urlStr
,
String
cacheSubdir
,
bool
unzip
)
async
{
static
Future
<
String
>
getThirdPartyFile
(
String
urlStr
,
String
cacheSubdir
,
bool
unzip
)
async
{
Uri
url
=
Uri
.
parse
(
urlStr
);
Uri
url
=
Uri
.
parse
(
urlStr
);
Directory
baseDir
=
_
getBaseCacheDir
();
Directory
baseDir
=
getBaseCacheDir
();
Directory
cacheDir
=
new
Directory
(
path
.
join
(
Directory
cacheDir
=
new
Directory
(
path
.
join
(
baseDir
.
path
,
'third_party'
,
cacheSubdir
));
baseDir
.
path
,
'third_party'
,
cacheSubdir
));
File
cachedFile
=
new
File
(
File
cachedFile
=
new
File
(
...
@@ -361,7 +361,7 @@ class ArtifactStore {
...
@@ -361,7 +361,7 @@ class ArtifactStore {
}
}
static
void
clear
()
{
static
void
clear
()
{
Directory
cacheDir
=
_
getBaseCacheDir
();
Directory
cacheDir
=
getBaseCacheDir
();
printTrace
(
'Clearing cache directory
${cacheDir.path}
'
);
printTrace
(
'Clearing cache directory
${cacheDir.path}
'
);
cacheDir
.
deleteSync
(
recursive:
true
);
cacheDir
.
deleteSync
(
recursive:
true
);
}
}
...
...
packages/flutter_tools/lib/src/commands/apk.dart
View file @
efa47a6f
...
@@ -20,7 +20,7 @@ import '../flx.dart' as flx;
...
@@ -20,7 +20,7 @@ import '../flx.dart' as flx;
import
'../runner/flutter_command.dart'
;
import
'../runner/flutter_command.dart'
;
import
'../services.dart'
;
import
'../services.dart'
;
import
'../toolchain.dart'
;
import
'../toolchain.dart'
;
import
'
start
.dart'
;
import
'
run
.dart'
;
const
String
_kDefaultAndroidManifestPath
=
'android/AndroidManifest.xml'
;
const
String
_kDefaultAndroidManifestPath
=
'android/AndroidManifest.xml'
;
const
String
_kDefaultOutputPath
=
'build/app.apk'
;
const
String
_kDefaultOutputPath
=
'build/app.apk'
;
...
...
packages/flutter_tools/lib/src/commands/cache.dart
View file @
efa47a6f
...
@@ -7,10 +7,12 @@ import 'dart:async';
...
@@ -7,10 +7,12 @@ import 'dart:async';
import
'package:args/command_runner.dart'
;
import
'package:args/command_runner.dart'
;
import
'../artifacts.dart'
;
import
'../artifacts.dart'
;
import
'../base/globals.dart'
;
class
CacheCommand
extends
Command
{
class
CacheCommand
extends
Command
{
final
String
name
=
'cache'
;
final
String
name
=
'cache'
;
final
String
description
=
'Manages Flutter
\'
s cache of binary artifacts.'
;
final
String
description
=
'Manages Flutter
\'
s cache of binary artifacts.'
;
CacheCommand
()
{
CacheCommand
()
{
addSubcommand
(
new
_ClearCommand
());
addSubcommand
(
new
_ClearCommand
());
addSubcommand
(
new
_PopulateCommand
());
addSubcommand
(
new
_PopulateCommand
());
...
@@ -24,6 +26,7 @@ class _ClearCommand extends Command {
...
@@ -24,6 +26,7 @@ class _ClearCommand extends Command {
@override
@override
Future
<
int
>
run
()
async
{
Future
<
int
>
run
()
async
{
await
ArtifactStore
.
clear
();
await
ArtifactStore
.
clear
();
printStatus
(
'Cleared cache directory
${ArtifactStore.getBaseCacheDir().path}
.'
);
return
0
;
return
0
;
}
}
}
}
...
...
packages/flutter_tools/lib/src/commands/daemon.dart
View file @
efa47a6f
...
@@ -16,7 +16,7 @@ import '../device.dart';
...
@@ -16,7 +16,7 @@ import '../device.dart';
import
'../ios/device_ios.dart'
;
import
'../ios/device_ios.dart'
;
import
'../ios/simulator.dart'
;
import
'../ios/simulator.dart'
;
import
'../runner/flutter_command.dart'
;
import
'../runner/flutter_command.dart'
;
import
'
start
.dart'
;
import
'
run
.dart'
;
import
'stop.dart'
as
stop
;
import
'stop.dart'
as
stop
;
const
String
protocolVersion
=
'0.1.0'
;
const
String
protocolVersion
=
'0.1.0'
;
...
@@ -28,11 +28,16 @@ const String protocolVersion = '0.1.0';
...
@@ -28,11 +28,16 @@ const String protocolVersion = '0.1.0';
/// It can be shutdown with a `daemon.shutdown` command (or by killing the
/// It can be shutdown with a `daemon.shutdown` command (or by killing the
/// process).
/// process).
class
DaemonCommand
extends
FlutterCommand
{
class
DaemonCommand
extends
FlutterCommand
{
DaemonCommand
({
this
.
hideCommand
:
false
});
final
String
name
=
'daemon'
;
final
String
name
=
'daemon'
;
final
String
description
=
'Run a persistent, JSON-RPC based server to communicate with devices.'
;
final
String
description
=
'Run a persistent, JSON-RPC based server to communicate with devices.'
;
final
bool
hideCommand
;
bool
get
requiresProjectRoot
=>
false
;
bool
get
requiresProjectRoot
=>
false
;
bool
get
hidden
=>
hideCommand
;
Future
<
int
>
runInProject
()
{
Future
<
int
>
runInProject
()
{
printStatus
(
'Starting device daemon...'
);
printStatus
(
'Starting device daemon...'
);
...
@@ -246,7 +251,6 @@ class AppDomain extends Domain {
...
@@ -246,7 +251,6 @@ class AppDomain extends Domain {
// command. This would have race conditions with other commands happening in
// command. This would have race conditions with other commands happening in
// parallel and doesn't play well with the caching built into `FlutterCommand`.
// parallel and doesn't play well with the caching built into `FlutterCommand`.
// TODO(devoncarew): Make flutter_tools work better with commands run from any directory.
// TODO(devoncarew): Make flutter_tools work better with commands run from any directory.
// TODO(devoncarew): Use less (or more explicit) caching.
Directory
cwd
=
Directory
.
current
;
Directory
cwd
=
Directory
.
current
;
Directory
.
current
=
new
Directory
(
projectDirectory
);
Directory
.
current
=
new
Directory
(
projectDirectory
);
...
...
packages/flutter_tools/lib/src/commands/
list
.dart
→
packages/flutter_tools/lib/src/commands/
devices
.dart
View file @
efa47a6f
...
@@ -8,9 +8,10 @@ import '../base/globals.dart';
...
@@ -8,9 +8,10 @@ import '../base/globals.dart';
import
'../device.dart'
;
import
'../device.dart'
;
import
'../runner/flutter_command.dart'
;
import
'../runner/flutter_command.dart'
;
class
List
Command
extends
FlutterCommand
{
class
Devices
Command
extends
FlutterCommand
{
final
String
name
=
'
list
'
;
final
String
name
=
'
devices
'
;
final
String
description
=
'List all connected devices.'
;
final
String
description
=
'List all connected devices.'
;
final
List
<
String
>
aliases
=
<
String
>[
'list'
];
bool
get
requiresProjectRoot
=>
false
;
bool
get
requiresProjectRoot
=>
false
;
...
...
packages/flutter_tools/lib/src/commands/ios.dart
View file @
efa47a6f
...
@@ -115,7 +115,7 @@ class IOSCommand extends FlutterCommand {
...
@@ -115,7 +115,7 @@ class IOSCommand extends FlutterCommand {
void
_setupXcodeProjXcconfig
(
String
filePath
)
{
void
_setupXcodeProjXcconfig
(
String
filePath
)
{
StringBuffer
localsBuffer
=
new
StringBuffer
();
StringBuffer
localsBuffer
=
new
StringBuffer
();
localsBuffer
.
writeln
(
"//
Generated. Do not edit or check into version control!
"
);
localsBuffer
.
writeln
(
"//
This is a generated file; do not edit or check into version control.
"
);
localsBuffer
.
writeln
(
"// Recreate using `flutter ios --init`."
);
localsBuffer
.
writeln
(
"// Recreate using `flutter ios --init`."
);
String
flutterRoot
=
path
.
normalize
(
Platform
.
environment
[
kFlutterRootEnvironmentVariableName
]);
String
flutterRoot
=
path
.
normalize
(
Platform
.
environment
[
kFlutterRootEnvironmentVariableName
]);
...
@@ -164,8 +164,9 @@ class IOSCommand extends FlutterCommand {
...
@@ -164,8 +164,9 @@ class IOSCommand extends FlutterCommand {
revisionFile
.
writeAsStringSync
(
ArtifactStore
.
engineRevision
);
revisionFile
.
writeAsStringSync
(
ArtifactStore
.
engineRevision
);
// Step 6: Tell the user the location of the generated project.
// Step 6: Tell the user the location of the generated project.
printStatus
(
"An Xcode project has been placed in 'ios/'."
);
printStatus
(
"Xcode project created at
$xcodeprojPath
/."
);
printStatus
(
"You may edit it to modify iOS specific configuration."
);
printStatus
(
"User editable settings are in
$iosFilesPath
/."
);
return
0
;
return
0
;
}
}
...
...
packages/flutter_tools/lib/src/commands/listen.dart
View file @
efa47a6f
...
@@ -7,9 +7,9 @@ import 'dart:io';
...
@@ -7,9 +7,9 @@ import 'dart:io';
import
'../base/globals.dart'
;
import
'../base/globals.dart'
;
import
'../base/process.dart'
;
import
'../base/process.dart'
;
import
'
start
.dart'
;
import
'
run
.dart'
;
class
ListenCommand
extends
Start
CommandBase
{
class
ListenCommand
extends
Run
CommandBase
{
final
String
name
=
'listen'
;
final
String
name
=
'listen'
;
final
String
description
=
final
String
description
=
'Listen for changes to files and reload the running app (Android only).'
;
'Listen for changes to files and reload the running app (Android only).'
;
...
...
packages/flutter_tools/lib/src/commands/
start
.dart
→
packages/flutter_tools/lib/src/commands/
run
.dart
View file @
efa47a6f
...
@@ -32,8 +32,8 @@ String findMainDartFile([String target]) {
...
@@ -32,8 +32,8 @@ String findMainDartFile([String target]) {
}
}
}
}
abstract
class
Start
CommandBase
extends
FlutterCommand
{
abstract
class
Run
CommandBase
extends
FlutterCommand
{
Start
CommandBase
()
{
Run
CommandBase
()
{
argParser
.
addFlag
(
'checked'
,
argParser
.
addFlag
(
'checked'
,
negatable:
true
,
negatable:
true
,
defaultsTo:
true
,
defaultsTo:
true
,
...
@@ -51,12 +51,13 @@ abstract class StartCommandBase extends FlutterCommand {
...
@@ -51,12 +51,13 @@ abstract class StartCommandBase extends FlutterCommand {
}
}
}
}
class
StartCommand
extends
StartCommandBase
{
class
RunCommand
extends
RunCommandBase
{
final
String
name
=
'start'
;
final
String
name
=
'run'
;
final
String
description
=
'Start your Flutter app on an attached device '
final
String
description
=
'(defaults to checked/debug mode).'
;
'Run your Flutter app on an attached device (defaults to checked/debug mode).'
;
final
List
<
String
>
aliases
=
<
String
>[
'start'
];
Start
Command
()
{
Run
Command
()
{
argParser
.
addFlag
(
'full-restart'
,
argParser
.
addFlag
(
'full-restart'
,
defaultsTo:
true
,
defaultsTo:
true
,
help:
'Stop any currently running application process before starting the app.'
);
help:
'Stop any currently running application process before starting the app.'
);
...
...
packages/flutter_tools/lib/src/commands/run_mojo.dart
View file @
efa47a6f
...
@@ -13,7 +13,7 @@ import '../base/process.dart';
...
@@ -13,7 +13,7 @@ import '../base/process.dart';
import
'../build_configuration.dart'
;
import
'../build_configuration.dart'
;
import
'../flx.dart'
as
flx
;
import
'../flx.dart'
as
flx
;
import
'../runner/flutter_command.dart'
;
import
'../runner/flutter_command.dart'
;
import
'
start
.dart'
;
import
'
run
.dart'
;
const
String
_kDefaultBundlePath
=
'build/app.flx'
;
const
String
_kDefaultBundlePath
=
'build/app.flx'
;
...
...
packages/flutter_tools/lib/src/commands/test.dart
View file @
efa47a6f
...
@@ -16,7 +16,7 @@ import '../test/loader.dart' as loader;
...
@@ -16,7 +16,7 @@ import '../test/loader.dart' as loader;
class
TestCommand
extends
FlutterCommand
{
class
TestCommand
extends
FlutterCommand
{
String
get
name
=>
'test'
;
String
get
name
=>
'test'
;
String
get
description
=>
'Runs Flutter unit tests for the current project.'
;
String
get
description
=>
'Runs Flutter unit tests for the current project
(Linux only)
.'
;
bool
get
requiresProjectRoot
=>
false
;
bool
get
requiresProjectRoot
=>
false
;
...
...
packages/flutter_tools/lib/src/runner/flutter_command_runner.dart
View file @
efa47a6f
...
@@ -47,8 +47,8 @@ class FlutterCommandRunner extends CommandRunner {
...
@@ -47,8 +47,8 @@ class FlutterCommandRunner extends CommandRunner {
argParser
.
addOption
(
'package-root'
,
argParser
.
addOption
(
'package-root'
,
help:
'Path to your packages directory.
$packagesHelp
'
);
help:
'Path to your packages directory.
$packagesHelp
'
);
argParser
.
addOption
(
'flutter-root'
,
argParser
.
addOption
(
'flutter-root'
,
help:
'The root directory of the Flutter repository.
Defaults to
\$
$kFlutterRootEnvironmentVariableName
if
\n
'
help:
'The root directory of the Flutter repository.
Uses
\$
$kFlutterRootEnvironmentVariableName
if set,
\n
'
'
set,
otherwise defaults to a value derived from the location of this tool.'
,
defaultsTo:
_defaultFlutterRoot
);
'otherwise defaults to a value derived from the location of this tool.'
,
defaultsTo:
_defaultFlutterRoot
);
if
(
verboseHelp
)
if
(
verboseHelp
)
argParser
.
addSeparator
(
'Local build selection options (not normally required):'
);
argParser
.
addSeparator
(
'Local build selection options (not normally required):'
);
...
...
packages/flutter_tools/test/
list_
test.dart
→
packages/flutter_tools/test/
devices.
test.dart
View file @
efa47a6f
...
@@ -3,7 +3,7 @@
...
@@ -3,7 +3,7 @@
// found in the LICENSE file.
// found in the LICENSE file.
import
'package:flutter_tools/src/android/android_sdk.dart'
;
import
'package:flutter_tools/src/android/android_sdk.dart'
;
import
'package:flutter_tools/src/commands/
list
.dart'
;
import
'package:flutter_tools/src/commands/
devices
.dart'
;
import
'package:flutter_tools/src/device.dart'
;
import
'package:flutter_tools/src/device.dart'
;
import
'package:test/test.dart'
;
import
'package:test/test.dart'
;
...
@@ -13,16 +13,16 @@ import 'src/context.dart';
...
@@ -13,16 +13,16 @@ import 'src/context.dart';
main
()
=>
defineTests
();
main
()
=>
defineTests
();
defineTests
()
{
defineTests
()
{
group
(
'
list
'
,
()
{
group
(
'
devices
'
,
()
{
testUsingContext
(
'returns 0 when called'
,
()
{
testUsingContext
(
'returns 0 when called'
,
()
{
ListCommand
command
=
new
List
Command
();
DevicesCommand
command
=
new
Devices
Command
();
return
createTestCommandRunner
(
command
).
run
([
'list'
]).
then
((
int
code
)
{
return
createTestCommandRunner
(
command
).
run
([
'list'
]).
then
((
int
code
)
{
expect
(
code
,
equals
(
0
));
expect
(
code
,
equals
(
0
));
});
});
});
});
testUsingContext
(
'no error when no connected devices'
,
()
{
testUsingContext
(
'no error when no connected devices'
,
()
{
ListCommand
command
=
new
List
Command
();
DevicesCommand
command
=
new
Devices
Command
();
return
createTestCommandRunner
(
command
).
run
([
'list'
]).
then
((
int
code
)
{
return
createTestCommandRunner
(
command
).
run
([
'list'
]).
then
((
int
code
)
{
expect
(
code
,
equals
(
0
));
expect
(
code
,
equals
(
0
));
expect
(
testLogger
.
statusText
,
contains
(
'No connected devices'
));
expect
(
testLogger
.
statusText
,
contains
(
'No connected 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