Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[DO_NOT_MERGE] sync effect (V2) development and testing #2943

Draft
wants to merge 13 commits into
base: main
Choose a base branch
from

Conversation

dmaskasky
Copy link
Collaborator

@dmaskasky dmaskasky commented Jan 17, 2025

Summary

Uploading syncEffect v2 work in progress to finish development. The end goal is all tests pass.

The full implementation is provided towards this goal.

Not for merge

Current State

✅ All tests passing

 ✓  jotai  tests/syncEffect/syncEffect.test.tsx (32 tests) 126ms
   ✓ should run the effect on vanilla store
   ✓ should run the effect on mount and cleanup on unmount and whenever countAtom changes
   ✓ should not cause infinite loops when effect updates the watched atom
   ✓ should not cause infinite loops when effect updates the watched atom asynchronous
   ✓ should allow synchronous recursion with set.recurse for first run
   ✓ should allow synchronous recursion with set.recurse
   ✓ should allow multiple synchronous recursion with set.recurse
   ✓ should batch updates during synchronous recursion with set.recurse
   ✓ should allow asynchronous recursion with task delay with set.recurse
   ✓ should allow asynchronous recursion with microtask delay with set.recurse
   ✓ should work with both set.recurse and set
   ✓ should disallow synchronous set.recurse in cleanup
   ✓ should return value from set.recurse
   ✓ should conditionally run the effect and cleanup when effectAtom is unmounted
   ✓ synchronous updates to the same atom > when effectIncrementCountBy is +0 and incrementCountBy is +0
   ✓ synchronous updates to the same atom > when effectIncrementCountBy is +0 and incrementCountBy is 1
   ✓ synchronous updates to the same atom > when effectIncrementCountBy is +0 and incrementCountBy is 2
   ✓ synchronous updates to the same atom > when effectIncrementCountBy is 1 and incrementCountBy is +0
   ✓ synchronous updates to the same atom > when effectIncrementCountBy is 1 and incrementCountBy is 1
   ✓ synchronous updates to the same atom > when effectIncrementCountBy is 1 and incrementCountBy is 2
   ✓ synchronous updates to the same atom > when effectIncrementCountBy is 2 and incrementCountBy is +0
   ✓ synchronous updates to the same atom > when effectIncrementCountBy is 2 and incrementCountBy is 1
   ✓ synchronous updates to the same atom > when effectIncrementCountBy is 2 and incrementCountBy is 2
   ✓ should batch effect setStates
   ✓ should batch synchronous updates as a single transaction
   ✓ should run the effect once even if the effect is mounted multiple times
   ✓ should abort the previous promise
   ✓ should not infinite loop with nested atomEffects
   ✓ should not rerun with get.peek
   ✓ should throw on set when an error is thrown in effect
   ✓ should throw on set when an error is thrown in cleanup
   ✓ should not suspend the component

 Test Files  1 passed (1)
      Tests  32 passed (32)
   Start at  02:51:18
   Duration  247ms

Check List

  • pnpm run fix:format for formatting code and docs

Copy link

vercel bot commented Jan 17, 2025

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Comments Updated (UTC)
jotai ✅ Ready (Inspect) Visit Preview 💬 Add feedback Jan 21, 2025 7:35pm

Copy link

codesandbox-ci bot commented Jan 17, 2025

This pull request is automatically built and testable in CodeSandbox.

To see build info of the built libraries, click here or the icon next to each commit SHA.

Copy link

pkg-pr-new bot commented Jan 17, 2025

Open in Stackblitz

More templates

npm i https://pkg.pr.new/jotai@2943

commit: 9147721

Copy link

github-actions bot commented Jan 17, 2025

LiveCodes Preview in LiveCodes

Latest commit: 9147721
Last updated: Jan 21, 2025 7:34pm (UTC)

Playground Link
React demo https://livecodes.io?x=id/C8G7VYMJW

See documentations for usage instructions.

@dmaskasky dmaskasky changed the title push sync effect tests for development [DO_NOT_MERGE] push sync effect tests for development Jan 17, 2025
@dmaskasky dmaskasky marked this pull request as draft January 17, 2025 04:58
@dmaskasky dmaskasky changed the title [DO_NOT_MERGE] push sync effect tests for development [DO_NOT_MERGE] sync effect development and testing Jan 17, 2025
@dmaskasky dmaskasky changed the title [DO_NOT_MERGE] sync effect development and testing [DO_NOT_MERGE] sync effect (V2) development and testing Jan 17, 2025
@dmaskasky dmaskasky closed this Jan 20, 2025
@dmaskasky dmaskasky deleted the sync-effect branch January 20, 2025 20:50
@dmaskasky dmaskasky restored the sync-effect branch January 20, 2025 20:56
@dmaskasky dmaskasky reopened this Jan 20, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant