我正在将 Calabash 集成到一个大型项目中。我有 Calabash 在测试应用程序中工作,所以我知道我的安装和环境设置正确。我正在使用可访问性标签和 .feature 文件来点击按钮并在字段中输入文本。它工作得很好。
然而,我的“真实”项目更大更复杂。即使配置与我的测试应用程序相同(请参阅下面的统计信息),当我在真实应用程序上运行一个简单的 .feature 文件时,我会得到不稳定的结果:大约 80% 的时间,它甚至在通过“ .feature 文件的“给定”行,并最终超时并显示以下消息:
Retrying.. HTTPClient::ReceiveTimeoutError: (execution expired)
我注意到在这些情况下,当我尝试使用鼠标与之交互时,该应用程序完全没有响应。它似乎已经冻结了。还有一个 UIAlertView 应该出现,但从未出现。请注意,当我从 XCode(相同的“-cal”目标)启动模拟器时,它永远不会冻结。我可以与之交互,UIAlert 出现,一切正常。
另外 20% 的时间,它将使它在我的 .feature 文件中更进一步——它会有效地通过“Given”行,可能还有其他行,只要它们不涉及与屏幕交互。任何敲击或键入命令都会导致它挂起并最终超时,并显示与上述相同的“执行过期”消息。
经过大量调查,我消除了此应用程序和我的测试应用程序的环境/配置之间的任何可能差异,并确定我的应用程序一定有一些 Calabash 真的不喜欢的地方!不幸的是,我对葫芦太不熟悉了,不知道从哪里开始寻找。任何帮助,将不胜感激。
Calabash 团队要求的诊断:
> xcode-select --print-path
/Applications/Xcode.app/Contents/Developer
> xcodebuild -version
Xcode 6.1
Build version 6A1052d
> calabash-ios version
0.11.3
> calabash.framework/Resources/version
0.11.3
irb(main):006:0> server_version
{
"app_version" => "0.10",
"outcome" => "SUCCESS",
"app_id" => "<redacted>",
"simulator_device" => "iPhone",
"version" => "0.11.3",
"app_name" => "<redacted>",
"iphone_app_emulated_on_ipad" => false,
"4inch" => true,
"git" => {
"remote_origin" => "git@github.com:calabash/calabash-ios-server.git",
"branch" => "master",
"revision" => "40c6245"
},
"screen_dimensions" => {
"scale" => 2,
"width" => 640,
"sample" => 1,
"height" => 1136
},
"iOS_version" => "8.1",
"system" => "x86_64",
"simulator" => ""
}