-
Notifications
You must be signed in to change notification settings - Fork 2.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'Expensify:main' into rm-setNativeProps-composer
- Loading branch information
Showing
61 changed files
with
1,227 additions
and
311 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
// <App> uses <ErrorBoundary> and we need to mock the imported crashlytics module | ||
// due to an error that happens otherwise https://github.com/invertase/react-native-firebase/issues/2475 | ||
export default { | ||
log: jest.fn(), | ||
recordError: jest.fn(), | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,9 @@ | ||
import {PusherMock} from 'pusher-js-mock'; | ||
|
||
export default PusherMock; | ||
class PusherMockWithDisconnect extends PusherMock { | ||
disconnect() { | ||
return jest.fn(); | ||
} | ||
} | ||
|
||
export default PusherMockWithDisconnect; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
import React, {forwardRef} from 'react'; | ||
import {View} from 'react-native'; | ||
|
||
const insets = { | ||
top: 0, right: 0, bottom: 0, left: 0, | ||
}; | ||
|
||
function withSafeAreaInsets(WrappedComponent) { | ||
const WithSafeAreaInsets = props => ( | ||
<WrappedComponent | ||
// eslint-disable-next-line react/jsx-props-no-spreading | ||
{...props} | ||
// eslint-disable-next-line react/prop-types | ||
ref={props.forwardedRef} | ||
insets={insets} | ||
/> | ||
); | ||
return forwardRef((props, ref) => ( | ||
// eslint-disable-next-line react/jsx-props-no-spreading | ||
<WithSafeAreaInsets {...props} forwardedRef={ref} /> | ||
)); | ||
} | ||
|
||
const SafeAreaView = View; | ||
const SafeAreaProvider = props => props.children; | ||
const SafeAreaConsumer = props => props.children(insets); | ||
const SafeAreaInsetsContext = { | ||
Consumer: SafeAreaConsumer, | ||
}; | ||
|
||
const useSafeAreaFrame = jest.fn(() => ({ | ||
x: 0, y: 0, width: 390, height: 844, | ||
})); | ||
const useSafeAreaInsets = jest.fn(() => insets); | ||
|
||
export { | ||
SafeAreaProvider, | ||
SafeAreaConsumer, | ||
SafeAreaInsetsContext, | ||
withSafeAreaInsets, | ||
SafeAreaView, | ||
useSafeAreaFrame, | ||
useSafeAreaInsets, | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,72 @@ | ||
// eslint-disable-next-line no-restricted-imports | ||
import * as ReactNative from 'react-native'; | ||
import _ from 'underscore'; | ||
import CONST from '../src/CONST'; | ||
|
||
jest.doMock('react-native', () => { | ||
let url = 'https://new.expensify.com/'; | ||
const getInitialURL = () => Promise.resolve(url); | ||
|
||
let appState = 'active'; | ||
let count = 0; | ||
const changeListeners = {}; | ||
|
||
// Tests will run with the app in a typical small screen size by default. We do this since the react-native test renderer | ||
// runs against index.native.js source and so anything that is testing a component reliant on withWindowDimensions() | ||
// would be most commonly assumed to be on a mobile phone vs. a tablet or desktop style view. This behavior can be | ||
// overridden by explicitly setting the dimensions inside a test via Dimensions.set() | ||
let dimensions = CONST.TESTING.SCREEN_SIZE.SMALL; | ||
|
||
return Object.setPrototypeOf( | ||
{ | ||
NativeModules: { | ||
...ReactNative.NativeModules, | ||
BootSplash: { | ||
getVisibilityStatus: jest.fn(), | ||
hide: jest.fn(), | ||
}, | ||
StartupTimer: {stop: jest.fn()}, | ||
}, | ||
Linking: { | ||
...ReactNative.Linking, | ||
getInitialURL, | ||
setInitialURL(newUrl) { | ||
url = newUrl; | ||
}, | ||
}, | ||
AppState: { | ||
...ReactNative.AppState, | ||
get currentState() { | ||
return appState; | ||
}, | ||
emitCurrentTestState(state) { | ||
appState = state; | ||
_.each(changeListeners, listener => listener(appState)); | ||
}, | ||
addEventListener(type, listener) { | ||
if (type === 'change') { | ||
const originalCount = count; | ||
changeListeners[originalCount] = listener; | ||
++count; | ||
return { | ||
remove: () => { | ||
delete changeListeners[originalCount]; | ||
}, | ||
}; | ||
} | ||
|
||
return ReactNative.AppState.addEventListener(type, listener); | ||
}, | ||
}, | ||
Dimensions: { | ||
...ReactNative.Dimensions, | ||
addEventListener: jest.fn(), | ||
get: () => dimensions, | ||
set: (newDimensions) => { | ||
dimensions = newDimensions; | ||
}, | ||
}, | ||
}, | ||
ReactNative, | ||
); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,15 +1,64 @@ | ||
import fs from 'fs'; | ||
import path from 'path'; | ||
import 'react-native-gesture-handler/jestSetup'; | ||
import _ from 'underscore'; | ||
|
||
require('react-native-reanimated/lib/reanimated2/jestUtils').setUpTests(); | ||
|
||
// Silence the warning: Animated: `useNativeDriver` is not supported because the native animated module is missing | ||
jest.mock('react-native-blob-util', () => ({})); | ||
|
||
// These two mocks are required as per setup instructions for react-navigation testing | ||
// https://reactnavigation.org/docs/testing/#mocking-native-modules | ||
jest.mock('react-native/Libraries/Animated/NativeAnimatedHelper'); | ||
jest.mock('react-native-reanimated', () => { | ||
const Reanimated = require('react-native-reanimated/mock'); | ||
Reanimated.default.call = () => {}; | ||
return Reanimated; | ||
}); | ||
|
||
// Set up manual mocks for methods used in the actions so our test does not fail. | ||
jest.mock('../src/libs/Notification/PushNotification', () => ({ | ||
// There is no need for a jest.fn() since we don't need to make assertions against it. | ||
register: () => {}, | ||
deregister: () => {}, | ||
// The main app uses a NativeModule called BootSplash to show/hide a splash screen. Since we can't use this in the node environment | ||
// where tests run we simulate a behavior where the splash screen is always hidden (similar to web which has no splash screen at all). | ||
jest.mock('../src/libs/BootSplash', () => ({ | ||
hide: jest.fn(), | ||
getVisibilityStatus: jest.fn().mockResolvedValue('hidden'), | ||
})); | ||
|
||
jest.mock('react-native-blob-util', () => ({})); | ||
// Local notifications (a.k.a. browser notifications) do not run in native code. Our jest tests will also run against | ||
// any index.native.js files as they are using a react-native plugin. However, it is useful to mock this behavior so that we | ||
// can test the expected web behavior and see if a browser notification would be shown or not. | ||
jest.mock('../src/libs/Notification/LocalNotification', () => ({ | ||
showCommentNotification: jest.fn(), | ||
})); | ||
|
||
/** | ||
* @param {String} imagePath | ||
*/ | ||
function mockImages(imagePath) { | ||
const imageFilenames = fs.readdirSync(path.resolve(__dirname, `../assets/${imagePath}/`)); | ||
// eslint-disable-next-line rulesdir/prefer-early-return | ||
_.each(imageFilenames, (fileName) => { | ||
if (/\.svg/.test(fileName)) { | ||
jest.mock(`../assets/${imagePath}/${fileName}`, () => () => ''); | ||
} | ||
}); | ||
} | ||
|
||
// We are mocking all images so that Icons and other assets cannot break tests. In the testing environment, importing things like .svg | ||
// directly will lead to undefined variables instead of a component or string (which is what React expects). Loading these assets is | ||
// not required as the test environment does not actually render any UI anywhere and just needs them to noop so the test renderer | ||
// (which is a virtual implemented DOM) can do it's thing. | ||
mockImages('images'); | ||
mockImages('images/avatars'); | ||
mockImages('images/bankicons'); | ||
mockImages('images/product-illustrations'); | ||
jest.mock('../src/components/Icon/Expensicons', () => { | ||
const reduce = require('underscore').reduce; | ||
const Expensicons = jest.requireActual('../src/components/Icon/Expensicons'); | ||
return reduce(Expensicons, (prev, _curr, key) => { | ||
// We set the name of the anonymous mock function here so we can dynamically build the list of mocks and access the | ||
// "name" property to use in accessibility hints for element querying | ||
const fn = () => ''; | ||
Object.defineProperty(fn, 'name', {value: key}); | ||
return {...prev, [key]: fn}; | ||
}, {}); | ||
}); |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.