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
c5800fe1
Unverified
Commit
c5800fe1
authored
Mar 27, 2020
by
Jonah Williams
Committed by
GitHub
Mar 27, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[flutter_tools] update iOS deploy tests for best practices (#53343)
parent
8afc67f7
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
65 additions
and
140 deletions
+65
-140
devices_test.dart
...es/flutter_tools/test/general.shard/ios/devices_test.dart
+0
-54
ios_deploy_test.dart
...flutter_tools/test/general.shard/ios/ios_deploy_test.dart
+65
-86
No files found.
packages/flutter_tools/test/general.shard/ios/devices_test.dart
View file @
c5800fe1
...
@@ -176,60 +176,6 @@ void main() {
...
@@ -176,60 +176,6 @@ void main() {
});
});
}
}
group
(
'ios-deploy wrappers'
,
()
{
const
String
appId
=
'789'
;
const
String
deviceId
=
'device-123'
;
IOSDevice
device
;
IOSDeploy
iosDeploy
;
FakeProcessManager
fakeProcessManager
;
const
String
iosDeployPath
=
'/path/to/ios-deploy'
;
setUp
(()
{
when
(
mockArtifacts
.
getArtifactPath
(
Artifact
.
iosDeploy
,
platform:
TargetPlatform
.
ios
))
.
thenReturn
(
iosDeployPath
);
});
testWithoutContext
(
'isAppInstalled() catches ProcessException from ios-deploy'
,
()
async
{
final
MockIOSApp
mockApp
=
MockIOSApp
();
when
(
mockApp
.
id
).
thenReturn
(
appId
);
fakeProcessManager
=
FakeProcessManager
.
list
(<
FakeCommand
>[
FakeCommand
(
command:
const
<
String
>[
iosDeployPath
,
'--id'
,
deviceId
,
'--exists'
,
'--bundle_id'
,
appId
,
],
onRun:
()
=>
throw
const
ProcessException
(
'ios-deploy'
,
<
String
>[]),
)
]);
iosDeploy
=
IOSDeploy
(
artifacts:
mockArtifacts
,
cache:
mockCache
,
logger:
logger
,
platform:
macPlatform
,
processManager:
fakeProcessManager
,
);
device
=
IOSDevice
(
deviceId
,
artifacts:
mockArtifacts
,
fileSystem:
mockFileSystem
,
logger:
logger
,
platform:
macPlatform
,
iosDeploy:
iosDeploy
,
iMobileDevice:
iMobileDevice
,
name:
'iPhone 1'
,
sdkVersion:
'13.3'
,
cpuArchitecture:
DarwinArch
.
arm64
,
);
final
bool
result
=
await
device
.
isAppInstalled
(
mockApp
);
expect
(
result
,
false
);
});
});
group
(
'.dispose()'
,
()
{
group
(
'.dispose()'
,
()
{
IOSDevice
device
;
IOSDevice
device
;
MockIOSApp
appPackage1
;
MockIOSApp
appPackage1
;
...
...
packages/flutter_tools/test/general.shard/ios/ios_deploy_test.dart
View file @
c5800fe1
...
@@ -2,11 +2,8 @@
...
@@ -2,11 +2,8 @@
// Use of this source code is governed by a BSD-style license that can be
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// found in the LICENSE file.
import
'dart:io'
show
Process
;
import
'package:flutter_tools/src/artifacts.dart'
;
import
'package:flutter_tools/src/artifacts.dart'
;
import
'package:flutter_tools/src/base/logger.dart'
;
import
'package:flutter_tools/src/base/logger.dart'
;
import
'package:flutter_tools/src/build_info.dart'
;
import
'package:flutter_tools/src/cache.dart'
;
import
'package:flutter_tools/src/cache.dart'
;
import
'package:flutter_tools/src/ios/ios_deploy.dart'
;
import
'package:flutter_tools/src/ios/ios_deploy.dart'
;
import
'package:mockito/mockito.dart'
;
import
'package:mockito/mockito.dart'
;
...
@@ -14,105 +11,87 @@ import 'package:platform/platform.dart';
...
@@ -14,105 +11,87 @@ import 'package:platform/platform.dart';
import
'package:process/process.dart'
;
import
'package:process/process.dart'
;
import
'../../src/common.dart'
;
import
'../../src/common.dart'
;
import
'../../src/mocks.dart'
;
import
'../../src/context.dart'
;
class
MockArtifacts
extends
Mock
implements
Artifacts
{}
class
MockCache
extends
Mock
implements
Cache
{}
class
MockPlatform
extends
Mock
implements
Platform
{}
class
MockProcess
extends
Mock
implements
Process
{}
class
MockProcessManager
extends
Mock
implements
ProcessManager
{}
void
main
(
)
{
void
main
(
)
{
group
(
'IOSDeploy()'
,
()
{
testWithoutContext
(
'IOSDeploy.iosDeployEnv returns path with /usr/bin first'
,
()
{
Artifacts
mockArtifacts
;
final
IOSDeploy
iosDeploy
=
setUpIOSDeploy
(
FakeProcessManager
.
any
());
Cache
mockCache
;
final
Map
<
String
,
String
>
environment
=
iosDeploy
.
iosDeployEnv
;
IOSDeploy
iosDeploy
;
Logger
logger
;
Platform
mockPlatform
;
ProcessManager
mockProcessManager
;
const
String
iosDeployPath
=
'/path/to/ios-deploy'
;
const
String
deviceId
=
'123'
;
const
String
bundleId
=
'com.example.app'
;
setUp
(()
{
mockArtifacts
=
MockArtifacts
();
when
(
mockArtifacts
.
getArtifactPath
(
Artifact
.
iosDeploy
,
platform:
TargetPlatform
.
ios
))
.
thenReturn
(
iosDeployPath
);
mockCache
=
MockCache
();
const
MapEntry
<
String
,
String
>
mapEntry
=
MapEntry
<
String
,
String
>(
'DYLD_LIBRARY_PATH'
,
'/path/to/libs'
);
when
(
mockCache
.
dyLdLibEntry
).
thenReturn
(
mapEntry
);
logger
=
BufferLogger
.
test
();
mockPlatform
=
MockPlatform
();
when
(
mockPlatform
.
environment
).
thenReturn
(<
String
,
String
>{
'PATH'
:
'/usr/local/bin:/usr/bin'
,
});
mockProcessManager
=
MockProcessManager
();
iosDeploy
=
IOSDeploy
(
artifacts:
mockArtifacts
,
cache:
mockCache
,
logger:
logger
,
platform:
mockPlatform
,
processManager:
mockProcessManager
,
);
});
testWithoutContext
(
'iosDeployEnv returns path with /usr/bin first'
,
()
{
expect
(
environment
[
'PATH'
],
startsWith
(
'/usr/bin'
));
final
Map
<
String
,
String
>
env
=
iosDeploy
.
iosDeployEnv
;
});
expect
(
env
[
'PATH'
].
startsWith
(
'/usr/bin'
),
true
);
});
testWithoutContext
(
'uninstallApp() calls ios-deploy with correct arguments and returns 0 on success'
,
()
async
{
testWithoutContext
(
'IOSDeploy.uninstallApp calls ios-deploy with correct arguments and returns 0 on success'
,
()
async
{
final
List
<
String
>
args
=
<
String
>[
const
String
deviceId
=
'123'
;
iosDeployPath
,
const
String
bundleId
=
'com.example.app'
;
final
FakeProcessManager
processManager
=
FakeProcessManager
.
list
(<
FakeCommand
>[
const
FakeCommand
(
command:
<
String
>[
'ios-deploy'
,
'--id'
,
'--id'
,
deviceId
,
deviceId
,
'--uninstall_only'
,
'--uninstall_only'
,
'--bundle_id'
,
'--bundle_id'
,
bundleId
,
bundleId
,
];
])
when
(
mockProcessManager
.
start
(
]);
args
,
final
IOSDeploy
iosDeploy
=
setUpIOSDeploy
(
processManager
);
workingDirectory:
anyNamed
(
'workingDirectory'
),
final
int
exitCode
=
await
iosDeploy
.
uninstallApp
(
environment:
anyNamed
(
'environment'
),
deviceId:
deviceId
,
)).
thenAnswer
((
Invocation
invocation
)
=>
Future
<
Process
>.
value
(
createMockProcess
(
exitCode:
0
)));
bundleId:
bundleId
,
final
int
exitCode
=
await
iosDeploy
.
uninstallApp
(
);
deviceId:
deviceId
,
bundleId:
bundleId
,
);
verify
(
mockProcessManager
.
start
(
expect
(
exitCode
,
0
);
args
,
expect
(
processManager
.
hasRemainingExpectations
,
false
);
workingDirectory:
anyNamed
(
'workingDirectory'
),
});
environment:
anyNamed
(
'environment'
),
));
expect
(
exitCode
,
0
);
});
testWithoutContext
(
'uninstallApp() returns non-zero exit code when ios-deploy does the same'
,
()
async
{
testWithoutContext
(
'IOSDeploy.uninstallApp returns non-zero exit code when ios-deploy does the same'
,
()
async
{
final
List
<
String
>
args
=
<
String
>[
const
String
deviceId
=
'123'
;
iosDeployPath
,
const
String
bundleId
=
'com.example.app'
;
final
FakeProcessManager
processManager
=
FakeProcessManager
.
list
(<
FakeCommand
>[
const
FakeCommand
(
command:
<
String
>[
'ios-deploy'
,
'--id'
,
'--id'
,
deviceId
,
deviceId
,
'--uninstall_only'
,
'--uninstall_only'
,
'--bundle_id'
,
'--bundle_id'
,
bundleId
,
bundleId
,
];
],
exitCode:
1
)
when
(
mockProcessManager
.
start
(
]);
args
,
final
IOSDeploy
iosDeploy
=
setUpIOSDeploy
(
processManager
);
workingDirectory:
anyNamed
(
'workingDirectory'
),
final
int
exitCode
=
await
iosDeploy
.
uninstallApp
(
environment:
anyNamed
(
'environment'
),
deviceId:
deviceId
,
)).
thenAnswer
((
Invocation
invocation
)
=>
Future
<
Process
>.
value
(
createMockProcess
(
exitCode:
1
)));
bundleId:
bundleId
,
final
int
exitCode
=
await
iosDeploy
.
uninstallApp
(
);
deviceId:
deviceId
,
bundleId:
bundleId
,
);
verify
(
mockProcessManager
.
start
(
expect
(
exitCode
,
1
);
args
,
expect
(
processManager
.
hasRemainingExpectations
,
false
);
workingDirectory:
anyNamed
(
'workingDirectory'
),
environment:
anyNamed
(
'environment'
),
));
expect
(
exitCode
,
1
);
});
});
});
}
}
IOSDeploy
setUpIOSDeploy
(
ProcessManager
processManager
)
{
const
MapEntry
<
String
,
String
>
kDyLdLibEntry
=
MapEntry
<
String
,
String
>(
'DYLD_LIBRARY_PATH'
,
'/path/to/libs'
,
);
final
FakePlatform
macPlatform
=
FakePlatform
(
operatingSystem:
'macos'
,
environment:
<
String
,
String
>{
'PATH'
:
'/usr/local/bin:/usr/bin'
}
);
final
MockArtifacts
artifacts
=
MockArtifacts
();
final
MockCache
cache
=
MockCache
();
when
(
cache
.
dyLdLibEntry
).
thenReturn
(
kDyLdLibEntry
);
when
(
artifacts
.
getArtifactPath
(
Artifact
.
iosDeploy
,
platform:
anyNamed
(
'platform'
)))
.
thenReturn
(
'ios-deploy'
);
return
IOSDeploy
(
logger:
BufferLogger
.
test
(),
platform:
macPlatform
,
processManager:
processManager
,
artifacts:
artifacts
,
cache:
cache
,
);
}
class
MockArtifacts
extends
Mock
implements
Artifacts
{}
class
MockCache
extends
Mock
implements
Cache
{}
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