单元测试 – 当使用茉莉花进行单元测试时,您如何在AngularJS中模拟服务?

前端之家收集整理的这篇文章主要介绍了单元测试 – 当使用茉莉花进行单元测试时,您如何在AngularJS中模拟服务?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
假设我有一个依赖于两个状态服务计划和仓库的服务商店。如何将不同版本的进度表和仓库注入车间进行单元测试?

这里是我的服务:

angular.module('myModule').service('shop',function(schedule,warehouse) {
    return {
        canSellSweets : function(numrequiredSweets){
             return schedule.isShopOpen()
                 && (warehouse.numAvailableSweets() > numrequiredSweets);
        }
    }
});

这里是我的嘲笑:

var mockSchedule = {
    isShopOpen : function() {return true}
}
var mockWarehouse = {
    numAvailableSweets: function(){return 10};
}

这里是我的测试:

expect(shop.canSellSweets(5)).toBe(true);
expect(shop.canSellSweets(20)).toBe(false);
beforeEach(function () {
  module(function ($provide) {
    $provide.value('schedule',mockSchedule);
  });
});

模块是由角模块提供的一个函数。如果你传递一个字符串参数,一个带有相应名称的模块被加载,所有提供者,控制器,服务等都可用于规范。通常,它们使用inject函数加载。如果你传递一个回调函数,它将使用Angular的$ inject服务来调用。这个服务然后查看传递给回调函数的参数,并尝试推断应该将哪些依赖项传递到回调中。

猜你在找的Angularjs相关文章