私たちはよくこのような状況に遭遇します。つまり、まったくテストされていないレガシー コードを書き直してテストすることですが、これらのコードでさえ依然としてオブジェクト指向モードで記述されています。このようなコードをテストする場合の私のアドバイスは、テストしやすいようにコードをいくつかのチャンクに分割することです。
ただし、これらのレガシー コードは、元のプログラムへの影響を避けるため、テスト前にコードを書き直すことはそれほど簡単ではありません。もちろん、単体テストを実行することも簡単ではありません。
PHP プログラムでは、通常、コードの一部が複数の Index.php および script.php ファイルに記述されており、これらの .php ファイルは複数の異なるフォルダーに保存されます。エントリ ポイントが見つからない場合、Web サーバーから直接アクセスすることはできません。
テストコピー
PHP スクリプトをテストするには、HTTP リクエストをシミュレートし、返された応答が期待値と等しいかどうかを確認する必要があります。ここで注意が必要なのは、リクエストをシミュレートし、レスポンスとリクエストの内容が異なるだけでなく、ヘッダーも異なることです。
さらに、データを操作するトランザクション スクリプトをテストする場合は、それが実際のデータベースやアプリケーションの残りの部分に接続しないようにする必要があります。
実際には、通常、テストのために元の PHP スクリプトを直接書き直す人は誰もいません。コードが回復不能になるのが怖いからです。 PHP コードに簡単な操作を実行できるように、PHP スクリプトのコピーを使用することをお勧めします。
コードに最小限の変更を加える方法: include ステートメントと require ステートメント (使用されていない場合) を削除し、内部関数の呼び出し方法を変更します。たとえば、header() を $object->header() として記述します。
最後に、このトランザクション スクリプトをテストしてみましょう。テスト後、複製スクリプトからそれらを抽出し、新しいスクリプト ファイルに配置できます。
具体的な手順
1. HTTP リクエストをシミュレートし、変数 $_GET および $_POST を再定義し、$_SERVER のヘッダーも変更します。
2. リクエストのレスポンスを取得します。レスポンスの本文は、ob_start() および ob_get_clean() を使用して取得できます。
注: 出力バッファリングは PHP の複数レベルのネストをサポートしているため、スクリプトが ob_* 呼び出し自体を使用している場合でも、ほとんどの場合、出力バッファリングがキャプチャされます。3. テスト スクリプトには、このスクリプトの範囲内のすべてのメソッドを呼び出せるように、トランザクション スクリプトの内部メソッドが含まれている必要があります。例:
1. スクリプトに必要な変数は、ローカル変数として定義してカプセル化できます (データベース接続としての $connection など)。
2. これは PHP のオリジナルの組み込み関数ではありません。たとえば、header() は $this->header() として記述されます。
特定のコード
これはテストしたいトランザクション スクリプト オブジェクトであり、これをカプセル化する必要もあります:
クラスフォーラム投稿
{
private $headers = array();
パブリック関数 handleRequest($postRequest)
{
$_POST = $postRequest;
$connection = $this->getAConnection();
ob_start();
「forum/post_new_copy.php」をインクルードします;
$content = ob_get_clean();
配列を返します(
'content' => $content,
'ヘッダー' => $this->ヘッダー
);
}
プライベート関数ヘッダー($headerLine)
{
$this->headers[] = $headerLine;
}
...
}
これは私たちのテストコードです:
パブリック関数 testANewPostIsCreated()
{
$action = new ForumPosting();
$response = $action->handleRequest(array(
'id_thread' => 42,
'text' => 'Hello, world',
...
));
$this->assertEquals('...', $response['content']);
$this->assertContains('Content-type: text/html', $response['headers']);
}
結論
テスト コピーは一時的なものであり、作成したテストが変更されるのを防ぎます。最後に、テストに合格した PHP スクリプトをリファクタリングして、冗長なコードを削除します。
テストが完了すると、handleRequest() の内容を実際のロジック コードに置き換えることができます。このようなテスト スクリプトを多数作成する場合は、テストのニーズを満たす一般的なテスト オブジェクトを作成できます。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

Dreamweaver Mac版
ビジュアル Web 開発ツール

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、
