diff options
author | Thomas F. K. Jorna <[email protected]> | 2021-07-23 15:24:35 +0200 |
---|---|---|
committer | Thomas F. K. Jorna <[email protected]> | 2021-07-23 15:24:35 +0200 |
commit | 356381d14cb1ff3cbd39c7e396dd14379336451b (patch) | |
tree | a03e9b2534600bde7b3b781411b5b03f8134904b /app_expo/utils/storage | |
parent | 7aa007f158a52b41494049a1202938fc97813ec1 (diff) | |
parent | 73308af061af5e17ac7d4a73fa027a2f303c70dd (diff) |
resolving merge conflicts
Diffstat (limited to 'app_expo/utils/storage')
-rw-r--r-- | app_expo/utils/storage/index.ts | 1 | ||||
-rw-r--r-- | app_expo/utils/storage/storage.test.ts | 39 | ||||
-rw-r--r-- | app_expo/utils/storage/storage.ts | 79 |
3 files changed, 0 insertions, 119 deletions
diff --git a/app_expo/utils/storage/index.ts b/app_expo/utils/storage/index.ts deleted file mode 100644 index 69b61ec..0000000 --- a/app_expo/utils/storage/index.ts +++ /dev/null @@ -1 +0,0 @@ -export * from './storage' diff --git a/app_expo/utils/storage/storage.test.ts b/app_expo/utils/storage/storage.test.ts deleted file mode 100644 index bb241c0..0000000 --- a/app_expo/utils/storage/storage.test.ts +++ /dev/null @@ -1,39 +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_expo/utils/storage/storage.ts b/app_expo/utils/storage/storage.ts deleted file mode 100644 index 659e738..0000000 --- a/app_expo/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<string | null> { - 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<boolean> { - 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<any | null> { - 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<boolean> { - 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<void> { - try { - await AsyncStorage.removeItem(key) - } catch {} -} - -/** - * Burn it all to the ground. - */ -export async function clear(): Promise<void> { - try { - await AsyncStorage.clear() - } catch {} -} |