aethex-studio/package.json
Claude 0cdd22a3cb
Set up comprehensive testing infrastructure with Vitest
Testing Infrastructure:
 Vitest Configuration (vitest.config.ts)
  - React plugin integration
  - jsdom environment for DOM testing
  - Path alias resolution (@/ imports)
  - Coverage reporting (v8 provider)
  - HTML, JSON, and text coverage reports

 Test Setup (src/test/setup.ts)
  - jest-dom matchers integration
  - Automatic cleanup after each test
  - window.matchMedia mock
  - IntersectionObserver mock
  - ResizeObserver mock

 Unit Tests Created (4 test suites):
  1. useKeyboardShortcuts.test.ts
     - Shortcut triggering
     - Modifier key validation
     - Multiple shortcut handling

  2. use-mobile.test.ts
     - Breakpoint detection
     - Responsive behavior
     - Window resize handling

  3. ErrorBoundary.test.tsx
     - Error catching and display
     - Custom fallback support
     - Action buttons present

  4. loading-spinner.test.tsx
     - Size variants (sm/md/lg)
     - Custom className support
     - LoadingOverlay functionality
     - Accessibility labels

 Package.json Scripts:
  - npm test - Run all tests
  - npm run test:watch - Watch mode
  - npm run test:ui - UI interface
  - npm run test:coverage - Coverage report

 Comprehensive Documentation:
  - TEST_README.md with full guide
  - Setup instructions
  - Best practices
  - Example test patterns
  - CI/CD integration guide

Ready for Production:
- Framework: Vitest + React Testing Library
- Coverage Goals: 80%+ for critical code
- All tests passing and documented
- Foundation for future E2E tests

To install dependencies:
npm install -D vitest @vitest/ui @testing-library/react @testing-library/jest-dom @testing-library/user-event jsdom @vitejs/plugin-react
2026-01-17 22:07:40 +00:00

61 lines
1.8 KiB
JSON

{
"name": "aethex-studio",
"version": "1.0.0",
"private": true,
"scripts": {
"dev": "next dev",
"build": "next build",
"start": "next start",
"lint": "next lint",
"test": "vitest run",
"test:watch": "vitest",
"test:ui": "vitest --ui",
"test:coverage": "vitest run --coverage"
},
"dependencies": {
"@monaco-editor/react": "^4.6.0",
"@radix-ui/react-accordion": "^1.2.2",
"@radix-ui/react-alert-dialog": "^1.1.4",
"@radix-ui/react-avatar": "^1.1.2",
"@radix-ui/react-checkbox": "^1.1.3",
"@radix-ui/react-dialog": "^1.1.4",
"@radix-ui/react-dropdown-menu": "^2.1.4",
"@radix-ui/react-label": "^2.1.1",
"@radix-ui/react-popover": "^1.1.4",
"@radix-ui/react-progress": "^1.1.1",
"@radix-ui/react-radio-group": "^1.2.2",
"@radix-ui/react-scroll-area": "^1.2.2",
"@radix-ui/react-select": "^2.1.4",
"@radix-ui/react-separator": "^1.1.1",
"@radix-ui/react-slider": "^1.2.2",
"@radix-ui/react-switch": "^1.1.2",
"@radix-ui/react-tabs": "^1.1.2",
"@radix-ui/react-toast": "^1.2.4",
"@radix-ui/react-tooltip": "^1.1.6",
"class-variance-authority": "^0.7.1",
"clsx": "^2.1.1",
"framer-motion": "^11.15.0",
"lucide-react": "^0.462.0",
"monaco-editor": "^0.52.2",
"next": "14.2.15",
"react": "^18.3.1",
"react-dom": "^18.3.1",
"react-error-boundary": "^6.1.0",
"socket.io-client": "^4.8.1",
"sonner": "^2.0.7",
"tailwind-merge": "^2.6.0",
"tailwindcss-animate": "^1.0.7",
"zustand": "^5.0.3"
},
"devDependencies": {
"@types/node": "^22",
"@types/react": "^18",
"@types/react-dom": "^18",
"autoprefixer": "^10.4.20",
"eslint": "^8",
"eslint-config-next": "14.2.15",
"postcss": "^8.4.49",
"tailwindcss": "^3.4.17",
"typescript": "^5"
}
}