Rumah >pembangunan bahagian belakang >tutorial php >Petua untuk melaksanakan ujian prestasi kod menggunakan PHP dan PHPUnit
Dalam pembangunan perisian moden, prestasi kod adalah aspek yang sangat penting. Jika kod anda dilaksanakan dengan perlahan, program anda akan berjalan perlahan, yang akan kehilangan kepercayaan dan kesetiaan pengguna anda. Untuk mengkaji dan menala prestasi kod, anda memerlukan alat untuk menyiasat dan menganalisis tingkah laku kod anda. Dalam artikel ini, kita akan belajar cara menggunakan PHP dan PHPUnit untuk ujian prestasi kod.
PHPUnit ialah rangka kerja ujian PHP yang popular yang bukan sahaja boleh melaksanakan ujian unit tetapi juga ujian berfungsi. Ujian fungsi PHPUnit boleh mensimulasikan senario ujian dalam persekitaran sebenar. Ujian menentukan kes ujian dan kecekapan pelaksanaan kod anda. Ia juga boleh digunakan untuk ujian semasa kitaran hayat projek, mengenal pasti isu prestasi dan mengoptimumkan kod.
Untuk menguji prestasi kod, kita perlu menggunakan beberapa komponen yang disertakan bersama PHPUnit iaitu PHPUnit_Framework_TestSuite, PHPUnit_Framework_TestCase dan PHPUnit_Util_Testdox_ResultPrinter. Berikut ialah beberapa petua yang boleh anda gunakan semasa menguji prestasi kod PHP anda.
Kami boleh menambah tag anotasi (@kumpulan) dalam pengepala kaedah ujian untuk membezakan kaedah ujian tahap prestasi yang berbeza, contohnya:
/** * @group slow */ public function testSlow() { //code to test goes here }
Dalam baris arahan, kita boleh memilih sahaja Jalankan kumpulan ujian tertentu, contohnya:
phpunit --group slow
Ini hanya akan menjalankan kaedah ujian yang ditandakan sebagai lambat untuk menjimatkan masa.
Rangka kerja PHPUnit menyediakan kes ujian berfungsi, yang boleh menguji operasi tertentu dengan mudah. Menggunakan kes ujian ini, kami boleh menguji isu prestasi asas dari segi kependaman, masa pemprosesan, I/O, dsb.
Berikut ialah contoh ujian kelewatan menggunakan kes ujian yang disertakan dengan PHPUnit:
class DelayTest extends PHPUnit_Framework_TestCase { public function testExecutionTime() { $this->assertGreaterThan( 10000, //expected time in microseconds $this->getExecutionTime() ); } protected function getExecutionTime() { $start = microtime(true); //your code implementation usleep(10000000); //delay for 10 seconds return microtime(true) - $start; } }
Melalui kaedah getExecutionTime, kita boleh mendapatkan masa yang diperlukan untuk pelaksanaan, dan menggunakan kaedah assertGreaterThan() yang disediakan oleh PHPUnit untuk menentukan sama ada masa yang diperlukan untuk pelaksanaan telah melebihi Masa yang dikehendaki yang kami tetapkan.
Apabila melakukan pemprosesan data dan analisis algoritma berskala besar, ujian prestasi adalah sangat penting, kerana isu prestasi selalunya menjadi hambatan utama yang perlu kita optimumkan. Oleh itu, kami perlu melakukan ujian prestasi algoritma dan struktur data untuk mengenal pasti kemungkinan kesesakan.
Berikut ialah contoh penggunaan PHPUnit untuk menguji prestasi algoritma isihan pantas:
class QuickSortTest extends PHPUnit_Framework_TestCase { /** * @test * @group performance */ public function testQuickSortPerformance() { $this->markTestSkipped(); //skip the test $data = range(1, 500); shuffle($data); $start = microtime(true); $quickSort = new QuickSort(); $quickSort->sort($data); $end = microtime(true); $this->assertLessThan(0.02, $end - $start); //check execution time } }
Dalam contoh ini, kami menggunakan algoritma isihan pantas yang ditulis sendiri yang telah ditambahkan pada pangkalan kod kami. Kami boleh menggunakan kaedah PHPUnit_Framework_TestCase::markTestSkipped() PHPUnit untuk menandakan ujian yang ingin kami langkau untuk mengelak daripada menjalankan ujian setiap kali ujian dijalankan.
Akhir sekali, kami boleh menggunakan pelbagai alat analisis dan pemalam dalam komponen ujian PHPUnit untuk memahami lebih lanjut isu prestasi. Komponen PHPUnit_Framework_TestSuite membolehkan kami mengumpul dan menganalisis data terperinci dan maklumat keputusan semasa melaksanakan ujian.
class CustomTestResultPrinter extends PHPUnit_Util_Testdox_ResultPrinter { public function addError(PHPUnit_Framework_Test $test, Exception $exception, $time) { //print out custom message $this->write('Error: ' . $test->getName()); parent::addError($test, $exception, $time); } public function addFailure(PHPUnit_Framework_Test $test, PHPUnit_Framework_AssertionFailedError $exception, $time) { //print out custom message $this->write('Failure: ' . $test->getName()); parent::addFailure($test, $exception, $time); } }
Dalam contoh ini, kami mencipta Pencetak Keputusan Ujian tersuai untuk memaparkan keputusan ujian dan mencetak mesej kami sendiri. Kita boleh menentukan tingkah laku kita sendiri menggunakan kaedah addFailure() dan addError(). Apabila menjalankan PHPUnit, kami boleh menentukan Pencetak Hasil Ujian kami sendiri menggunakan pilihan --printer.
Ringkasan
Dalam artikel ini, kami mempelajari cara menggunakan PHP dan PHPUnit untuk ujian prestasi. Menggunakan teg anotasi, ujian fungsi PHPUnit sendiri, menguji kecekapan pelaksanaan algoritma dan struktur data, dan komponen ujian PHPUnit untuk menganalisis isu prestasi dan teknik lain boleh membantu kami lebih memahami dan mengoptimumkan isu prestasi dalam pembangunan. Kedua, ujian bukan sahaja boleh digunakan untuk menemui dan membetulkan masalah prestasi Semasa kitaran hayat projek, ujian boleh membantu menstabilkan dan mengesahkan kod, dan meningkatkan kebolehselenggaraan dan kebolehskalaan.
Atas ialah kandungan terperinci Petua untuk melaksanakan ujian prestasi kod menggunakan PHP dan PHPUnit. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!