1
嗨我有一个Angular服务,使用另一项服务,从本地存储加载数据在初始化。不能更新茉莉间谍
angular
.module('app')
.factory('localStorage', function ($window)
{
if (!$window.localStorage)
{
// throw Error
}
return $window.localStorage;
});
angular
.module('app')
.factory('session', function (localStorage)
{
var container = JSON.parse(localStorage.getItem('sessionContainer'));
return {
getUser: getUser
};
});
现在我想测试会话服务。
describe('SessionService', function()
{
var service;
var localStorageMock;
// Load the module.
beforeEach(module('appRegistration'));
// Create mocks.
beforeEach(function()
{
logMock = {};
localStorageMock = jasmine.createSpyObj('localStorageServiceMockSpy', ['setItem', 'getItem']);
localStorageMock.getItem.and.returnValue('{}');
module(function ($provide)
{
$provide.value('localStorage', localStorageMock);
});
inject(function (_session_)
{
service = _session_;
});
});
it('should call `getItem` on the `localStorageService` service', function()
{
expect(localStorageMock.getItem).toHaveBeenCalledWith('sessionContainer');
});
describe('getUser method', function()
{
it('should return an empty object when the user is not set', function()
{
var result = service.getUser();
expect(result).toEqual({});
});
it('should return the user data', function()
{
// localStorageMock.getItem.and.returnValue('{"user":{"some":"data"}}');
var result = service.getUser();
expect(result).toEqual({some: 'user data'});
});
});
});
正如你可以在should return the user data
部分看到的。 我需要一种方法来更新container
,所以getUser
返回预期的数据。
我试图更新getItem
间谍,但这不起作用。 localStorageMock
已经注入session
服务,当我想更改间谍。
任何帮助?
简单的解决方案是完美的。谢谢。 如果您将答案更改为ES5,您将得到最佳答案 – WitteStier
如果您关于箭头函数,它们在可读性方面很好,我将其替换为正常的例子。 – estus