草庐IT

unit-testing

全部标签

javascript - RegExp.test 不工作?

我试图在javascript中使用Regex.test验证年份,但无法弄清楚为什么它返回false。varregEx=newRegExp("^(19|20)[\d]{2,2}$");regEx.test(inputValue)对于输入值1981、2007返回false谢谢 最佳答案 当您使用字符串表达式创建RegExp对象时,您需要加倍反斜杠以便它们正确转义。另外[\d]{2,2}可以简化为\d\d:varregEx=newRegExp("^(19|20)\\d\\d$");或者更好的是使用正则表达式文字来避免双反斜杠:varreg

javascript - headless (headless) JavaScript 测试 HTML5 音频/视频

我知道还有很多其他类似的问题,但是答案并没有提供解决这个问题的方法。我的网站上使用了一个使用HTML5网络音频的JavaScript文件,我想对其进行单元测试。我研究过将QUnit与PhantomJS结合使用,在你说什么之前我知道Phantom不支持它(http://phantomjs.org/supported-web-standards.html),但是我想知道是否有办法解决这个问题?在浏览器中使用QUnit测试它会像您预期的那样工作,但我不想每次都使用浏览器测试它,我希望它在服务器上自动进行。其中一个测试失败的示例:QUnit.test("isPlaying",function(

javascript - D3.js - 以编程方式在 Jasmine 中生成拖动事件

我有一个使用D3和Angular编写的折线图组件。它具有用于更改x轴比例的可拖动条。现在我正在尝试使用Karma/Jasmine测试组件。我在单元测试中无法触发拖动事件。鼠标悬停和单击等其他事件也可以正常触发。我认为这是导致问题的d3中“拖动”事件的综合实现。这是我用来触发拖动的代码(此类代码在测试html页面上触发正确的d3拖动事件,但在单元测试中失败)。varleftBar=element.find(".left-bar")[0];varevObjStart=document.createEvent("MouseEvents");evObjStart.initMouseEvent(

javascript - 如何在 Vue.js 中测试计算属性?无法模拟 "data"

我想知道如何在Vue.js的单元测试中测试计算属性。我已经通过vue-cli(基于webpack)创建了一个新项目。例如这是我的组件:exportdefault{data(){return{source:[]}},methods:{removeDuplicates(arr){return[...newSet(arr)]}},computed:{types(){returnthis.removeDuplicates(this.source))}}}我试过这样测试it('shouldremoveduplicatesfromarray',()=>{constarr=[1,2,1,2,3]co

javascript - meteor JS : How to stub validated method in unit test

我正在使用经过验证的方法(mdg:validated-method)和LoggedInMixin(tunifight:loggedin-mixin)。现在我的单元测试出现了问题,因为它们因notLogged错误而失败,因为在单元测试中当然没有登录用户。我怎么必须stub呢?方法constresetEdit=newValidatedMethod({name:'reset',mixins:[LoggedInMixin],checkLoggedInError:{error:'notLogged'},//单元测试describe('resetEdit',()=>{it('shouldreset

javascript - 如何在 Trails.js 中测试水线模型

我想用mocha测试我的Trails.js项目的模型。我用trailpack-waterline将我的模型加载到WaterlineORM中。追随足迹Docs我创建了一个User.test.js:'usestrict'constassert=require('assert')describe('UserModel',()=>{letUserbefore(()=>{assert(global.app.models.User)User=global.app.models.User})it('shouldexist',()=>{assert(User)})})这运行没有任何错误。但我无法以任何

javascript - Karma 找不到配置文件中指定的文件

我正在为我的Angularjs应用编写Jasmine测试。我使用karmainit生成了karma.conf.js,但是当我运行karmastart时,我收到这样的警告:WARN[web-server]:404:/bower_components/angular/angular.jsWARN[web-server]:404:/js/app.jskarma.conf.js在我的应用程序文件夹中,这也是bower_components文件夹的位置。我想这可能是因为我使用这种方法的本地测试服务器:https://github.com/mhevery/angular-node-socketio

javascript - 如何以不同的顺序刷新 AngularJS $httpBackend 响应

我有一个AngularJS服务,它执行$httpGET请求并在本地缓存响应。它旨在处理同时发生的多个调用,以便仅缓存来自最终调用的数据。具体来说,如果发生以下情况:请求开始请求B开始请求B已完成请求完成结果是请求B的响应被缓存了,因为它是最后发起的。但是我在Jasmine中对此进行单元测试时遇到了问题。我可以设置两个$httpBackend.expectGET()期望,但我只能按照请求的顺序刷新它们。本质上我需要能够做这样的事情:$httpBackend.expectGET('/one').respond(200,data1);$httpBackend.expectGET('/two'

javascript - 如何在单元测试环境中模拟 browserHistory?

我正在尝试测试使用react-router的browserHistory的React组件。为了确保能够访问browserHistory,我使用了createMemoryHistory(react-router)模块,如下所示:letcreateMemoryHistory=require('react-router/lib/createMemoryHistory');在测试环境中,我利用了JSDOM库。global.document=jsdom('');global.window=document.defaultView;然后我尝试将创建的历史对象分配给DOM:lethistory=cr

javascript - 测试元素是否存在 Vuejs, Karma, Mocha

我是Javascript和Vue.js测试的新手。我通过vue-cli和内置Karma、Mocha和PhantomJS的完整webpack模板安装了vue。我运行了helloworld组件测试,它通过了。我有一个名为my-input.vue的vuejs组件,它生成以下HTML。exportdefault{}我对看起来像这样的组件进行了测试。importVuefrom'vue'import{defaultasMyInput}from'src/components/my-input.vue'describe('my-input.vue',()=>{it('shoulddisplayanin