2019-09-04 21:01:54 +05:30
|
|
|
/**
|
|
|
|
* Manage the instance of a custom `window.localStorage`
|
|
|
|
*
|
|
|
|
* This only encapsulates the setup / teardown logic so that it can easily be
|
|
|
|
* reused with different implementations (i.e. a spy or a [fake][1])
|
|
|
|
*
|
|
|
|
* [1]: https://stackoverflow.com/a/41434763/1708147
|
|
|
|
*
|
|
|
|
* @param {() => any} fn Function that returns the object to use for localStorage
|
|
|
|
*/
|
|
|
|
const useLocalStorage = fn => {
|
|
|
|
const origLocalStorage = window.localStorage;
|
2020-11-24 15:15:51 +05:30
|
|
|
let currentLocalStorage = origLocalStorage;
|
2019-09-04 21:01:54 +05:30
|
|
|
|
|
|
|
Object.defineProperty(window, 'localStorage', {
|
|
|
|
get: () => currentLocalStorage,
|
|
|
|
});
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
currentLocalStorage = fn();
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
currentLocalStorage = origLocalStorage;
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create an object with the localStorage interface but `jest.fn()` implementations.
|
|
|
|
*/
|
2020-06-23 00:09:42 +05:30
|
|
|
export const createLocalStorageSpy = () => {
|
|
|
|
let storage = {};
|
|
|
|
|
|
|
|
return {
|
|
|
|
clear: jest.fn(() => {
|
|
|
|
storage = {};
|
|
|
|
}),
|
2021-01-03 14:25:43 +05:30
|
|
|
getItem: jest.fn(key => (key in storage ? storage[key] : null)),
|
2020-06-23 00:09:42 +05:30
|
|
|
setItem: jest.fn((key, value) => {
|
|
|
|
storage[key] = value;
|
|
|
|
}),
|
|
|
|
removeItem: jest.fn(key => delete storage[key]),
|
|
|
|
};
|
|
|
|
};
|
2019-09-04 21:01:54 +05:30
|
|
|
|
|
|
|
/**
|
|
|
|
* Before each test, overwrite `window.localStorage` with a spy implementation.
|
|
|
|
*/
|
|
|
|
export const useLocalStorageSpy = () => useLocalStorage(createLocalStorageSpy);
|