aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/client/pages/LoginPage.test.tsx
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2026-01-04 17:43:59 +0900
committernsfisis <nsfisis@gmail.com>2026-01-04 19:09:58 +0900
commitf8e4be9b36a16969ac53bd9ce12ce8064be10196 (patch)
treeb2cf350d2e2e52803ff809311effb40da767d859 /src/client/pages/LoginPage.test.tsx
parente1c9e5e89bb91bca2586470c786510c3e1c03826 (diff)
downloadkioku-f8e4be9b36a16969ac53bd9ce12ce8064be10196.tar.gz
kioku-f8e4be9b36a16969ac53bd9ce12ce8064be10196.tar.zst
kioku-f8e4be9b36a16969ac53bd9ce12ce8064be10196.zip
refactor(client): migrate state management from React Context to Jotai
Replace AuthProvider and SyncProvider with Jotai atoms for more granular state management and better performance. This migration: - Creates atoms for auth, sync, decks, cards, noteTypes, and study state - Uses atomFamily for parameterized state (e.g., cards by deckId) - Introduces StoreInitializer component for subscription initialization - Updates all components and pages to use useAtomValue/useSetAtom - Updates all tests to use Jotai Provider with createStore pattern 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
Diffstat (limited to 'src/client/pages/LoginPage.test.tsx')
-rw-r--r--src/client/pages/LoginPage.test.tsx27
1 files changed, 17 insertions, 10 deletions
diff --git a/src/client/pages/LoginPage.test.tsx b/src/client/pages/LoginPage.test.tsx
index a3efa8d..6ed4011 100644
--- a/src/client/pages/LoginPage.test.tsx
+++ b/src/client/pages/LoginPage.test.tsx
@@ -3,11 +3,11 @@
*/
import { cleanup, render, screen, waitFor } from "@testing-library/react";
import userEvent from "@testing-library/user-event";
+import { createStore, Provider } from "jotai";
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
import { Router } from "wouter";
import { memoryLocation } from "wouter/memory-location";
-import { apiClient } from "../api/client";
-import { AuthProvider } from "../stores";
+import { authLoadingAtom } from "../atoms";
import { LoginPage } from "./LoginPage";
vi.mock("../api/client", () => ({
@@ -30,14 +30,18 @@ vi.mock("../api/client", () => ({
},
}));
+import { apiClient } from "../api/client";
+
function renderWithProviders(path = "/login") {
const { hook } = memoryLocation({ path });
+ const store = createStore();
+ store.set(authLoadingAtom, false);
return render(
- <Router hook={hook}>
- <AuthProvider>
+ <Provider store={store}>
+ <Router hook={hook}>
<LoginPage />
- </AuthProvider>
- </Router>,
+ </Router>
+ </Provider>,
);
}
@@ -156,12 +160,15 @@ describe("LoginPage", () => {
return [result[0], navigateSpy];
};
+ const store = createStore();
+ store.set(authLoadingAtom, false);
+
render(
- <Router hook={hookWithSpy}>
- <AuthProvider>
+ <Provider store={store}>
+ <Router hook={hookWithSpy}>
<LoginPage />
- </AuthProvider>
- </Router>,
+ </Router>
+ </Provider>,
);
await waitFor(() => {