|
1 |
| -import { accounts, config } from '@wagmi/test' |
2 |
| -import { afterEach, expect, test } from 'vitest' |
| 1 | +import { accounts, config, mainnet } from '@wagmi/test' |
| 2 | +import { afterEach, expect, test, vi } from 'vitest' |
| 3 | +import { http } from 'viem' |
3 | 4 |
|
4 | 5 | import { mock } from '../connectors/mock.js'
|
5 | 6 | import { connect } from './connect.js'
|
6 | 7 | import { disconnect } from './disconnect.js'
|
7 | 8 | import { reconnect } from './reconnect.js'
|
| 9 | +import { createStorage } from '../createStorage.js' |
| 10 | +import { createConfig } from '../createConfig.js' |
8 | 11 |
|
9 | 12 | const connector = config._internal.connectors.setup(
|
10 | 13 | mock({
|
@@ -68,3 +71,49 @@ test("behavior: doesn't reconnect if already reconnecting", async () => {
|
68 | 71 | ).resolves.toStrictEqual([])
|
69 | 72 | config.setState((x) => ({ ...x, status: previousStatus }))
|
70 | 73 | })
|
| 74 | + |
| 75 | +test('behavior: recovers from invalid state', async () => { |
| 76 | + const state = { |
| 77 | + 'wagmi.store': JSON.stringify({ |
| 78 | + state: { |
| 79 | + status: 'connected', // <-- invalid - `status` should not be kept in storage |
| 80 | + chainId: 1, |
| 81 | + current: '983b8aca245', |
| 82 | + }, |
| 83 | + version: Number.NaN, // mocked version is `'x.y.z'`, which will get interpreted as `NaN` |
| 84 | + }), |
| 85 | + } as Record<string, string> |
| 86 | + Object.defineProperty(window, 'localStorage', { |
| 87 | + value: { |
| 88 | + getItem: vi.fn((key) => state[key] ?? null), |
| 89 | + removeItem: vi.fn((key) => state.delete?.[key]), |
| 90 | + setItem: vi.fn((key, value) => { |
| 91 | + state[key] = value |
| 92 | + }), |
| 93 | + }, |
| 94 | + writable: true, |
| 95 | + }) |
| 96 | + |
| 97 | + const storage = createStorage<{ store: object }>({ |
| 98 | + storage: window.localStorage, |
| 99 | + }) |
| 100 | + |
| 101 | + const config = createConfig({ |
| 102 | + chains: [mainnet], |
| 103 | + storage, |
| 104 | + transports: { |
| 105 | + [mainnet.id]: http(), |
| 106 | + }, |
| 107 | + }) |
| 108 | + |
| 109 | + await reconnect(config, { connectors: [connector] }) |
| 110 | + |
| 111 | + expect(config.state).toMatchInlineSnapshot(` |
| 112 | + { |
| 113 | + "chainId": 1, |
| 114 | + "connections": Map {}, |
| 115 | + "current": null, |
| 116 | + "status": "disconnected", |
| 117 | + } |
| 118 | + `) |
| 119 | +}) |
0 commit comments