Why Use This
This skill provides specialized capabilities for HoangNguyen0403's codebase.
Use Cases
- Developing new features in the HoangNguyen0403 repository
- Refactoring existing code to follow HoangNguyen0403 standards
- Understanding and working with HoangNguyen0403's codebase structure
Install Guide
2 steps - 1
- 2
Install inside Ananke
Click Install Skill, paste the link below, then press Install.
https://github.com/HoangNguyen0403/agent-skills-standard/tree/develop/skills/react/testing
Skill Snapshot
Auto scan of skill assets. Informational only.
Valid SKILL.md
Checks against SKILL.md specification
Source & Community
Updated At Jan 18, 2026, 04:24 AM
Skill Stats
SKILL.md 46 Lines
Total Files 1
Total Size 0 B
License NOASSERTION
---
name: React Testing
description: Testing strategies with RTL and Jest/Vitest.
metadata:
labels: [react, testing, jest, vitest]
triggers:
files: ['**/*.test.tsx', '**/*.spec.tsx']
keywords: [render, screen, userEvent, expect]
---
# React Testing
## **Priority: P2 (MAINTENANCE)**
Reliable tests focusing on user behavior.
## Implementation Guidelines
- **Tooling**: React Testing Library + Vitest.
- **Philosophy**: Test behavior, not implementation (State/Internal vars).
- **Queries**: `getByRole` > `getByText` > `getByTestId`.
- **Events**: Use `userEvent` (async) over `fireEvent`.
- **Async**: `await screen.findBy*` for async updates.
- **Mocks**: MSW for network. Mock heavy 3rd-party libs.
- **Accessibility**: Testing Lib implicitly tests a11y roles.
## Anti-Patterns
- **No Shallow Rendering**: Render full tree.
- **No Testing Implementation Details**: Don't check `component.state`.
- **No Wait**: Use `findBy`, avoid `waitFor` if possible.
## Code
```tsx
test('submits form', async () => {
const user = userEvent.setup();
render(<LoginForm />);
await user.type(screen.getByLabelText(/email/i), '[email protected]');
await user.click(screen.getByRole('button', { name: /login/i }));
expect(await screen.findByText(/welcome/i)).toBeInTheDocument();
});
```