Skip to content

Commit

Permalink
fix(utils): make 'unwrap' update immediate after resolve (#2794)
Browse files Browse the repository at this point in the history
Co-authored-by: Daishi Kato <dai-shi@users.noreply.github.com>
  • Loading branch information
organize and dai-shi authored Nov 11, 2024
1 parent c883763 commit 34b4f8e
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 6 deletions.
16 changes: 10 additions & 6 deletions src/vanilla/utils/unwrap.ts
Original file line number Diff line number Diff line change
Expand Up @@ -60,12 +60,16 @@ export function unwrap<Value, Args extends unknown[], Result, PendingValue>(
return { v: promise as Awaited<Value> }
}
if (promise !== prev?.p) {
promise
.then(
(v) => promiseResultCache.set(promise, v as Awaited<Value>),
(e) => promiseErrorCache.set(promise, e),
)
.finally(setSelf)
promise.then(
(v) => {
promiseResultCache.set(promise, v as Awaited<Value>)
setSelf()
},
(e) => {
promiseErrorCache.set(promise, e)
setSelf()
},
)
}
if (promiseErrorCache.has(promise)) {
throw promiseErrorCache.get(promise)
Expand Down
12 changes: 12 additions & 0 deletions tests/vanilla/utils/unwrap.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -137,4 +137,16 @@ describe('unwrap', () => {
await new Promise((r) => setTimeout(r)) // wait for a tick
expect(store.get(unwrap(asyncAtom))).toEqual('concrete')
})

it('should get a fulfilled value after the promise resolves', async () => {
const store = createStore()
const asyncAtom = atom(Promise.resolve('concrete'))
const syncAtom = unwrap(asyncAtom)

expect(store.get(syncAtom)).toEqual(undefined)

await store.get(asyncAtom)

expect(store.get(syncAtom)).toEqual('concrete')
})
})

0 comments on commit 34b4f8e

Please sign in to comment.