- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的项目是 ionic-angularjs-requirejs
我的环境是 Mac OS X 10.10.1, node v0.10.30
我想将 karma 测试集成到我的项目中,但是当我运行 grunt test
时这是错误的:
结果:
Running "karma:unit" (karma) task
INFO [karma]: Karma v0.12.28 server started at http://localhost:9876/
INFO [launcher]: Starting browser PhantomJS
INFO [PhantomJS 1.9.8 (Mac OS X)]: Connected on socket UhgMIttDejE4Xdm8I7mG with id 52208731
WARN [PhantomJS 1.9.8 (Mac OS X)]: Disconnected (1 times), because no message in 10000 ms.
Warning: Task "karma:unit" failed. Use --force to continue.
Aborted due to warnings.
"grunt-bower-requirejs": "^1.1.1",
"grunt-contrib-uglify": "^0.2.7",
"grunt-karma": "^0.9.0",
"karma": "^0.12.28",
"karma-jasmine": "^0.3.2",
"karma-phantomjs-launcher": "^0.1.4",
"karma-requirejs": "^0.2.2",
"requirejs": "^2.1.15"
module.exports = function (grunt) {
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),
bower: {
target: {
rjsConfig: 'js/main.js'
}
},
uglify: {
options: {
banner: '/*! <%= pkg.name %> <%= grunt.template.today("yyyy-mm-dd") %> */\n'
},
build: {
src: 'src/<%= pkg.name %>.js',
dest: 'build/<%= pkg.name %>.min.js'
},
},
karma: {
unit: {
options: {
frameworks: ['jasmine', 'requirejs'],
browsers: ['PhantomJS'],
autoWatch: true,
singleRun: true,
files: [
'lib/js/generated/angular/angular.js',
'lib/js/generated/angular-mocks/angular-mocks.js',
//'js/**/*.js',
//'templates/**/*.html',
'tests/*.tests.js'
],
exclude: [
'js/main.js'
]
}
}
}
});
grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.loadNpmTasks('grunt-bower-requirejs');
grunt.loadNpmTasks('grunt-karma');
// Tell Grunt what to do when we type "grunt" into the terminal
grunt.registerTask('default', [
'uglify',
'bower'
]);
grunt.registerTask('test', [
'karma'
]);
最佳答案
我使用 grunt-karma 插件的经验是,我花在调试插件上的时间比在我的实际站点上花费的时间多。我的解决方案是完全避免它并使用 grunt-exec 运行我的 karma 命令,或者只是不使用 grunt 并在新选项卡中手动运行 karma。
grunt.loadNpmTasks('grunt-exec');
var config =
{
exec: {
karma : 'karma start {path to your karma.conf.js file}'
// or
// karma : 'karma run {path to your karma.conf.js file}'
}
}
module.exports = [
'public/lib/angular/angular.js',
'public/lib/lodash/dist/lodash.compat.js',
'public/lib/jquery/dist/jquery.js',
'public/lib/angular-ui-router/release/angular-ui-router.js',
'tests/test-main.js',
{pattern: 'public/js/**/*.js', included: true},
{pattern: 'tests/unit/**/*.js', included: true}
];
var files = require('./files.js');
module.exports = {
// base path that will be used to resolve all patterns (eg. files, exclude)
basePath: '../',
frameworks: ['jasmine', 'requirejs'],
// list of files / patterns to load in the browser
files: files,
// list of files to exclude
exclude: [
],
// web server port
port: 9876,
// enable / disable colors in the output (reporters and logs)
colors: true,
// enable / disable watching file and executing tests whenever any file changes
autoWatch: true,
coverageReporter: {
type : 'html',
dir : './tests/coverage/',
subdir: function(browser) {
"use strict";
// normalization process to keep a consistent browser name accross different
// OS
return browser.toLowerCase().split(/[ /-]/)[0];
}
},
};
module.exports = function(config) {
"use strict";
commonConfig.reporters = ['nyan', 'growl'];
commonConfig.browsers = ['PhantomJS'];
commonConfig.captureTimeout = 60000;
commonConfig.singleRun = false;
commonConfig.logLevel = config.LOG_DEBUG;
config.set(commonConfig);
};
// commonConfig.browsers = ['PhantomJS', 'Chrome']
// commonConfig.browsers = ['PhantomJS', 'Chrome', 'Safari', 'Firefox'],
var commonConfig = require('./common.conf.js');
module.exports = function(config) {
"use strict";
commonConfig.reporters = ['progress'];
commonConfig.browsers = ['PhantomJS'];
commonConfig.captureTimeout = 120000;
commonConfig.singleRun = true;
commonConfig.logLevel = config.LOG_DEBUG;
config.set(commonConfig);
};
var commonConfig = require('./common.conf.js');
module.exports = function(config) {
"use strict";
commonConfig.reporters = ['progress','coverage'];
commonConfig.browsers = ['PhantomJS', 'Chrome', 'Safari', 'Firefox'];
commonConfig.captureTimeout = 120000;
commonConfig.singleRun = true;
commonConfig.logLevel = config.LOG_DEBUG;
commonConfig.preprocessors = {};
commonConfig.preprocessors['./public/js/*.js'] = ['coverage'];
config.set(commonConfig);
};
关于angularjs - 警告 [PhantomJS 1.9.8 (Mac OS X)] : Disconnected (1 times), 因为在 10000 毫秒内没有消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27310184/
我正在尝试开始使用 Mermaid CLI,但是当我尝试针对我的源文件运行它时,它说找不到 phantomjs。 (我运行的是 Win 7 64。) C:\Users\Chris\Documents>
我正在使用PhantomJS来调用网页,如下所示: page.open('http://example.com', function (s) { console.log(page.content)
如果有这样的功能,我需要更改Phantomjs自动清除缓存的默认时间。有什么想法吗? 最佳答案 应该是您正在寻找的功能: https://github.com/ariya/phantomjs/issu
我想从我的程序运行 PhantomJs 脚本,但由于脚本可能不是我写的,我需要确保 PhantomJs 在执行完成或因任何原因(例如无效语法、超时、 ETC)。到目前为止,我读到的所有内容都说你必须始
在 Package JSON 中,我尝试了许多不同版本的 karma-phantomjs-launcher、phantomjs,包括 phantomjs-prebuilt。 当前包 JSON “开发依
我的脚本有一些语法错误,但 PhantomJS 没有显示任何错误,而是没有显示任何内容。如果脚本有错误,为什么 Phantom JS 不显示解析错误? 在以下 PhantomJS 脚本(通过 Wind
我有一些需要填写的动态输入表单。问题是要填写表格,我需要访问另一个页面以获取取决于上一页输入的数据。因此,在我获得数据然后返回表单后,表单已经更改,因此我需要在获取数据时保持该表单打开。那么问题是如何
PhantomJS 在为我捕获网页到图像文件方面做得很好。我正在使用基于 rasterize.js 的脚本。 但是,对于某些固定大小的 Web 元素,我需要生成的图像与 Web 元素的大小相匹配。 例
我正在将 PhantomJS headless 浏览器集成到我的一个项目中(目前使用 1.6 版)。在大多数情况下,它在完成我需要完成的工作方面做得很好。但是,WebPage.open() 调用工作方
是否可以在page.evaluate中传递变量? function myFunction(webpage, arg1, arg2){ var page = require('webpage').cre
有没有办法始终如一地检测 PhantomJS/CasperJS?我一直在处理用它构建的一系列恶意垃圾邮件机器人,并且能够根据某些行为基本上阻止它们,但是我很好奇是否有一种坚如磐石的方法来了解 Casp
有没有办法拦截资源请求并直接从处理程序给出响应?像这样的事情: page.onRequest(function(request){ request.reply({data: 123}); });
phantomjs 有配置 loadImage, 但我想要更多, 如何控制phantomjs跳过下载某种资源, 比如css等... ===== 好消息:已添加此功能。 https://code.goo
我正在尝试在 PhantomJS (2.1.1) 的 page.evaulate() 调用中使用 WebSocket。当尝试连接到 WebSocket 服务器时,出现以下错误: 安全错误:DOM 异常
我正在使用 PhantomJS 1.8,但遇到了一个限制——您无法指定它用于磁盘缓存的目录。我将其添加到他们的问题跟踪系统中,但由于以前没有它,所以我不希望它很快添加。 因此,我正在寻找解决此限制的方
我想渲染一个仅在用户滚动页面时加载图像的页面。仅设置 page.scrollPosition 没有任何效果。我需要一些可以随时间改变滚动位置的东西。 最佳答案 不确定这是否是最好的方法,但它确实有效。
我正在尝试使用 PhantomJS 设置远程调试,但运气不佳。我按照 https://github.com/ariya/phantomjs/wiki/Troubleshooting 上的说明进行操作。
在 PhantomJS 中,webpage.open 会使用状态参数设置为“成功”或“失败”的回调。根据文档,如果没有发生网络错误,则“成功”,否则“失败”。有没有办法查看导致失败的底层网络错误? 当
有什么方法可以使用 phantomjs 请求资源并能够到达响应的主体吗? 最佳答案 更新:关于“获取并使用所有其他资源(如图像、CSS、字体等)做某事”的其他可能含义,我最近在博客上写了 how to
在运行 PhantomJS 提供的 rasterize.js 示例时,我发现我必须等待 20 秒或更长时间才能生成网页图像。 有没有可能在不消耗大量资源的情况下加快速度的方法?我基本上希望快速生成从加
我是一名优秀的程序员,十分优秀!