首先感谢您花时间阅读并希望在我的问题中提供一些煽动性.目前,我只是简单地尝试使用Instruments自动登录和注销我公司正在制作的应用程序.我遇到了一些小问题(正如你可以看到密码条
问题是,当我将警报弹出到屏幕时,我希望点击“注销”按钮.但是,似乎我从未进入应该处理警报的块.我可以推断出这是因为我在onAlert块中乱丢了logMessages,这些logMessages在运行测试脚本时没有出现在我的日志中.我知道默认处理程序只是解除任何警报,除非明确处理警报.我也相信我或至少试图明确处理该警报,以便我可以点击右键.
我究竟做错了什么?我遵循了Apple Instruments指南,我相信我使用的语法完全相同.请在下面找到我的代码,我将所有代码都包含在内,但感兴趣的内容是最后的.
var target = UIATarget.localTarget();
var password = "something"
UIALogger.logStart("Test1");
target.frontMostApp().mainWindow().scrollViews()[0].webViews()[0].textFields()[0].tap();
target.frontMostApp().keyboard().typeString("something");
UIATarget.localTarget().delay(2);
target.frontMostApp().mainWindow().scrollViews()[0].webViews()[0].secureTextFields()[0].tap();
UIATarget.localTarget().delay(2);
for (i = 0; i < password.length; i++){
var strChar = password.charAt(i);
target.frontMostApp().keyboard().typeString(strChar);
}
target.frontMostApp().mainWindow().scrollViews()[0].webViews()[0].buttons()["Log in"].tap();
target.frontMostApp().mainWindow().tableViews()[0].cells()["Wipe data after 10 attempts"].staticTexts()["Wipe data after 10 attempts"].scrollToVisible();
target.frontMostApp().mainWindow().tableViews()[0].groups()["logout default"].buttons()["logout default"].tap();
// Alert detected. Expressions for handling alerts should be moved into the UIATarget.onAlert function definition.
UIALogger.logMessage("Just before alert");
UIATarget.onAlert = function onAlert(alert){
UIALogger.logMessage("In Alert!");
UIATarget.delay(1);
var title = alert.name();
UIALogger.logMessage("Alert with title '" + title + "' encountered!");
UIALogger.alert.logElementTree();
alert.buttons()["Logout"].tap();
}
我有这个问题,并最终发现自动化代码在UI(在这种情况下是警报视图)显示在模拟器中之前正在进行到下一行.
为了缓解这种情况,我在onAlert块之前添加了一个延迟,以允许显示警报视图.
UIATarget.localTarget().delay(3)
UIATarget.onAlert = function onAlert(alert){
var title = alert.name();
UIALogger.logWarning("Alert with title ’" + title + "’ encountered!");
target.frontMostApp().alert().cancelButton().tap();
return false; // use default handler
}
