标签:angularjs protractor javascript
在量角器测试中,我试图找到一个端点,该端点将重置当前登录用户的所有数据.现在,我正在使用普通的旧javascript在beforeAll中命中该端点,并且成功命中了它,但是现在我的测试在页面刷新之前执行,导致它们失败.这是我当前的代码:
var EC = protractor.ExpectedConditions,
el = element(by.css('body div.modal-x'));
browser.executeAsyncScript(function() {
var inj = angular.element(document.body).injector();
var reHTTP = inj.get('reHTTP');
var myService = inj.get('myService');
var someVar = myService.getCurrent().definition.userName;
console.log(someVar); // works
reHTTP.get('/app/' + someVar + '/reset').then(function () {
// console.log('i am here'); // this works
// alert('Success!'); // this works
return browser.wait(EC.visibilityOf(el)); // this does not work
});
});
问题:因为我现在在浏览器上下文中,所以无法在该executeScript块内使用Protractor函数.即EC未定义
问题:如何在访问此端点的同时正确访问/使用我的ExpectedConditions(再次,我当前在beforeAll块中使用此函数)?
注意事项:
>如果我不使用browser.executeAsyncScript,那么angular是未定义的,并且我无法访问服务(或者我找不到其他方法)
>使用executeScript(而不是AsyncScript)失败的速度甚至比异步脚本还要快
有任何想法吗?
解决方法:
方法executeAsyncScript期望调用回调函数.您可以在请求返回结果后调用它:
var EC = protractor.ExpectedConditions,
el = element(by.css('body div.modal-x'));
browser.executeAsyncScript(function(callback) {
var inj = angular.element(document.body).injector();
var reHTTP = inj.get('reHTTP');
var myService = inj.get('myService');
var someVar = myService.getCurrent().definition.userName;
console.log(someVar); // works
reHTTP.get('/app/' + someVar + '/reset').then(function () {
callback();
});
});
browser.wait(EC.visibilityOf(el));
标签:angularjs,protractor,javascript 来源: https://codeday.me/bug/20191118/2029632.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。