import React, { useState, useEffect, useContext } from 'react'; import { render, act, screen, waitFor, fireEvent } from '@testing-library/react'; import { UploadContextProvider, UploadContext } from 'context/UploadContext'; import axios from 'axios'; let uploadContext = null; function UploadView() { const [renderCount, setRenderCount] = useState(0); const [total, setTotal] = useState(0); const [channel, setChannel] = useState(); const upload = useContext(UploadContext); uploadContext = upload; useEffect(() => { setRenderCount(renderCount + 1); upload.state.progress.forEach((value, key) => { value.forEach((topic) => { if (topic.active?.total > total) { setTotal(topic.active?.total); } }); setChannel(key); }); }, [upload.state]); return (
{renderCount} {channel} {total}
); } function UploadTestApp() { return ( ); } const realPost = axios.post; let asset; beforeEach(() => { asset = {}; const mockPost = jest.fn().mockImplementation(async (url, data, options) => { for (let i = 0; i < 10; i++) { await new Promise((r) => setTimeout(r, 10)); options.onUploadProgress({ loaded: i * 11, total: 111 }); } return Promise.resolve({ data: asset }); }); axios.post = mockPost; }); afterEach(() => { axios.post = realPost; }); test('uploading assets', async () => { let setComplete; render(); await waitFor(async () => { expect(uploadContext).not.toBe(null); }); asset = [{ assetId: '3', transform: 'acopy;audio', status: 'pending' }]; setComplete = false; await act(async () => { uploadContext.actions.addTopic( 'asdf', '123', '1', [{ audio: 'asdf' }], () => { setComplete = true; }, () => {}, ); }); await waitFor(async () => { expect(setComplete).toBe(true); expect(screen.getByTestId('total').textContent).toBe('111'); expect(screen.getByTestId('channel').textContent).toBe(':123'); }); setComplete = false; await act(async () => { uploadContext.actions.addTopic( 'asdf', '123', '1', [{ audio: 'asdf' }], () => { setComplete = true; }, () => {}, { server: 'test.org', token: '0011', cardId: '96' }, ); }); await waitFor(async () => { expect(setComplete).toBe(true); expect(screen.getByTestId('channel').textContent).toBe('96:123'); }); });