我正在测试一个网页,用户可以通过textinput向另一个网页发送消息。然后在服务器上发送POST请求,并将邮件转储到var/mail/new
文件夹中的磁盘上。
自动化在带有量角器的页面中发送消息后,我正在调用browser.waitForAngular()
和browser.driver.sleep(4000)
以留出时间让后端在磁盘上写入邮件。
在这些呼叫之后,检查电子邮件的存在失败。查看Unix shell时,我可以确认电子邮件已发送,并且Jasmine中标有it
标记的下一个测试确认电子邮件已存在。
为什么browser.driver.sleep(4000)
无效等待后端继续?如何更正以下代码?
it("is possible to send a message", function() {
shared.loginContributor();
var mailsBeforeMessaging =
fs.readdirSync(browser.params.mail.queue_path + "/new");
console.log('mailsBeforeMessaging');
console.log(mailsBeforeMessaging.length);
console.log(fs.lstatSync(browser.params.mail.queue_path + "/new"));
var usersListing = new UserPages.UsersListing().get();
var annotatorPage = usersListing.getUserPage("annotator");
annotatorPage.sendMessage("title5", "content64");
exec("/tmp/check.sh");
// we expect the message widget to disappear
var button = element(by.css(".user-profile-info-button"));
console.log('waiting');
browser.wait(EC.elementToBeClickable(button), 5000);
console.log('waiting is finished');
expect(EC.elementToBeClickable(button)).toBeTruthy();
// wait for mail to be dumped on the disk?
browser.waitForAngular();
browser.driver.sleep(4000);
exec("/tmp/check.sh");
var mailsAfterMessaging =
fs.readdirSync(browser.params.mail.queue_path + "/new");
console.log('mailsAfterMessaging');
// ERROR: here the number of emails is NOT incremented
console.log(mailsAfterMessaging.length);
console.log(fs.lstatSync(browser.params.mail.queue_path + "/new"));
});
it("xyz", function() {
console.log(fs.lstatSync(browser.params.mail.queue_path + "/new"));
// here the number of emails is incremented
var mailsAfterMessaging =
fs.readdirSync(browser.params.mail.queue_path + "/new");
console.log('mailsAfterMessaging');
console.log(mailsAfterMessaging.length);
});
答案 0 :(得分:3)
大多数量角器功能都没有做任何东西。他们将某些事情排队等待稍后,然后返回承诺去做。在it
块计划要做的事情之后,它们实际上开始发生(通过它们在ControlFlow中注册的承诺)。
但是,您的支票都是立即执行的。所以,在任何量角器调用完成任何事情之前,它们都会发生。
使用then
在测试中显示等待和依赖项。像这样:
annotatorPage.sendMessage("title5", "content64").then(function() {
exec("/tmp/check.sh");
});
或:
browser.wait(EC.elementToBeClickable(button), 5000).then(function() {
console.log('wait-for-clickable has completed'); // B
});
console.log('wait-for-clickable has been scheduled'); // A
请参阅Protractor Control Flow文档和Webdriver JS API doc。
不是你。这是一个疯狂的API学习,因为它根本不像任何熟悉正常同步编程的人所期望的那样。