草庐IT

unit-testing

全部标签

javascript - 按类不返回元素的 Angular Fixture DebugElement 查询

正如Angular.io框架测试文档所建议的,我一直在尝试使用AngularTestbed+Karma测试运行器来使用DebugElement查询。我创建了一个jqwidgetsTree组件,它生成类'.jqx-tree-item-li'的li元素。以下在DOM测试中直接使用javascript的测试通过了GREEN:it('Elementsofclassjqx-tree-item-lifoundusinggetElementsByClassName',(done)=>{this.fixture.whenStable().then(()=>{varelementArray=docume

javascript - 在松散类型语言的单元测试中,是否应该检查方法的返回类型?

在Java等强类型语言中,无需显式检查返回对象的类型,因为如果返回类型与方法签名不匹配,代码将无法编译。前任。当需要整数时,您不能返回bool值。在Ruby、JavaScript、Python等松散类型语言中,可以返回任何内容。编写检查从方法返回的对象类型的单元测试是否有意义?在我看来,这将确保在需要bool值的地方返回bool值。有必要在下面进行单元测试吗?=============================Ruby示例的尝试:first_module.rb:moduleFirstModuleTypeA=Struct.new(:prop1,:prop2)self.create_

javascript - 针对不同浏览器的 JavaScript 中的一般单元测试概念/实践?

我一直在用强类型语言编写单元测试,对此我有很好的理解。当用JavaScript编写单元测试以验证某些功能在某些浏览器中是否正常工作时,我又回到了手动测试。我不了解它是如何工作的。因为JavaScript旨在缩小数据和表示之间的差距,并使其更具交互性。一切都在浏览器中发生,而且更多地与UI有关。所以我假设如果我要编写单元测试,我会编写类似(伪代码)的内容:runfunctionAcheckDOMifcertainelementhasbeencreatedifnotthenfailcheckifelementisvisibleifnotthenfailcheckforthecontento

javascript - ECMAScript 5 支持测试套件

有谁知道是否存在测试ECMAScript5支持的测试套件(例如,用QUnit编写)? 最佳答案 最“官方”的测试套件可能是ECMAScriptTest262,由EcmaTC39的成员开发。还有开源的ECMAScript5ConformanceSuite由Microsoft和Google开发Sputnik,它测试ECMAScript3的“所有方面”和ECMAScript5的部分内容。这两个套件都包含在ECMAScriptTest262中。如果您只想测试基本支持(例如,新功能的存在,而不是它们是否在每种情况下都表现正确),可以使用ECM

javascript - 对模块化 Javascript 网络应用程序进行单元测试

我正在使用BackboneJS和RequireJS构建一个网络应用程序,需要通过AJAX为UI交互和数据检索实现某种形式的单元测试。我遇到过QUnit和Jasmine但我真的不知道如何将它集成到我的应用程序中。如果我正在测试以下内容:用户登录正常吗?从服务器接收到的数据是否正常?点击按钮是否会触发预期的响应?点击事件是否适用于动态加载的html内容?应用程序是否正确响应哈希/推送状态url的变化?我想测试必须直接集成到我的应用程序中,以便访问特定的JS对象,使用session特定的数据并响应推送状态URL的变化。如何将QUnit或Jasmine(或其他建议)集成到我的模块化应用程序中以

javascript - 如何在不需要运行浏览器或服务器的情况下在 Maven 中运行 javascript 单元测试?

我致力于开发包含javascript的网络内容,在某种程度上,它包含比动画和移动值更多的逻辑。我想为这种逻辑实现一些单元测试。我想找到一些方法用javascript编写这些测试,并在我用maven构建web项目时让它们运行。因为我要测试的代码处理方法或对象中包含的逻辑内容,所以我觉得我不应该让服务器运行。另外,我读过Rhino之类的东西,这让我觉得应该没有必要让浏览器从某处开始只是为了执行javascript。我并不是特别关心浏览器的差异——我很少发现我在该领域遇到问题,而且当我遇到问题时,总是与样式或罕见的DOM问题有关。我想测试一下我能否将1加1最后得到2。我在谷歌上搜索了一些,发

javascript - AngularJS 指令中的单元测试私有(private)函数

如何对在指令内定义的函数进行单元测试,如下面的myFunc?angular.module('myApp').directive('myDir',[function(){varmyFunc=function(arg){//codeinhere.};return{restrict:'A',scope:{},link:function(scope,element){}};}]);或者您如何定义我不想在指令之外公开的可测试指令特定函数? 最佳答案 最常见的方法是不测试私有(private)方法,而是测试公开其行为的公共(public)接口(

javascript - 模拟/ stub `super` 调用

我想模拟super调用,尤其是某些ES6类中的构造函数。例如importBarfrom'bar';classFooextendsBar{constructor(opts){...super(opts);}someFunc(){super.someFunc('asdf');}}然后在我的测试中,我想做类似的事情importFoofrom'../lib/foo';importBarfrom'bar';describe('constructor',function(){it('shouldcallsuper',function(){letopts=Symbol('opts');letcons

javascript - 使用 Protractor 获取按钮上的禁用属性不起作用

我试图在一个按钮上获取禁用属性,它应该被“禁用”,但我似乎没有得到值。Angular和Protractor的新手!当我检查页面时,这是我得到的显示已禁用按钮的HTML,就像它在页面上一样:Save下面的Protractor测试返回'Expectednulltoequaldisabled'varbtnSave=element(by.css('.primary'));expect(btnSave.isPresent()).toBeTruthy();varattr=element(by.css('.primary')).getAttribute('disabled');expect(attr

javascript - 在 Node.js 中模拟嵌套模块?

我有这些文件:文件1.jsvarmod1=require('mod1');mod1.someFunction()...文件2.jsvarFile1=require('./File1');现在在为File2编写单元测试时,是否可以模拟mod1,这样我就不会调用mod1.someFunction()? 最佳答案 我通常使用mockery模块,如下所示:lib/file1.jsvarmod1=require('./mod1');mod1.someFunction();lib/file2.jsvarfile1=require('./file