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