2014-09-03 61 views
1

我有一个角度的应用程序正在进行一些茉莉花测试。我最近添加了一个新的方法来在我的一个服务中对弹性搜索进行查询,它看起来像这样。为茉莉花集成测试做出真正的异步请求

test: 
    function(){ 
     return "Working"; 
    }, 

executeSearch: 
    function(field, value, size, page_number){ 
     return service.executeRegExSearch(field, value, size, page_number); 
    }, 

//new method 
executeRegExSearch: 
    function(field, value, size, page_number){ 
     //main search body, I know it works because 
     //I am getting expected results in the browser 
    } 

然后在我的茉莉花测试中,我有这样的事情。

//initialization stuff 
var $httpBackend; 
var searchAPI; 

beforeEach(inject(function($injector){ 
    jasmine.DEFAULT_TIMEOUT_INTERVAL = 5000; 
    $httpBackend = $injector.get('$httpBackend'); 
    searchAPI = $injector.get('searchAPI'); 
})); 

it("is loaded properly", function(){ 
    expect(searchAPI.test() == "Working").toBe(true); //passes 
}); 

it("can make a request", function(){ 
    var field = "col_name"; 
    var value = "bb.*"; //this is matching in my browser/application 
    var size = 10; 
    var page_number = 1; 

    var res; 

    searchAPI.executeSearch(field, value, size, page_number).then(function(res){ 
     res = res; 
     alert(JSON.stringify(res)); 
     done(); 
    }); 
    $httpBackend.flush(); 

}); 

但是当我跑,我得到的错误

Unexpected request: GET http://myserver/index-1/_search?source={"query":{"regexp":{"col_name":{"value":"bb.*"}}}}"&size=10&from=0 No more request expected in http://localhost:8081/js/angularjs/angular-mocks.js (line 1180) 

我不知道如何使用的嘲笑,还是我甚至知道我在做它。我所要做的就是能够运行一套测试,实际调用我的后端,以确认事情正在被正确集成......你知道......集成测试。

任何人有任何建议?

回答

0

如果你想为角度应用做端到端的e2e测试,你肯定必须使用量角器(由角度团队创建),你可以使用茉莉花创建你的测试并运行它们对你的应用程序,如果你只是使用单元测试我认为最好的方法是模拟httpBackend。

https://github.com/angular/protractor

https://docs.angularjs.org/guide/e2e-testing

+0

好的,我想同时做两个,所以我会检查出这两个链接。谢谢! – Zack 2014-09-03 16:35:21

+0

除了使用量角器进行e2e teting之外,您还可以使用ngMidway测试器调用真实的后端形式Jasmine测试。我建议阅读http://stackoverflow.com/questions/20864764/e2e-mock-httpbackend-doesnt-actually-passthrough-for-me,尤其是重击http://plnkr.co/edit/552UuwY6mQGyrMnJMqPx?p=预览 – tapatron 2014-09-03 20:27:17

1

我不想做硒的东西的测试,所以测试我的应用程序与真正的后台调用我用modified version of angular-mocks

它的工作原理就像为单位 - 在茉莉花测试。

我使用它与茉莉2.0,所以测试看起来如下:

it(' myTest', function (done) { 
    _myService.apiCall() 
     .then(function() { 
      expect(true).toBeTruthy(); 
      done() 
     }); 
}); 

注:由于异步调用的是需要done

+0

感谢您的回复。 – Zack 2014-09-22 15:41:41