位置重新加载Jasmine

时间:2014-04-28 14:41:23

标签: javascript ruby-on-rails-3 jasmine

我真的不确定如何进行测试? (spyOn?)

function reloadPage() {
  $('#logo').click(function() {
    location.reload();
  })
}

任何建议都会很棒!

1 个答案:

答案 0 :(得分:5)

你可能不确定如何测试这段代码的原因是因为它做了两件不同的事情,你应该把它分解成更小的块。

我在这里看到两个不同的功能:

  • 点击事件处理
  • 重新加载页面

那么为什么不打破这样的逻辑?

function reloadPage() {
    location.reload();
}

function bindEvents() {
    $('#logo').click(reloadPage);
}

现在您可以使用间谍分别测试它们:

describe('when the logo is clicked', function() {
   var logo;
   var handlers;
   beforeEach(function() {
       handlers = {
           locationReload: location.reload, // handle for location.reload()
           reloadPage: reloadPage      // handle for your reloadPage()
       };

       logo = $('#logo').click(reloadPage);

       // attach Spy on reloadPage() and let the function call through
       spyOn(handlers, 'reloadPage').and.callThrough();

       // attach Spy on location.reload() 
       spyOn(handlers, 'locationReload');

   });

   it('will execute reloadPage function', function() {
        logo.trigger('click');
        expect(handlers.reloadPage).toHaveBeenCalled();
   });

   it('will reload the page', function() {
        logo.trigger('click');
        expect(handlers.locationReload).toHaveBeenCalled();
   });

   afterEach(function() {
       // clean up event bindings after each test
       logo.off('click');
   });

});

我们不需要测试reloadPage处理程序是否已正确添加到#logo的点击事件中,因为该测试正在模拟.click()和检查是否调用了reloadPage

因此,您很可能只需拥有it('will reload the page')规范,而不是两者。