import React, { useState, useEffect, useContext } from 'react';
import { View, Text } from 'react-native';
import { useTestStoreContext } from 'context/useTestStoreContext.hook';
import {render, act, screen, waitFor, fireEvent} from '@testing-library/react-native'
import * as fetchUtil from 'api/fetchUtil';
import { UploadContextProvider } from 'context/UploadContext';
import { AppContext, AppContextProvider } from 'context/AppContext';
import { AccountContextProvider } from 'context/AccountContext';
import { ProfileContextProvider } from 'context/ProfileContext';
import { CardContextProvider } from 'context/CardContext';
import { ChannelContextProvider } from 'context/ChannelContext';
import { StoreContext } from 'context/StoreContext';
function AppView() {
const [renderCount, setRenderCount] = useState(0);
const app = useContext(AppContext);
useEffect(() => {
setRenderCount(renderCount + 1);
}, [app.state]);
return (
{ app.state.session }
{ app.state.status }
);
}
function AppTestApp() {
return (
);
}
let mockWebsocket;
function MockWebsocket(url) {
this.url = url;
this.sent = false;
this.send = (msg) => { this.sent = true };
};
jest.mock('@react-native-firebase/messaging', () => () => ({ getToken: async () => '##' }));
jest.mock('react-native-device-info', () => ({
getVersion: () => '##',
getApplicationName: () => '##',
getDeviceId: () => '##',
}));
const realUseContext = React.useContext;
const realCreateWebsocket = fetchUtil.createWebsocket;
const realFetchWithTimeout = fetchUtil.fetchWithTimeout;
const realFetchWithCustomTimeout = fetchUtil.fetchWithCustomTimeout;
beforeEach(() => {
const mockCreateWebsocket = jest.fn().mockImplementation((url) => {
mockWebsocket = new MockWebsocket(url);
return mockWebsocket;
});
const mockUseContext = jest.fn().mockImplementation((ctx) => {
if (ctx === StoreContext) {
return useTestStoreContext();
}
return realUseContext(ctx);
});
React.useContext = mockUseContext;
const mockFetch = jest.fn().mockImplementation((url, options) => {
if (url.startsWith('https://test.org/account/apps')) {
return Promise.resolve({
json: () => Promise.resolve({ guid: '123', appToken: 'abc' })
});
}
return Promise.resolve({
json: () => Promise.resolve([])
});
});
fetchUtil.fetchWithTimeout = mockFetch;
fetchUtil.fetchWithCustomTimeout = mockFetch;
fetchUtil.createWebsocket = mockCreateWebsocket;
});
afterEach(() => {
React.useContext = realUseContext;
fetchUtil.fetchWithTimeout = realFetchWithTimeout;
fetchUtil.fetchWithCustomTimeout = realFetchWithCustomTimeout;
fetchUtil.createWebsocket = realCreateWebsocket;
});
test('testing', async () => {
render()
await waitFor(async () => {
expect(screen.getByTestId('session').props.children).toBe(false);
});
await act(async () => {
const app = screen.getByTestId('app').props.app;
app.actions.login('testlogin@test.org', 'testpassword');
});
await waitFor(async () => {
expect(mockWebsocket).not.toBe(undefined);
expect(mockWebsocket?.onopen).not.toBe(null);
expect(mockWebsocket?.onmessage).not.toBe(null);
expect(mockWebsocket?.onclose).not.toBe(null);
});
await act(async () => {
mockWebsocket.onopen();
});
await waitFor(async () => {
expect(mockWebsocket.sent).toBe(true);
});
await act(async () => {
mockWebsocket.onmessage({ data: JSON.stringify({ account: 1, profile: 1, card: 1, channel: 1 }) });
});
await waitFor(async () => {
expect(screen.getByTestId('status').props.children).toBe('connected');
});
});