首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >测试异步组件方法

测试异步组件方法
EN

Stack Overflow用户
提问于 2017-01-17 11:39:24
回答 1查看 51关注 0票数 0

我有一个角分量,我想在调用异步方法之后测试状态。我该怎么做?我的方法doSomething不返回承诺!

代码语言:javascript
复制
angular.module('myModule').component('myComponent', {
  template: '<p></p>',
  controller: function($q) {
    this.state = 1;
    this.doSomething: function() {
      var that = this;
      setTimeout(function() { that.state = 2; }, 50);
    }
  }
});

测试

代码语言:javascript
复制
describe('Test', function() {
    var ctrl = null;

    beforeEach(module('myModule'));
    beforeEach(inject(function(_$componentController_) {
       ctrl = _$componentController_('myComponent', null, {});
    }));

    it('should be 2', function() {
      ctrl.doSomething();
      expect(ctrl.state).toBe(2);
    });
});
EN

回答 1

Stack Overflow用户

发布于 2017-01-17 14:16:03

您需要在测试中等待更新,如下所示:

代码语言:javascript
复制
describe('Test', function() {
    var ctrl = null;

    beforeEach(module('myModule'));
    beforeEach(inject(function(_$componentController_) {
       ctrl = _$componentController_('myComponent', null, {});
    }));

    it('should be 2', function(done) {
      ctrl.doSomething();
      setTimeout(function() { 
         expect(ctrl.state).toBe(2);
         done(); 
      }, 52);
    });
});

希望能帮上忙。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41696178

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档