- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
这是我的配置文件:
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
社区站点,因此希望的每个人都可以运行它。我选择它来学习 Protractor ,因为它是用 Angular 编写的:
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 驱动程序在同一目录 Node 中,%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
我错过了什么?
最佳答案
至少,我设法让它运行测试:
phantomjs
1.9.7 Protractor
2.0.0但是,现在它在成功通过第一个 it()
block 后立即抛出以下错误消息:
Error: Failed: Error communicating with the remote browser. It may have died.
这是我使用的配置(应用了几个 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
}
};
有很多人问如何解决这样的错误:
有不同的解决方法建议,但对我和其他人都不起作用。
这引出了答案的要点:为什么首先是 phantomjs?
如 protractor
developers 所述:
We recommend against using PhantomJS for tests with Protractor. There are many reported issues with PhantomJS crashing and behaving differently from real browsers.
扩展点。
如果使用 protractor
的主要目的是端到端测试,那么您绝对应该重新考虑您的浏览器选择。端到端测试应该模仿您的应用程序的真实用户,我敢肯定,他不会使用 phantomjs
来浏览您的网站。
如果选择 phantomjs
的原因是没有真实显示,您可以借助 xvfb
使用虚拟显示(参见更多 here )或运行你在远程 selenium 服务器上的测试,可以是你自己的,也可以是 BrowserStack
提供的或 Sauce Labs
.
关于angularjs - 带有 phantomjs 的 Protractor 永远挂起,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30056265/
是否有在非 AngularJS 页面内初始化 AngularJS 应用程序的最佳实践方法?我正在向现有网页添加新功能,需要传入一个参数。具体来说,有一组选项卡,一个新选项卡将启动一个 Angular
找不到这两者之间的区别。 保留其中任何一个来引导我的 Angular 应用程序是否有意义? angular.bootstrap(document,['myApp']); 或者 angularAMD.b
我试图理解 Packpub 的书附带的示例 AngularJS 应用程序。 app.js文件在 client/src/app 下定义文件夹,它的模块定义看起来像 angular.module('app
Angularjs 具有用于表单验证和显示错误消息的强大基础设施。但是,我处于必须在特定场景中向用户显示警告消息的情况。这是我的简单表格的图表 该表单在两个字段上都应用了必需和模式验证。除了此验证之外
我在重试功能正常工作时遇到了一些麻烦,希望能获得一些帮助。我有一个要调用的$ resource,直到出现成功情况或超过最大重试次数为止。 我似乎遇到的问题是,在我的重试函数中,我正在调用另一个prom
我目前正在开发一个 AngularJS 应用程序,我遇到了以下障碍。 当用户提交时,我们有一个 login 页面,我们调用一个 web api 并对用户进行身份验证,我们目前正在使用 claims 身
当范围更新时,指令的属性不会改变,它们仍然保持初始值。我在这里缺少什么? HTML works great works: {{foo}} Javascript (基于首页上的 A
我正在使用 Zurb 的 Foundation 框架修改应用程序以实现响应性和 AngularJS。存在数据显示在带有 ... 的表中的错误有 是根据 Foundation 的响应规则隐藏/显示的。不
在过去的三天里,我一直在搜寻互联网,试图弄清楚当angular注意到div的宽度发生变化时如何使指令运行。 我不断看到相同的示例,说明如何实现此目标,但是它们对我不起作用,我也不知道为什么。 我回到一
我正在使用以下代码尝试汇总 在 Angular ,这在整个作品中,但是小于 0.5 的数字四舍五入为 0。我想 向上取整 每个数字到下一个整数。例如 0.02 应四舍五入为 1 {{((data.Vi
我目前正在尝试以一种能够适当扩展到企业级别的方式来组织我的 Angular 应用程序。但是我发现似乎过度依赖框架内的命名约定,并且试图避免命名冲突是一个真正的问题。 例如,当定义任何 constant
我正在阅读 AngularJS 基础知识,并且喜欢在我的页面中使用它的绑定(bind)功能。所以我可以定义可以在 View 中显示的数据,可以对数据进行更改,以便在 View 中更改它而无需担心。 在
在父 Controller 范围内,我定义了 selectedItem设置为“x”。然后在子范围内,我定义了selectedItem使用 ngModel:
关闭。这个问题需要更多 focused .它目前不接受答案。 想改进这个问题?更新问题,使其仅关注一个问题 editing this post . 5年前关闭。 Improve this questi
如果2个条件为真,我试图将一个特定的类应用于li元素,因此我编写了以下代码,但似乎无法正常工作 ng-class="{current:isActive('/'), loginStatus: false
请看看朋克。 http://plnkr.co/edit/DuTFYbLVbPkCIvRznYjG?p=preview ng-pattern regEx不适用于输入文本字段。 仅在需要验证的情况下才能正
我正在为iOS + Android构建AngularJS(1.x)和Ionic/Cordova移动应用程序。我想在登录页面上添加/创建“深层链接”,以便在我向新用户发送“确认您的电子邮件”电子邮件时,
angularjs 中服务(或工厂)的生命周期是什么,何时重新初始化? 最佳答案 当 Angular 启动时,它会将服务的构造函数附加到关联的模块上。这种情况发生一次。 angular .modu
我对 Angular 很陌生,所以希望我知道的足够多,可以问什么似乎是合理的设计问题。 我正在通过 Angular 绘制一些数据,并且正在使用 $resource。在将 Angular 引入项目之前,
我需要在我的 angular-breeze 应用程序中使用国家/地区下拉菜单,我尝试了以下操作: https://github.com/banafederico/angularjs-country-s
我是一名优秀的程序员,十分优秀!