From 5f4611d65e40eae3ca6191a15f68d69ea5a1c4cb Mon Sep 17 00:00:00 2001 From: Kirill Rogovoy Date: Tue, 20 Jul 2021 21:24:52 +0300 Subject: WIP --- app/utils/storage/index.ts | 1 - app/utils/storage/storage.test.ts | 43 --------------------- app/utils/storage/storage.ts | 79 --------------------------------------- 3 files changed, 123 deletions(-) delete mode 100644 app/utils/storage/index.ts delete mode 100644 app/utils/storage/storage.test.ts delete mode 100644 app/utils/storage/storage.ts (limited to 'app/utils/storage') diff --git a/app/utils/storage/index.ts b/app/utils/storage/index.ts deleted file mode 100644 index 69b61ec..0000000 --- a/app/utils/storage/index.ts +++ /dev/null @@ -1 +0,0 @@ -export * from './storage' diff --git a/app/utils/storage/storage.test.ts b/app/utils/storage/storage.test.ts deleted file mode 100644 index b8cf732..0000000 --- a/app/utils/storage/storage.test.ts +++ /dev/null @@ -1,43 +0,0 @@ -import AsyncStorage from '@react-native-async-storage/async-storage' -import { load, loadString, save, saveString, clear, remove } from './storage' - -// fixtures -const VALUE_OBJECT = { x: 1 } -const VALUE_STRING = JSON.stringify(VALUE_OBJECT) - -beforeEach(() => - (AsyncStorage.getItem as jest.Mock).mockReturnValue( - Promise.resolve(VALUE_STRING), - ), -) -afterEach(() => jest.clearAllMocks()) - -test('load', async () => { - const value = await load('something') - expect(value).toEqual(JSON.parse(VALUE_STRING)) -}) - -test('loadString', async () => { - const value = await loadString('something') - expect(value).toEqual(VALUE_STRING) -}) - -test('save', async () => { - await save('something', VALUE_OBJECT) - expect(AsyncStorage.setItem).toHaveBeenCalledWith('something', VALUE_STRING) -}) - -test('saveString', async () => { - await saveString('something', VALUE_STRING) - expect(AsyncStorage.setItem).toHaveBeenCalledWith('something', VALUE_STRING) -}) - -test('remove', async () => { - await remove('something') - expect(AsyncStorage.removeItem).toHaveBeenCalledWith('something') -}) - -test('clear', async () => { - await clear() - expect(AsyncStorage.clear).toHaveBeenCalledWith() -}) diff --git a/app/utils/storage/storage.ts b/app/utils/storage/storage.ts deleted file mode 100644 index 659e738..0000000 --- a/app/utils/storage/storage.ts +++ /dev/null @@ -1,79 +0,0 @@ -import AsyncStorage from '@react-native-async-storage/async-storage' - -/** - * Loads a string from storage. - * - * @param key The key to fetch. - */ -export async function loadString(key: string): Promise { - try { - return await AsyncStorage.getItem(key) - } catch { - // not sure why this would fail... even reading the RN docs I'm unclear - return null - } -} - -/** - * Saves a string to storage. - * - * @param key The key to fetch. - * @param value The value to store. - */ -export async function saveString(key: string, value: string): Promise { - try { - await AsyncStorage.setItem(key, value) - return true - } catch { - return false - } -} - -/** - * Loads something from storage and runs it thru JSON.parse. - * - * @param key The key to fetch. - */ -export async function load(key: string): Promise { - try { - const almostThere = await AsyncStorage.getItem(key) - return JSON.parse(almostThere) - } catch { - return null - } -} - -/** - * Saves an object to storage. - * - * @param key The key to fetch. - * @param value The value to store. - */ -export async function save(key: string, value: any): Promise { - try { - await AsyncStorage.setItem(key, JSON.stringify(value)) - return true - } catch { - return false - } -} - -/** - * Removes something from storage. - * - * @param key The key to kill. - */ -export async function remove(key: string): Promise { - try { - await AsyncStorage.removeItem(key) - } catch {} -} - -/** - * Burn it all to the ground. - */ -export async function clear(): Promise { - try { - await AsyncStorage.clear() - } catch {} -} -- cgit v1.2.3