feat: Clerk + Supabase 통합 시스템 구현 완료
주요 변경사항: • Clerk 인증 시스템 통합 및 설정 • Supabase 데이터베이스 스키마 설계 및 적용 • JWT 기반 Row Level Security (RLS) 정책 구현 • 기존 Appwrite 인증을 Clerk로 완전 교체 기술적 개선: • 무한 로딩 문제 해결 - Index.tsx 인증 로직 수정 • React root 마운팅 오류 수정 - main.tsx 개선 • CORS 설정 추가 - vite.config.ts 수정 • Sentry 에러 모니터링 통합 추가된 컴포넌트: • AuthGuard: 인증 보호 컴포넌트 • SignIn/SignUp: Clerk 기반 인증 UI • ClerkProvider: Clerk 설정 래퍼 • EnvTest: 개발환경 디버깅 도구 데이터베이스: • user_profiles, transactions, budgets, category_budgets 테이블 • Clerk JWT 토큰 기반 RLS 정책 • 자동 사용자 프로필 생성 및 동기화 Task Master: • Task 11.1, 11.2, 11.4 완료 • 프로젝트 관리 시스템 업데이트 Note: ESLint 정리는 별도 커밋에서 진행 예정 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
51
debug-test-simple.js
Normal file
51
debug-test-simple.js
Normal file
@@ -0,0 +1,51 @@
|
||||
import { chromium } from "playwright";
|
||||
|
||||
(async () => {
|
||||
const browser = await chromium.launch({ headless: false });
|
||||
const page = await browser.newPage();
|
||||
|
||||
// 콘솔 메시지 수집
|
||||
page.on("console", (msg) => {
|
||||
console.log(`[CONSOLE ${msg.type().toUpperCase()}] ${msg.text()}`);
|
||||
});
|
||||
|
||||
// 에러 메시지 수집
|
||||
page.on("pageerror", (err) => {
|
||||
console.log(`[PAGE ERROR] ${err.message}`);
|
||||
});
|
||||
|
||||
// 네트워크 요청 모니터링
|
||||
page.on("response", (response) => {
|
||||
if (!response.ok()) {
|
||||
console.log(`[NETWORK ERROR] ${response.status()} ${response.url()}`);
|
||||
}
|
||||
});
|
||||
|
||||
try {
|
||||
console.log("페이지 로딩 시작...");
|
||||
await page.goto("http://localhost:3000", {
|
||||
waitUntil: "domcontentloaded",
|
||||
timeout: 30000,
|
||||
});
|
||||
|
||||
console.log("페이지 로딩 완료");
|
||||
|
||||
// 5초 기다려서 로딩 상태 확인
|
||||
await page.waitForTimeout(5000);
|
||||
|
||||
// 페이지 내용 확인
|
||||
const title = await page.title();
|
||||
const content = await page.textContent("body");
|
||||
|
||||
console.log("페이지 제목:", title);
|
||||
console.log("페이지 내용 (앞부분):", content.substring(0, 200));
|
||||
|
||||
// 스크린샷 찍기
|
||||
await page.screenshot({ path: "debug-screenshot-current.png" });
|
||||
console.log("스크린샷 저장됨: debug-screenshot-current.png");
|
||||
} catch (error) {
|
||||
console.error("에러 발생:", error.message);
|
||||
}
|
||||
|
||||
await browser.close();
|
||||
})();
|
||||
Reference in New Issue
Block a user