mirror of
https://github.com/status-im/status-mobile.git
synced 2025-01-26 16:39:24 +00:00
8ad58bb364
This commit improves in-app feature flags to persist what is currently only stored in a Reagent atom by using RN Async Storage https://reactnative.dev/docs/asyncstorage. This should make them more convenient to use, which is a good thing overall for developers. Additionally, there's now a top-right button in screen Settings > Feature Flags that will reset the flags to the initial values obtained from environment variables. These in-app feature flags are exclusively available in debug builds in Settings > Feature Flags, and only visible when flag ENABLE_QUO_PREVIEW is enabled. There's no impact whatsoever in prod builds. A reminder that they are not meant to be used by users (yet). It's worth noting that RN has deprecated Async Storage and now recommends other community solutions, but for a dev-only feature, I think it's fine.
122 lines
2.8 KiB
JavaScript
122 lines
2.8 KiB
JavaScript
const WebSocket = require('ws');
|
|
const { NativeModules } = require('react-native');
|
|
|
|
mockAsyncStorage = require('@react-native-async-storage/async-storage/jest/async-storage-mock');
|
|
require('react-native-gesture-handler/jestSetup');
|
|
require('react-native-reanimated/src/reanimated2/jestUtils').setUpTests();
|
|
|
|
jest.mock('@react-native-async-storage/async-storage', () => mockAsyncStorage);
|
|
|
|
jest.mock('react-native-fs', () => ({
|
|
default: {},
|
|
}));
|
|
|
|
jest.mock('react-native-share', () => ({
|
|
default: {},
|
|
}));
|
|
|
|
jest.mock('react-native-navigation', () => ({
|
|
getNavigationConstants: () => ({ constants: [] }),
|
|
Navigation: {
|
|
constants: async () => ({
|
|
statusBarHeight: 10,
|
|
topBarHeight: 10,
|
|
bottomTabsHeight: 10,
|
|
}),
|
|
},
|
|
}));
|
|
|
|
jest.mock('react-native-background-timer', () => ({}));
|
|
|
|
jest.mock('react-native-static-safe-area-insets', () => ({
|
|
default: {
|
|
safeAreaInsetsTop: 0,
|
|
safeAreaInsetsBottom: 0,
|
|
},
|
|
}));
|
|
|
|
jest.mock('react-native-permissions', () => require('react-native-permissions/mock'));
|
|
|
|
jest.mock('@react-native-clipboard/clipboard', () => ({
|
|
getString: jest.fn().mockResolvedValue('mockString'),
|
|
getImagePNG: jest.fn(),
|
|
getImageJPG: jest.fn(),
|
|
setImage: jest.fn(),
|
|
setString: jest.fn(),
|
|
hasString: jest.fn().mockResolvedValue(true),
|
|
hasImage: jest.fn().mockResolvedValue(true),
|
|
hasURL: jest.fn().mockResolvedValue(true),
|
|
addListener: jest.fn(),
|
|
removeAllListeners: jest.fn(),
|
|
getEnforcing: jest.fn(),
|
|
useClipboard: jest.fn(() => ['mockString', jest.fn()]),
|
|
}));
|
|
|
|
jest.mock('@react-native-community/audio-toolkit', () => ({
|
|
Recorder: jest.fn().mockImplementation(() => ({
|
|
prepare: jest.fn(),
|
|
record: jest.fn(),
|
|
toggleRecord: jest.fn(),
|
|
pause: jest.fn(),
|
|
stop: jest.fn(),
|
|
on: jest.fn(),
|
|
})),
|
|
Player: jest.fn().mockImplementation(() => ({
|
|
prepare: jest.fn(),
|
|
playPause: jest.fn(),
|
|
play: jest.fn(),
|
|
pause: jest.fn(),
|
|
stop: jest.fn(),
|
|
seek: jest.fn(),
|
|
on: jest.fn(),
|
|
})),
|
|
MediaStates: {
|
|
DESTROYED: -2,
|
|
ERROR: -1,
|
|
IDLE: 0,
|
|
PREPARING: 1,
|
|
PREPARED: 2,
|
|
SEEKING: 3,
|
|
PLAYING: 4,
|
|
RECORDING: 4,
|
|
PAUSED: 5,
|
|
},
|
|
PlaybackCategories: {
|
|
Playback: 1,
|
|
Ambient: 2,
|
|
SoloAmbient: 3,
|
|
},
|
|
}));
|
|
|
|
jest.mock('i18n-js', () => ({
|
|
...jest.requireActual('i18n-js'),
|
|
t: (label) => `tx:${label}`,
|
|
}));
|
|
|
|
jest.mock('react-native-blob-util', () => ({
|
|
default: {
|
|
config: jest.fn().mockReturnValue({
|
|
fetch: jest.fn(),
|
|
}),
|
|
},
|
|
}));
|
|
|
|
jest.mock('react-native-reanimated', () => require('react-native-reanimated/mock'));
|
|
|
|
jest.mock('react-native-static-safe-area-insets', () => ({
|
|
default: {
|
|
safeAreaInsetsTop: 0,
|
|
safeAreaInsetsBottom: 0,
|
|
},
|
|
}));
|
|
|
|
NativeModules.ReactLocalization = {
|
|
language: 'en',
|
|
locale: 'en',
|
|
};
|
|
global.navigator = {
|
|
userAgent: 'node',
|
|
};
|
|
|
|
global.WebSocket = WebSocket;
|