茉莉花不再需要了

问题描述 投票:0回答:1

当我试图运行这个测试用例时,有没有人可以告诉我我做错了什么我得到一个错误:错误:意外请求:获取“localhost:3000 / home?extended = true”没有更多请求预期我怎么能通过jasmine在一个控制器中处理多个HTTP和工厂调用?这是我的测试代码

describe('homeController Controller', function(){
beforeEach(module('myapp'));
var ctrl,$http,$httpBackend,scope,trendingProducts,newArrivalsProducts,store,categories,HomeProduct,Product;
beforeEach(inject(function(Product,HomeProduct,$injector,_$q_,$controller, $rootScope, $httpBackend,$http) {
  var deferred = _$q_.defer();
Product = Product;
HomeProduct = HomeProduct;
$httpBackend = $injector.get('$httpBackend');
$http = $http;
trendingProducts = {};
newArrivalsProducts = {};
store = {};
categories = {};
trendingProducts = [];
rootScope = $rootScope;
scope = $rootScope.$new();
$httpBackend.when('GET','http://localhost:3000/home',{
'headers': {
  'Content-Type': 'application/json'
},
  'params': { extended: 'true' },
  'withCredentials':true
}).respond({'success':true});
deferred.resolve('resolveData');
spyOn(Product,'fetchProductList').and.returnValue(deferred.promise);
spyOn(HomeProduct,'fetchTrendingProduct').and.returnValue(deferred.promise);
spyOn(HomeProduct,'fetchNewArrivals').and.returnValue(deferred.promise);
spyOn(HomeProduct,'fetchStore').and.returnValue(deferred.promise);
spyOn(HomeProduct,'fetchCategories').and.returnValue(deferred.promise);
ctrl = $controller('homeController', {
  $scope: scope,
  trendingProducts:trendingProducts,
  newArrivalsProducts:newArrivalsProducts,
  store:store,
  categories:categories
});
 }));

 it('Check Controller Promise function"s of Home Controller', function() {
  rootScope.$apply(); 
 });
});
jasmine karma-jasmine jasmine-node jasmine-jquery
1个回答
1
投票

你用'http://localhost:3000/home'嘲笑了你的$ httpBackend,但你已经调用了'localhost:3000/home?extended=true' - 没有'http://'。改善你的正则表达式。试试像:

$httpBackend.when('GET',/localhost:3000\/home/,...)
  .respond({'success':true});
© www.soinside.com 2019 - 2024. All rights reserved.