ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

javascript-量角器HTTP GET请求

2019-11-18 16:35:41  阅读:213  来源: 互联网

标签: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. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有