mirror of
https://github.com/streamich/react-use.git
synced 2026-02-01 14:37:31 +00:00
Test. add testing for useAudio
This commit is contained in:
parent
c92b4d7400
commit
ef1dc1bf76
42
src/__tests__/useAudio.test.ts
Normal file
42
src/__tests__/useAudio.test.ts
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
import { renderHook, act } from '@testing-library/react-hooks';
|
||||||
|
import useAudio from '../useAudio';
|
||||||
|
const setUp = (
|
||||||
|
src: string = 'https://www.soundhelix.com/examples/mp3/SoundHelix-Song-2.mp3',
|
||||||
|
autoPlay: boolean = true
|
||||||
|
) => renderHook(() => useAudio({ src, autoPlay }));
|
||||||
|
|
||||||
|
it('should init audio and utils', () => {
|
||||||
|
global.console.error = jest.fn();
|
||||||
|
|
||||||
|
const MOCK_AUDIO_SRC = 'MOCK_AUDIO_SRC';
|
||||||
|
const MOCK_AUTO_PLAY_STATE = true;
|
||||||
|
const { result } = setUp(MOCK_AUDIO_SRC, MOCK_AUTO_PLAY_STATE);
|
||||||
|
const [audio, state, controls, ref] = result.current;
|
||||||
|
// if not production mode, it will show the error message, cause audio do not render
|
||||||
|
expect(console.error).toHaveBeenCalledTimes(1);
|
||||||
|
|
||||||
|
// Test the audio comp
|
||||||
|
expect(audio.type).toBe('audio');
|
||||||
|
expect(audio.props.src).toBe(MOCK_AUDIO_SRC);
|
||||||
|
expect(audio.props.autoPlay).toBe(MOCK_AUTO_PLAY_STATE);
|
||||||
|
|
||||||
|
// Test state value
|
||||||
|
expect(state.time).toBe(0);
|
||||||
|
expect(state.paused).toBe(true);
|
||||||
|
expect(state.muted).toBe(false);
|
||||||
|
expect(state.volume).toBe(1);
|
||||||
|
|
||||||
|
// Test controls
|
||||||
|
ref.current = document.createElement('audio');
|
||||||
|
// Mock ref current for controls testing
|
||||||
|
|
||||||
|
expect(ref.current.muted).toBe(false);
|
||||||
|
controls.mute();
|
||||||
|
expect(ref.current.muted).toBe(true);
|
||||||
|
controls.unmute();
|
||||||
|
expect(ref.current.muted).toBe(false);
|
||||||
|
|
||||||
|
expect(ref.current.volume).toBe(1);
|
||||||
|
controls.volume(0.5);
|
||||||
|
expect(ref.current.volume).toBe(0.5);
|
||||||
|
});
|
||||||
Loading…
x
Reference in New Issue
Block a user