草庐IT

gulp-jasmine

全部标签

javascript - 使用 gulp 简化顶级函数

以这个简单的gulp为例进行丑化:gulp.task('scripts',function(){//MinifyandcopyallJavaScript(exceptvendorscripts)returngulp.src(paths.scripts).pipe(uglify()).pipe(concat('all.min.js')).pipe(gulp.dest('build/js'));});如果你有两个文件:文件f1.js:functionf1(){varhello=1;returnhello;}文件f2.js:functionf2(){returnf1();}all.min.j

javascript - Gulp 在 gulp.src() 的符号链接(symbolic link)上给出错误

我的图像文件夹中有一个符号链接(symboliclink)指向另一个包含第三方库提供的外部图像的文件夹(由bower管理-非常喜欢javascript)。作为构建过程的一部分,我按如下方式压缩所有图像:gulp.task('images',function(){returngulp.src('static/img/**/*').pipe(imagemin({optimizationLevel:3,progressive:true,interlaced:true})).pipe(gulp.dest('dist/img'))});当gulp到达img文件夹中的符号链接(symbolicli

javascript - Angular.js + karma + Jasmine : Unknown provider for service

我正在为以下Angular.js服务编写测试:varmodule=angular.module('wp',['aws','lodash','jquery','moment','wp.model']);/***Wordpressservice.*/module.service('wpService',function(_,$http,$q,$aws,Post){varself=this;/***HTTPrequest.*/this.http=function(config){var$config=_.clone(config);if($config.user&&$config.passw

javascript - Jasmine 测试在 Chrome 和 Firefox 中通过,但在 PhantomJS 中失败

我正在使用React构建一个基本的博客应用程序。我正在使用Jasmine和Karma来运行我的前端测试。我启动并运行了第一个测试,它在Chrome(Chromium)和Firefox中通过了测试,但是当它在PhantomJS中运行时,我收到以下错误:PhantomJS1.9.8(Linux0.0.0)ERRORTypeError:'undefined'isnotafunction(evaluating'ReactElementValidator.createElement.bind(null,type)')at/home/michael/repository/short-stories

javascript - 测试 Jasmine 中自定义事件的处理

我想确保在触发自定义jQuery事件时,对象的方法作为事件处理程序被调用;但是单元测试似乎返回了假阴性,因为我的实现效果很好。(这是使用TwitterFlight和FlightJasmineextensions的测试套件的一部分,但这只是一个普通的Jasminespy。)describe('listeningforuiNeedsPlanevent',function(){varspy;beforeEach(function(){spy=spyOn(this.component,'getPlan');$(document).trigger('uiNeedsPlan');});it('ge

javascript - 使用 Jasmine 在 JavaScript 中插入 WebSocket

我尝试测试onmessage是否是一个正确的函数。这是一个测试:describe(".init(address,window)",function(){beforeEach(function(){address='ws://test.address';window={};e={data:{}}spyOn(window,'WebSocket').and.returnValue(function(){return{onmessage:null}});spyOn(subject,'handleMessage');});it("shouldcreateaWebSocketclientwhich

javascript - 如何为包含来自另一个类/文件的全局变量的方法编写 Jasmine 测试?

我的测试失败的原因如下:ReferenceError:Can'tfindvariable:moving_canvas_contextinfile(line5)我了解测试失败的原因。它不理解该变量,因为它是在单独的JavaScript文件中定义的。但是,它是全局声明的并且在现实中有效。如何为这个clear_canvas函数编写jasmine测试?JavaScriptCanvas_Actions:(function(){window.Canvas_Actions=(function(){functionCanvas_Actions(){}Canvas_Actions.prototype.c

javascript - gulp-filter 没有正确过滤掉排除的文件

我正在尝试在一个项目中使用gulpjs而不是grunt。在我的代码上运行jsHint时,我试图使用gulp过滤器忽略vendor库。我的代码基于自述文件示例中的代码,但文件未被过滤。我正在运行Node0.10.26、gulp3.8.0和gulp过滤器0.4.1我正在尝试在包含许多其他JS文件目录的目录wcui/app/js上运行jshint,总共大约有120个js文件。我只想排除vendor目录。我的代码是这样的:vargulp=require('gulp');vargulpFilter=require('gulp-filter');varjshint=require('gulp-js

javascript - 如何通过 Jasmine spy 将被拒绝/失败的 promise 返回到单元测试中的 Angular Controller

我正在使用jasmine来测试我的AngularController。我在.then(successCallback,errorCallback)中捕获错误和成功虽然它在实时功能的基础上运行良好,但我很困惑如何编写一个spy来返回错误,因为它总是在successCallback()中被捕获以下是Controller:-angular.module('myApp').controller('LoginCtrl',function($scope,$location,loginService,SessionService){$scope.errorMessage='';$scope.logi

javascript - jasmine.clock().tick() 不适用于 $timeout 和 debounce,但适用于 setTimeout

下面我有3个功能完全相同。每种调用setTimeout的方式不同,delay1()直接使用setTimeout,delay2()使用angularjs$timeout和delay3()使用lodashdebounce。它们都工作正常。问题出现在我用Jasmine测试的时候。setTimeout可以与jasmine.clock().tick()方法配合使用,但$timeout和debounce不适用't我有兴趣使用Jasmine进行去抖动。我知道我可以将$timeout.flush()与angularjs一起使用,但是$timeout和setTimeout在我使用的代码的其他地方给我带来