带有phantomjs的量角器永远挂起

时间:2015-05-05 14:48:31

标签: angularjs windows node.js phantomjs protractor

这是我的conf文件:

exports.config = { 
   seleniumServerJar: './selenium-server-standalone-2.43.1.jar', 
  "capabilities": { 
    "browserName": "phantomjs"   
 }, 
 specs: [ 
        "test.js" 
    ], 
    jasmineNodeOpts: { 
        isVerbose: false, 
        showColors: true, 
        includeStackTrace: true 
    }, 
};

这里是名为test.js。它反对ng-europe社区网站,所以希望每个人都可以运行这个。我选择它来学习量角器,因为它是用角度写的:

describe('test ng-europe', function() { 

        beforeEach(function() { 
                browser.get('http://ngeurope.org'); 
        }); 

         it('should have a title', function() { 
                expect(browser.getTitle()).toContain('ng-europe'); 
                element.all(by.repeater('avatar in talk.avatars')).count().then(function(count) { 
                        console.log(count); 
                }); 
        }); 

        it('search something', function() { 
                var search_=element(by.model('speakerq')); 
                var speakers_=element.all(by.repeater('speaker in config.speakers').column('name')); 
                var speakers = $$('div.speaker.col-xs-12.col-sm-4.text-center.ng-scope img.img-responsive.img-thumbnail.img-circle.avatar');
                search_.sendKeys('igor'); 
                expect(speakers.count()).toBe(1); 
                console.log("speakers count" + speakers.count()); 
        }); 

        it('search something else', function() { 
                var search_=element(by.model('talksq')); 
                var talkers = $$('ul.list-unstyled li.ng-scope.ng-binding span.speakers-names.ng-binding'); 
                search_.sendKeys('with'); 
                expect(talkers.count()).toBe(8); 
                console.log("talkers count" + talkers.count()); 
        }); 

        it('click on jobs', function() { 
                var jobs_button=element(by.linkText('Jobs')); 
                jobs_button.click(); 
                var sponsors=$$('div.col-md-4 img.sponsor-logo.gold-sponsor') 
                expect(sponsors.count()).toBe(4);        
        }); 
});

以下是我称之为:

>protractor conf.js

selenium驱动程序位于同一个目录节点中,%appdata%\ npm 位于路径中,安装并更新了phantomjs。如果我将驱动程序设置为 chrome firefox 但是使用 phantomjs ,脚本会永远挂起而没有任何反应。没有显示错误,没有。就是这样:

Starting selenium standalone server... 
[launcher] Running 1 instances of WebDriver 
Selenium standalone server started at http://XX.XX.XXX.XX:60324/wd/hub

我缺少什么?

1 个答案:

答案 0 :(得分:1)

至少,我设法让它运行测试:

  • phantomjs 1.9.7
  • protractor 2.0.0

但是,现在它在成功传递第一个it()块之后立即抛出以下错误消息:

  

错误:失败:与远程浏览器通信时出错。它可能已经死了。

这是我使用的配置(应用了几个phantomjs帮助“技巧”):

exports.config = {
    seleniumArgs: ['-browserTimeout=60'],

    "capabilities": {
        "browserName": "phantomjs",
        'phantomjs.cli.args': [
            '--ignore-ssl-errors=true',  
            '--web-security=false'
        ]
    },

    specs: [
        "test.js"
    ],

    framework: "jasmine2",

    allScriptsTimeout: 20000,

    onPrepare: function () {
        browser.driver.manage().window().maximize();
    },

    jasmineNodeOpts: {
        showColors: true,
        isVerbose: true,
        includeStackTrace: true,

        defaultTimeoutInterval: 25000
    }
};

有很多人在询问如何解决这样的错误:

建议采用不同的解决方法,但这些解决方法都不适用于我和其他人。

这导致了答案的要点:为什么首先出现幻影?

正如protractor developers所述:

  

我们建议不要使用PhantomJS进行Protractor测试。那里   有很多报道的PhantomJS崩溃和行为问题   与真正的浏览器不同。

扩大观点。

如果使用protractor的主要目的是端到端测试,那么您一定要重新考虑浏览器的选择。端到端测试应该模仿您的应用程序的真实用户,我很确定,他们不会使用phantomjs来浏览您的网站。

如果选择phantomjs的原因是缺少真实显示,您可以在xvfb的帮助下使用虚拟显示(请参阅更多here)或在远程selenium服务器,您自己的,或由BrowserStackSauce Labs提供。