用于 Jest 的 NetworkInformation API 模拟
pnpm add -D jest-network-mock
import { enableMock, disableMock, dispatch } from 'jest-network-mock'
beforeEach(() => enableMock())
afterEach(() => disableMock())
test('example', done => {
navigator.connection.addEventListener('change', () => {
done()
})
dispatch({ effectiveType: '4g' })
})
启用 navigator.connection
模拟
type enableMock = (preset?: ConnectionInfo) => void
你可以使用 preset
设置 navigator.connection
的初始状态,默认使用 PRESET_4G
禁用 navigator.connection
模拟
type disableMock = () => void
修改 navigator.connection
状态并触发 change
事件
type dispatch = (state?: Partial<ConnectionInfo>) => boolean
你也可以在这里使用预设
我们提供了一些预设,你可以在调用 enableMock
和 dispatch
时使用:
PRESET_4G | PRESET_FAST_3G | PRESET_SLOW_3G | PRESET_OFFLINE | |
---|---|---|---|---|
downlink | 10 | 1.3 | 0.35 | 0 |
downlinkMax | 20 | 2.6 | 0.7 | 0 |
effectiveType | 4g |
3g |
3g |
4g |
rtt | 250 | 500 | 1850 | 0 |
saveData | false | false | false | false |
type | wifi |
wifi |
wifi |
none |