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'); }); });