[11팀 임재도][Chapter 1-1] 프레임워크 없이 SPA 만들기 #134
Annotations
20 errors and 3 warnings
src/__tests__/advanced.hashRouter.test.js:
src/__tests__/advanced.hashRouter.test.js#L12
TypeError: Cannot set properties of null (setting 'innerHTML')
❯ src/__tests__/advanced.hashRouter.test.js:12:45
|
src/__tests__/advanced.hashRouter.test.js > 심화과제 > 해시 라우터 테스트 > 1. 라우팅 구현 > "/login" 경로로 접근하면 로그인 페이지가 렌더링된다:
src/__tests__/advanced.hashRouter.test.js#L35
AssertionError: expected 1 to be +0 // Object.is equality
- Expected
+ Received
- 0
+ 1
❯ src/__tests__/advanced.hashRouter.test.js:35:63
|
src/__tests__/advanced.hashRouter.test.js > 심화과제 > 해시 라우터 테스트 > 1. 라우팅 구현 > 로그인이 되지 않은 상태에서 "/profile" 경로로 접근하면, 로그인 페이지로 리다이렉션 된다.:
src/__tests__/advanced.hashRouter.test.js#L47
AssertionError: expected 1 to be +0 // Object.is equality
- Expected
+ Received
- 0
+ 1
❯ src/__tests__/advanced.hashRouter.test.js:47:63
|
src/__tests__/advanced.hashRouter.test.js > 심화과제 > 해시 라우터 테스트 > 1. 라우팅 구현 > 존재하지 않는 경로로 접근하면 404 페이지가 렌더링된다:
src/__tests__/advanced.hashRouter.test.js#L54
AssertionError: expected '\n \n <div class="bg-gray-100 min-h…' to contain '404'
- Expected
+ Received
- 404
+
+
+ <div class="bg-gray-100 min-h-screen flex justify-center">
+ <div class="max-w-md w-full">
+ <header class="bg-blue-600 text-white p-4 sticky top-0">
+ <h1 class="text-2xl font-bold">항해플러스</h1>
+ </header>
+
+ <nav class="bg-white shadow-md p-2 sticky top-14">
+ <ul class="flex justify-around">
+ <li><a href="/" class="text-blue-600">홈</a></li>
+ <li><a href="/profile" class="text-gray-600">프로필</a></li>
+ <li><a href="#" class="text-gray-600">로그아웃</a></li>
+ </ul>
+ </nav>
+
+ <main class="p-4">
+ <div class="mb-4 bg-white rounded-lg shadow p-4">
+ <textarea class="w-full p-2 border rounded" placeholder="무슨 생각을 하고 계신가요?"></textarea>
+ <button class="mt-2 bg-blue-600 text-white px-4 py-2 rounded">게시</button>
+ </div>
+
+ <div class="space-y-4">
+
+ <div class="bg-white rounded-lg shadow p-4">
+ <div class="flex items-center mb-2">
+ <img src="https://via.placeholder.com/40" alt="프로필" class="rounded-full mr-2">
+ <div>
+ <p class="font-bold">홍길동</p>
+ <p class="text-sm text-gray-500">5분 전</p>
+ </div>
+ </div>
+ <p>오늘 날씨가 정말 좋네요. 다들 좋은 하루 보내세요!</p>
+ <div class="mt-2 flex justify-between text-gray-500">
+ <button>좋아요</button>
+ <button>댓글</button>
+ <button>공유</button>
+ </div>
+ </div>
+
+ <div class="bg-white rounded-lg shadow p-4">
+ <div class="flex items-center mb-2">
+ <img src="https://via.placeholder.com/40" alt="프로필" class="rounded-full mr-2">
+ <div>
+ <p class="font-bold">김철수</p>
+ <p class="text-sm text-gray-500">15분 전</p>
+ </div>
+ </div>
+ <p>새로운 프로젝트를 시작했어요. 열심히 코딩 중입니다!</p>
+ <div class="mt-2 flex justify-between text-gray-500">
+ <button>좋아요</button>
+ <button>댓글</button>
+ <button>공유</button>
+ </div>
+ </div>
+
+ <div class="bg-white rounded-lg shadow p-4">
+ <div class="flex items-center mb-2">
+ <img src="https://via.placeholder.com/40" alt="프로필" class="rounded-full mr-2">
+ <div>
+ <p class="font-bold">이영희</p>
+ <p class="text-sm text-gray-500">30분 전</p>
+ </div>
+ </div>
+ <p>오늘 점심 메뉴 추천 받습니다. 뭐가 좋을까요?</p>
+ <div class="mt-2 flex justify-between text-gray-500">
+ <button>좋아요</button>
+ <button>댓글</button>
+ <button>공유</button>
+ </div>
+ </div>
+
+ <div class="bg-white rounded-lg shadow p-4">
+ <div class="flex items-center mb-2">
+ <img src="https://via.placeholder.com/40" alt="프로필" class="rounded-full mr-2">
+ <div>
+ <p class="font-bold">박민수</p>
+ <p class="text-sm text-gray-500">1시간 전</p>
+ </div>
+ </div>
+ <p>주말에 등산 가실 분 계신가요? 함께 가요!</p>
+ <div class="mt-2 flex justify-between text-gray-500">
+ <button>좋아요</button>
+ <button>댓글</button>
+ <button>공유</button>
+ </div>
+ </div>
+
+ <div class="bg-white rounded-lg shadow p-4">
+ <div class="flex items-center mb-2">
+ <img src="https://via.placeholder.com/40" alt="프로필" class="rounded-full mr-2">
+ <div>
+ <p class="font-bold">정수연</p>
+ <p class="text-sm text-gray-500">2시간 전</p>
+ </div>
+ </div>
+ <p>새로 나온 영화 재미있대요. 같이 보러 갈 사람?</p>
+ <div class="mt-2 flex justify-between text-gray-500">
+
|
src/__tests__/advanced.test.js:
src/__tests__/advanced.test.js#L21
TypeError: Cannot set properties of null (setting 'innerHTML')
❯ src/__tests__/advanced.test.js:21:45
|
src/__tests__/advanced.test.js > 심화과제 테스트 > 2. 라우트 가드 구현 > 비로그인 사용자가 프로필 페이지에 접근시 로그인 페이지로 리다이렉트 한다.:
src/__tests__/advanced.test.js#L46
AssertionError: expected '\n <div id="root">\n <div class="…' to contain '로그인'
- Expected
+ Received
- 로그인
+
+ <div id="root">
+ <div class="bg-gray-100 min-h-screen flex justify-center">
+ <div class="max-w-md w-full">
+ <header class="bg-blue-600 text-white p-4 sticky top-0">
+ <h1 class="text-2xl font-bold">항해플러스</h1>
+ </header>
+
+ <nav class="bg-white shadow-md p-2 sticky top-14">
+ <ul class="flex justify-around">
+ <li><a href="/" class="text-gray-600">홈</a></li>
+ <li><a href="/profile" class="text-blue-600">프로필</a></li>
+ <li><a href="#" class="text-gray-600">로그아웃</a></li>
+ </ul>
+ </nav>
+
+ <main class="p-4">
+ <div class="bg-white p-8 rounded-lg shadow-md">
+ <h2 class="text-2xl font-bold text-center text-blue-600 mb-8">
+ 내 프로필
+ </h2>
+ <form>
+ <div class="mb-4">
+ <label for="username" class="block text-gray-700 text-sm font-bold mb-2">사용자 이름</label>
+ <input type="text" id="username" name="username" value="홍길동" class="w-full p-2 border rounded">
+ </div>
+ <div class="mb-4">
+ <label for="email" class="block text-gray-700 text-sm font-bold mb-2">이메일</label>
+ <input type="email" id="email" name="email" value="[email protected]" class="w-full p-2 border rounded">
+ </div>
+ <div class="mb-6">
+ <label for="bio" class="block text-gray-700 text-sm font-bold mb-2">자기소개</label>
+ <textarea id="bio" name="bio" rows="4" class="w-full p-2 border rounded">안녕하세요, 항해플러스에서 열심히 공부하고 있는 홍길동입니다.</textarea>
+ </div>
+ <button type="submit" class="w-full bg-blue-600 text-white p-2 rounded font-bold">
+ 프로필 업데이트
+ </button>
+ </form>
+ </div>
+ </main>
+
+ <footer class="bg-gray-200 p-4 text-center">
+ <p>© 2024 항해플러스. All rights reserved.</p>
+ </footer>
+ </div>
+ </div>
+ </div>
+
❯ src/__tests__/advanced.test.js:46:39
|
src/__tests__/advanced.test.js > 심화과제 테스트 > 2. 라우트 가드 구현 > 로그인된 사용자가 로그인 페이지에 접근시 메인 페이지로 리다이렉트 한다.:
src/__tests__/advanced.test.js#L54
TypeError: Cannot read properties of null (reading 'disabled')
❯ Object.type node_modules/@testing-library/user-event/dist/esm/utility/type.js:14:17
❯ node_modules/@testing-library/user-event/dist/esm/setup/setup.js:83:35
❯ Object.asyncWrapper node_modules/@testing-library/dom/dist/config.js:23:23
❯ wrapAsync node_modules/@testing-library/user-event/dist/esm/setup/wrapAsync.js:6:24
❯ Object.method [as type] node_modules/@testing-library/user-event/dist/esm/setup/setup.js:83:16
❯ src/__tests__/advanced.test.js:54:18
|
src/__tests__/advanced.test.js > 심화과제 테스트 > 3. 이벤트 위임 활용 > 네비게이션의 링크를 클릭에서 이벤트 전파를 막았을 때, 아무일도 일어나지 않는다.:
src/__tests__/advanced.test.js#L73
TypeError: Cannot read properties of null (reading 'addEventListener')
❯ src/__tests__/advanced.test.js:73:19
|
advacned
Process completed with exit code 1.
|
src/__tests__/basic.test.js:
src/__tests__/basic.test.js#L22
TypeError: Cannot set properties of null (setting 'innerHTML')
❯ src/__tests__/basic.test.js:22:45
|
src/__tests__/basic.test.js > 기본과제 테스트 > 1. 라우팅 구현 > 로그인이 되지 않은 상태에서 "/profile" 경로로 접근하면, 로그인 페이지로 리다이렉션 된다.:
src/__tests__/basic.test.js#L63
AssertionError: expected 1 to be +0 // Object.is equality
- Expected
+ Received
- 0
+ 1
❯ src/__tests__/basic.test.js:63:63
|
src/__tests__/basic.test.js > 기본과제 테스트 > 1. 라우팅 구현 > 존재하지 않는 경로로 접근하면 404 페이지가 렌더링된다:
src/__tests__/basic.test.js#L70
AssertionError: expected '\n <div id="root">\n <div class="…' to contain '404'
- Expected
+ Received
- 404
+
+ <div id="root">
+ <div class="bg-gray-100 min-h-screen flex justify-center">
+ <div class="max-w-md w-full">
+ <header class="bg-blue-600 text-white p-4 sticky top-0">
+ <h1 class="text-2xl font-bold">항해플러스</h1>
+ </header>
+
+ <nav class="bg-white shadow-md p-2 sticky top-14">
+ <ul class="flex justify-around">
+ <li><a href="/" class="text-gray-600">홈</a></li>
+ <li><a href="/profile" class="text-blue-600">프로필</a></li>
+ <li><a href="#" class="text-gray-600">로그아웃</a></li>
+ </ul>
+ </nav>
+
+ <main class="p-4">
+ <div class="bg-white p-8 rounded-lg shadow-md">
+ <h2 class="text-2xl font-bold text-center text-blue-600 mb-8">
+ 내 프로필
+ </h2>
+ <form>
+ <div class="mb-4">
+ <label for="username" class="block text-gray-700 text-sm font-bold mb-2">사용자 이름</label>
+ <input type="text" id="username" name="username" value="홍길동" class="w-full p-2 border rounded">
+ </div>
+ <div class="mb-4">
+ <label for="email" class="block text-gray-700 text-sm font-bold mb-2">이메일</label>
+ <input type="email" id="email" name="email" value="[email protected]" class="w-full p-2 border rounded">
+ </div>
+ <div class="mb-6">
+ <label for="bio" class="block text-gray-700 text-sm font-bold mb-2">자기소개</label>
+ <textarea id="bio" name="bio" rows="4" class="w-full p-2 border rounded">안녕하세요, 항해플러스에서 열심히 공부하고 있는 홍길동입니다.</textarea>
+ </div>
+ <button type="submit" class="w-full bg-blue-600 text-white p-2 rounded font-bold">
+ 프로필 업데이트
+ </button>
+ </form>
+ </div>
+ </main>
+
+ <footer class="bg-gray-200 p-4 text-center">
+ <p>© 2024 항해플러스. All rights reserved.</p>
+ </footer>
+ </div>
+ </div>
+ </div>
+
❯ src/__tests__/basic.test.js:70:39
|
src/__tests__/basic.test.js > 기본과제 테스트 > 2. 사용자 관리 기능 > 로그인 폼에서 사용자 이름을 입력하고 제출하면 로그인 되고, 로그아웃 버튼 클릭시 로그아웃 된다.:
src/__tests__/basic.test.js#L80
TypeError: Cannot read properties of null (reading 'disabled')
❯ Object.type node_modules/@testing-library/user-event/dist/esm/utility/type.js:14:17
❯ node_modules/@testing-library/user-event/dist/esm/setup/setup.js:83:35
❯ Object.asyncWrapper node_modules/@testing-library/dom/dist/config.js:23:23
❯ wrapAsync node_modules/@testing-library/user-event/dist/esm/setup/wrapAsync.js:6:24
❯ Object.method [as type] node_modules/@testing-library/user-event/dist/esm/setup/setup.js:83:16
❯ src/__tests__/basic.test.js:80:18
|
src/__tests__/basic.test.js > 기본과제 테스트 > 3. 프로필 페이지 구현 > 로그인한 사용자의 이름과 소개가 표시된다:
src/__tests__/basic.test.js#L103
TypeError: Cannot read properties of null (reading 'disabled')
❯ Object.type node_modules/@testing-library/user-event/dist/esm/utility/type.js:14:17
❯ node_modules/@testing-library/user-event/dist/esm/setup/setup.js:83:35
❯ Object.asyncWrapper node_modules/@testing-library/dom/dist/config.js:23:23
❯ wrapAsync node_modules/@testing-library/user-event/dist/esm/setup/wrapAsync.js:6:24
❯ Object.method [as type] node_modules/@testing-library/user-event/dist/esm/setup/setup.js:83:16
❯ src/__tests__/basic.test.js:103:18
|
src/__tests__/basic.test.js > 기본과제 테스트 > 3. 프로필 페이지 구현 > 로그인한 사용자의 이름과 소개가 표시된다:
src/__tests__/basic.test.js#L113
TypeError: Cannot read properties of null (reading 'click')
❯ src/__tests__/basic.test.js:113:40
|
src/__tests__/basic.test.js > 기본과제 테스트 > 3. 프로필 페이지 구현 > 프로필 수정 기능이 동작한다:
src/__tests__/basic.test.js#L103
TypeError: Cannot read properties of null (reading 'disabled')
❯ Object.type node_modules/@testing-library/user-event/dist/esm/utility/type.js:14:17
❯ node_modules/@testing-library/user-event/dist/esm/setup/setup.js:83:35
❯ Object.asyncWrapper node_modules/@testing-library/dom/dist/config.js:23:23
❯ wrapAsync node_modules/@testing-library/user-event/dist/esm/setup/wrapAsync.js:6:24
❯ Object.method [as type] node_modules/@testing-library/user-event/dist/esm/setup/setup.js:83:16
❯ src/__tests__/basic.test.js:103:18
|
src/__tests__/basic.test.js > 기본과제 테스트 > 3. 프로필 페이지 구현 > 프로필 수정 기능이 동작한다:
src/__tests__/basic.test.js#L113
TypeError: Cannot read properties of null (reading 'click')
❯ src/__tests__/basic.test.js:113:40
|
src/__tests__/basic.test.js > 기본과제 테스트 > 4. 컴포넌트 기반 구조 설계 > Header, Footer 컴포넌트가 메인 페이지와 프로필 페이지에 존재하고, 로그인페이지와 에러페이지에는 존재하지 않는다.:
src/__tests__/basic.test.js#L143
TypeError: Cannot read properties of null (reading 'disabled')
❯ Object.type node_modules/@testing-library/user-event/dist/esm/utility/type.js:14:17
❯ node_modules/@testing-library/user-event/dist/esm/setup/setup.js:83:35
❯ Object.asyncWrapper node_modules/@testing-library/dom/dist/config.js:23:23
❯ wrapAsync node_modules/@testing-library/user-event/dist/esm/setup/wrapAsync.js:6:24
❯ Object.method [as type] node_modules/@testing-library/user-event/dist/esm/setup/setup.js:83:16
❯ src/__tests__/basic.test.js:143:18
|
src/__tests__/basic.test.js > 기본과제 테스트 > 5. 상태 관리 구현 > 로그인 상태에 따라 UI가 변경된다:
src/__tests__/basic.test.js#L189
TypeError: Cannot read properties of null (reading 'disabled')
❯ Object.type node_modules/@testing-library/user-event/dist/esm/utility/type.js:14:17
❯ node_modules/@testing-library/user-event/dist/esm/setup/setup.js:83:35
❯ Object.asyncWrapper node_modules/@testing-library/dom/dist/config.js:23:23
❯ wrapAsync node_modules/@testing-library/user-event/dist/esm/setup/wrapAsync.js:6:24
❯ Object.method [as type] node_modules/@testing-library/user-event/dist/esm/setup/setup.js:83:16
❯ src/__tests__/basic.test.js:189:18
|
e2e
Process completed with exit code 1.
|
advacned
ubuntu-latest pipelines will use ubuntu-24.04 soon. For more details, see https://github.com/actions/runner-images/issues/10636
|
basic
ubuntu-latest pipelines will use ubuntu-24.04 soon. For more details, see https://github.com/actions/runner-images/issues/10636
|
e2e
ubuntu-latest pipelines will use ubuntu-24.04 soon. For more details, see https://github.com/actions/runner-images/issues/10636
|