ホームページ >ウェブフロントエンド >jsチュートリアル >React テスト: 包括的なガイド
?テストの概要
テストは、コードが期待どおりに機能することを確認するソフトウェア開発における重要なプロセスです。これは、作業をダブルチェックしてエラーやバグを回避し、アプリケーションの全体的な品質を向上させることだと考えてください。 React では、コードの一部の変更が他の部分に影響を与える可能性があるコンポーネントベースの構造のため、テストはさらに重要です。
⚛️ Jest と React テスト ライブラリを使用した React テスト
React アプリケーションの信頼性を維持するために、Jest と React Testing Library (RTL) という 2 つのツールが広く使用されています。これらは、包括的で信頼性の高いテストを作成するための強力な機能を提供することで相互に補完します。
• Jest は、テスト ランナー、アサーション、モック機能を提供する JavaScript テスト フレームワークで、React での単体テストと統合テストに最適です。
• React テスト ライブラリは、DOM 要素とのユーザー操作をシミュレートすることで React コンポーネントの UI をテストすることに重点を置き、コンポーネントが期待どおりに動作することを確認します。
? React でのテストの重要性
React のコンポーネントベースのアーキテクチャでは、堅牢なテストが不可欠です。 1 つのコンポーネントを変更すると、他のコンポーネントに誤って影響を与える可能性があります。テストにより、各コンポーネントが独立して動作し、アプリケーション全体に正しく統合されていることを確認します。
? React テスト ライブラリ
React Testing Library は、ユーザーがコンポーネントを操作するのと同じようにコンポーネントをテストすることを推奨します。ボタンのクリック、フォームへの入力、ナビゲーションなどの実際のユーザーの行動に焦点を当てることで、アプリが実際にどのように使用されるかをテストに確実に反映できます。
主な利点:
• ユーザーインタラクションをシミュレートし、テストの信頼性を向上させます。
• 実際の DOM 操作に焦点を当て、テストをより有意義なものにします。
⁉️冗談の紹介
Jest は、高速で使いやすい機能が豊富なテスト フレームワークです。それは以下を提供します:
• テストを実行するテスト ランナー。
• 特定の条件が満たされているかどうかを確認するアサーション。
• 分離テスト用のモジュールとコンポーネントをシミュレートするためのモック。
Jest はパフォーマンスが高く、ほとんどの React アプリ、特に Create React App (CRA) を使用する場合に事前構成されています。
⁉️ テスト環境のセットアップ
Create React App (CRA) を使用している場合、テスト環境は Jest および React Testing Library で事前構成されています。この設定により、手動構成を行わずに直接テストの作成に取り掛かることができます。
バッシュ
コードをコピー
npx create-react-app my-app
cd マイアプリ
npm テスト
CRA をセットアップしたら、テストを作成して実行する準備が整います。
?️ テスト ファイルの規則
テスト ファイルを整理するときは、.test.js や .spec.js などの命名規則に従って、ソース ファイルと一緒にテストを簡単に識別してグループ化します。これは、Jest のようなテスト ランナーがテストを自動的に検出して実行するのにも役立ちます。
✅ Todo アプリの例
React での主要なテスト シナリオを示す簡単な Todo アプリの例を見てみましょう。
• タスクの追加: 送信ボタンをクリックしたときにタスクがリストに追加されるかどうかをテストします。
• タスクの完了: タスクを完了としてマークできるかどうかをテストします。
• タスクの削除: タスクを削除する機能をテストします。
• タスクのフィルタリング: フィルタをテストして、アクティブなタスクまたは完了したタスクのみを表示します。
js
コードをコピー
test('新しい Todo を追加', () => {
render();
const input = screen.getByPlaceholderText('新しいタスクを追加');
fireEvent.change(input, { target: { value: 'Test Todo' } });
fireEvent.click(screen.getByText('Add'));
Expect(screen.getByText('Test Todo')).toBeInTheDocument();
});
?ジェスト構文
Jest では通常、describe ブロックを使用して関連するテストをグループ化し、テストを使用して個々のケースを定義します。 Expect 関数は、値が特定の条件を満たすことをアサートします。
js
コードをコピー
description('Todo アプリ', () => {
test('Todo アプリを正しくレンダリングする必要があります', () => {
render();
Expect(screen.getByText('Todo の追加')).toBeInTheDocument();
});
});
?テストの作成
テストを作成するときは、コンポーネントの機能を完全にカバーするために、コンポーネントのレンダリング、ユーザー インタラクション (クリック、入力) のシミュレーション、および非同期動作 (API 呼び出しなど) の処理に重点を置きます。
主要なテスト シナリオ:
以上がReact テスト: 包括的なガイドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。